commit | 7138b07c622049151506a0d7f9541cbe42b2ae2b | [log] [tgz] |
---|---|---|
author | mschaller <mschaller@google.com> | Fri Sep 28 10:14:11 2018 -0700 |
committer | Copybara-Service <copybara-piper@google.com> | Fri Sep 28 10:15:34 2018 -0700 |
tree | e82c80c02a95252b86a68f26186887eb7dbdf2a0 | |
parent | 610e8ff2baebe996eee8dfea1c13be554c9464ff [diff] |
Mark nodes to be force-rebuilt during node restarting Non-deterministic nodes may evaluate to different values after being restarted. By ensuring that the nodes are "force-rebuilt" after a restart, such a situation won't result in a crash. Because restarted nodes are no longer dirtied with isChanged=true, the assertion logic that ensures that nodes are not dirtied twice with the same value for isChanged can go back into the #markDirty method. In other words, this CL includes a logical rollback of "Permit marking dirty/changed a node more than once". This also fixes a race condition bug where a dep which is restarted by >1 parent could cause a crash if the dep was inflight when the later restart attempted to dirty it. RELNOTES: None. PiperOrigin-RevId: 214954192
{Fast, Correct} - Choose two
Build and test software of any size, quickly and reliably.
Speed up your builds and tests: Bazel only rebuilds 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
Bazel is released in ‘Beta’. See the product roadmap to learn about the path toward a stable 1.0 release.