No description
802e9759cd
Modules that want properties that vary by variant often need to create zeroed copies of property structs. Add CloneEmptyProperties to proptools that is the equivalent of calling CloneProperties and then ZeroProperties, but is much faster because it directly creates zeroed objects. Saves 200ms in Context.ParseBlueprintsFiles and Context.ResolveDependencies in one case, which will be valuble when we start parsing Blueprints files for cases where we are not regenerating the manifest, for example when generating documentation or doing context-aware bpfmt. Change-Id: I3d4a6af2f393886d95f27d15afc1a455d8dd5fc6 |
||
---|---|---|
bootstrap | ||
bpfmt | ||
bpmodify | ||
deptools | ||
parser | ||
pathtools | ||
proptools | ||
.travis.yml | ||
Blueprints | ||
bootstrap.bash | ||
build.ninja.in | ||
context.go | ||
context_test.go | ||
CONTRIBUTING.md | ||
doc.go | ||
LICENSE | ||
live_tracker.go | ||
mangle.go | ||
module_ctx.go | ||
ninja_defs.go | ||
ninja_strings.go | ||
ninja_strings_test.go | ||
ninja_writer.go | ||
ninja_writer_test.go | ||
package_ctx.go | ||
README.md | ||
scope.go | ||
singleton_ctx.go | ||
splice_modules_test.go | ||
unpack.go | ||
unpack_test.go |
Blueprint Build System
Blueprint is a meta-build system that reads in Blueprints files that describe modules that need to be built, and produces a Ninja manifest describing the commands that need to be run and their dependencies. Where most build systems use built-in rules or a domain-specific language to describe the logic for converting module descriptions to build rules, Blueprint delegates this to per-project build logic written in Go. For large, heterogenous projects this allows the inherent complexity of the build logic to be maintained in a high-level language, while still allowing simple changes to individual modules by modifying easy to understand Blueprints files.