commit | acbceddd97fb86dca96d0cd1ec45807335d7f7fc | [log] [tgz] |
---|---|---|
author | tanzhengwei <tanzhengwei@google.com> | Tue Feb 09 06:00:31 2021 -0800 |
committer | Copybara-Service <copybara-worker@google.com> | Tue Feb 09 06:01:37 2021 -0800 |
tree | 42551dbe7d4ac0a0fd4f34b4889087cd9540afe8 | |
parent | b571f2c1b9272a14710e15f719dff8af86b79f06 [diff] |
Sort output of `query --order_output=auto` lexicographically by default. The `--incompatible_lexicographical_output` flag has two effects when used together with `--order_output=auto`: 1. It sorts the output lexicographically. 2. It uses the graphless query implementation. Sorting the output lexicographically allows us to make the outputs of query and genquery consistent. By using the graphless query implementation, query performance improves by at least ~60% in wall time (from some of our benchmarks). The flag is ignored when `somepath` is used as a top level function (e.g. `query 'somepath(a,b)'`), and continue to output in dependency order instead of lexicographical order. Using `--order_output=no` would make query even faster if you do not require a lexicographically sorted or deterministic output. RELNOTES[INC]: Query `--order_output=auto` will now sort lexicographically. However, when `somepath` is used as a top level function (e.g. `query 'somepath(a, b)'`), it will continue to output in dependency order. If you do not want the lexicographical output ordering, specify another `--order_output` value (`no`, `deps` or `full`) based on what ordering you require. PiperOrigin-RevId: 356483939
{Fast, Correct} - Choose two
Build and test software of any size, quickly and reliably.
Speed up your builds and tests: Bazel rebuilds only what is necessary. With advanced local and distributed caching, optimized dependency analysis and parallel execution, you get fast and incremental builds.
One tool, multiple languages: Build and test Java, C++, Android, iOS, Go, and a wide variety of other language platforms. Bazel runs on Windows, macOS, and Linux.
Scalable: Bazel helps you scale your organization, codebase, and continuous integration solution. It handles codebases of any size, in multiple repositories or a huge monorepo.
Extensible to your needs: Easily add support for new languages and platforms with Bazel's familiar extension language. Share and re-use language rules written by the growing Bazel community.
Follow our tutorials:
See CONTRIBUTING.md