blueprint

package module
v0.0.0-...-36bb07c Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: May 11, 2015 License: Apache-2.0 Imports: 19 Imported by: 0

README

Blueprint Build System

Build Status

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.

Documentation

Overview

Blueprint is a meta-build system that reads in Blueprints files that describe modules that need to be built, and produces a Ninja (http://martine.github.io/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 how modules are converted 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.

Blueprint uses a bootstrapping process to allow the code for Blueprint, the code for the build logic, and the code for the project being compiled to all live in the project. Dependencies between the layers are fully tracked - a change to the logic code will cause the logic to be recompiled, regenerate the project build manifest, and run modified project rules. A change to Blueprint itself will cause Blueprint to rebuild, and then rebuild the logic, etc.

A Blueprints file is a list of modules in a pseudo-python data format, where the module type looks like a function call, and the properties of the module look like optional arguments. For example, a simple module might look like:

cc_library(
    name = "cmd",
    srcs = [
        "main.c",
    ],
    deps = [
        "libc",
    ],
)

subdirs = ["subdir1", "subdir2"]

The modules from the top level Blueprints file and recursively through any subdirectories listed by the "subdirs" variable are read by Blueprint, and their properties are stored into property structs by module type. Once all modules are read, Blueprint calls any registered Mutators, in registration order. Mutators can visit each module top-down or bottom-up, and modify them as necessary. Common modifications include setting properties on modules to propagate information down from dependers to dependees (for example, telling a module what kinds of parents depend on it), or splitting a module into multiple variants (for example, one per architecture being compiled). After all Mutators have run, each module is asked to generate build rules based on property values, and then singletons can generate any build rules from the output of all modules.

The per-project build logic defines a top level command, referred to in the documentation as the "primary builder". This command is responsible for registering the module types needed for the project, as well as any singletons or mutators, and then calling into Blueprint with the path of the root Blueprint file.

Index

Constants

This section is empty.

Variables

View Source
var ErrBuildActionsNotReady = errors.New("build actions are not ready")

Functions

This section is empty.

Types

type BaseModuleContext

type BaseModuleContext interface {
	ModuleName() string
	ModuleDir() string
	Config() interface{}

	ContainsProperty(name string) bool
	Errorf(pos scanner.Position, fmt string, args ...interface{})
	ModuleErrorf(fmt string, args ...interface{})
	PropertyErrorf(property, fmt string, args ...interface{})
	Failed() bool
}

type BottomUpMutator

type BottomUpMutator func(mctx BottomUpMutatorContext)

type BottomUpMutatorContext

type BottomUpMutatorContext interface {
	AddDependency(module Module, name string)
	CreateVariations(...string) []Module
	SetDependencyVariation(string)
	// contains filtered or unexported methods
}

type BuildParams

type BuildParams struct {
	Rule      Rule              // The rule to invoke.
	Outputs   []string          // The list of output targets.
	Inputs    []string          // The list of explicit input dependencies.
	Implicits []string          // The list of implicit dependencies.
	OrderOnly []string          // The list of order-only dependencies.
	Args      map[string]string // The variable/value pairs to set.
	Optional  bool              // Skip outputting a default statement
}

A BuildParams object contains the set of parameters that make up a Ninja build statement. Each field except for Args corresponds with a part of the Ninja build statement. The Args field contains variable names and values that are set within the build statement's scope in the Ninja file.

type Context

type Context struct {
	// contains filtered or unexported fields
}

A Context contains all the state needed to parse a set of Blueprints files and generate a Ninja file. The process of generating a Ninja file proceeds through a series of four phases. Each phase corresponds with a some methods on the Context object

      Phase                            Methods
   ------------      -------------------------------------------
1. Registration         RegisterModuleType, RegisterSingletonType

2. Parse                    ParseBlueprintsFiles, Parse

3. Generate            ResolveDependencies, PrepareBuildActions

4. Write                           WriteBuildFile

The registration phase prepares the context to process Blueprints files containing various types of modules. The parse phase reads in one or more Blueprints files and validates their contents against the module types that have been registered. The generate phase then analyzes the parsed Blueprints contents to create an internal representation for the build actions that must be performed. This phase also performs validation of the module dependencies and property values defined in the parsed Blueprints files. Finally, the write phase generates the Ninja manifest text based on the generated build actions.

func NewContext

func NewContext() *Context

NewContext creates a new Context object. The created context initially has no module or singleton factories registered, so the RegisterModuleFactory and RegisterSingletonFactory methods must be called before it can do anything useful.

func (*Context) AllTargets

func (c *Context) AllTargets() (map[string]string, error)

AllTargets returns a map all the build target names to the rule used to build them. This is the same information that is output by running 'ninja -t targets all'. If this is called before PrepareBuildActions successfully completes then ErrbuildActionsNotReady is returned.

func (*Context) ParseBlueprintsFiles

func (c *Context) ParseBlueprintsFiles(rootFile string) (deps []string,
	errs []error)

ParseBlueprintsFiles parses a set of Blueprints files starting with the file at rootFile. When it encounters a Blueprints file with a set of subdirs listed it recursively parses any Blueprints files found in those subdirectories.

If no errors are encountered while parsing the files, the list of paths on which the future output will depend is returned. This list will include both Blueprints file paths as well as directory paths for cases where wildcard subdirs are found.

func (*Context) PrepareBuildActions

func (c *Context) PrepareBuildActions(config interface{}) (deps []string, errs []error)

PrepareBuildActions generates an internal representation of all the build actions that need to be performed. This process involves invoking the GenerateBuildActions method on each of the Module objects created during the parse phase and then on each of the registered Singleton objects.

If the ResolveDependencies method has not already been called it is called automatically by this method.

The config argument is made available to all of the Module and Singleton objects via the Config method on the ModuleContext and SingletonContext objects passed to GenerateBuildActions. It is also passed to the functions specified via PoolFunc, RuleFunc, and VariableFunc so that they can compute config-specific values.

The returned deps is a list of the ninja files dependencies that were added by the modules and singletons via the ModuleContext.AddNinjaFileDeps() and SingletonContext.AddNinjaFileDeps() methods.

func (*Context) RegisterBottomUpMutator

func (c *Context) RegisterBottomUpMutator(name string, mutator BottomUpMutator)

RegisterBottomUpMutator registers a mutator that will be invoked to split Modules into variants. Each registered mutator is invoked in registration order (mixing TopDownMutators and BottomUpMutators) once per Module, and is invoked on dependencies before being invoked on dependers.

The mutator type names given here must be unique to all bottom up or early mutators in the Context.

func (*Context) RegisterEarlyMutator

func (c *Context) RegisterEarlyMutator(name string, mutator EarlyMutator)

RegisterEarlyMutator registers a mutator that will be invoked to split Modules into multiple variant Modules before any dependencies have been created. Each registered mutator is invoked in registration order once per Module (including each variant from previous early mutators). Module order is unpredictable.

In order for dependencies to be satisifed in a later pass, all dependencies of a module either must have an identical variant or must have no variations.

The mutator type names given here must be unique to all bottom up or early mutators in the Context.

func (*Context) RegisterModuleType

func (c *Context) RegisterModuleType(name string, factory ModuleFactory)

RegisterModuleType associates a module type name (which can appear in a Blueprints file) with a Module factory function. When the given module type name is encountered in a Blueprints file during parsing, the Module factory is invoked to instantiate a new Module object to handle the build action generation for the module. If a Mutator splits a module into multiple variants, the factory is invoked again to create a new Module for each variant.

The module type names given here must be unique for the context. The factory function should be a named function so that its package and name can be included in the generated Ninja file for debugging purposes.

The factory function returns two values. The first is the newly created Module object. The second is a slice of pointers to that Module object's properties structs. Each properties struct is examined when parsing a module definition of this type in a Blueprints file. Exported fields of the properties structs are automatically set to the property values specified in the Blueprints file. The properties struct field names determine the name of the Blueprints file properties that are used - the Blueprints property name matches that of the properties struct field name with the first letter converted to lower-case.

The fields of the properties struct must be either []string, a string, or bool. The Context will panic if a Module gets instantiated with a properties struct containing a field that is not one these supported types.

Any properties that appear in the Blueprints files that are not built-in module properties (such as "name" and "deps") and do not have a corresponding field in the returned module properties struct result in an error during the Context's parse phase.

As an example, the follow code:

type myModule struct {
    properties struct {
        Foo string
        Bar []string
    }
}

func NewMyModule() (blueprint.Module, []interface{}) {
    module := new(myModule)
    properties := &module.properties
    return module, []interface{}{properties}
}

func main() {
    ctx := blueprint.NewContext()
    ctx.RegisterModuleType("my_module", NewMyModule)
    // ...
}

would support parsing a module defined in a Blueprints file as follows:

my_module {
    name: "myName",
    foo:  "my foo string",
    bar:  ["my", "bar", "strings"],
}

The factory function may be called from multiple goroutines. Any accesses to global variables must be synchronized.

func (*Context) RegisterSingletonType

func (c *Context) RegisterSingletonType(name string, factory SingletonFactory)

RegisterSingletonType registers a singleton type that will be invoked to generate build actions. Each registered singleton type is instantiated and and invoked exactly once as part of the generate phase.

The singleton type names given here must be unique for the context. The factory function should be a named function so that its package and name can be included in the generated Ninja file for debugging purposes.

func (*Context) RegisterTopDownMutator

func (c *Context) RegisterTopDownMutator(name string, mutator TopDownMutator)

RegisterTopDownMutator registers a mutator that will be invoked to propagate dependency info top-down between Modules. Each registered mutator is invoked in registration order (mixing TopDownMutators and BottomUpMutators) once per Module, and is invoked on a module before being invoked on any of its dependencies.

The mutator type names given here must be unique to all top down mutators in the Context.

func (*Context) ResolveDependencies

func (c *Context) ResolveDependencies(config interface{}) []error

ResolveDependencies checks that the dependencies specified by all of the modules defined in the parsed Blueprints files are valid. This means that the modules depended upon are defined and that no circular dependencies exist.

The config argument is made available to all of the DynamicDependerModule objects via the Config method on the DynamicDependerModuleContext objects passed to their DynamicDependencies method.

func (*Context) SetIgnoreUnknownModuleTypes

func (c *Context) SetIgnoreUnknownModuleTypes(ignoreUnknownModuleTypes bool)

SetIgnoreUnknownModuleTypes sets the behavior of the context in the case where it encounters an unknown module type while parsing Blueprints files. By default, the context will report unknown module types as an error. If this method is called with ignoreUnknownModuleTypes set to true then the context will silently ignore unknown module types.

This method should generally not be used. It exists to facilitate the bootstrapping process.

func (*Context) WriteBuildFile

func (c *Context) WriteBuildFile(w io.Writer) error

WriteBuildFile writes the Ninja manifeset text for the generated build actions to w. If this is called before PrepareBuildActions successfully completes then ErrBuildActionsNotReady is returned.

type Deps

type Deps int

A Deps value indicates the dependency file format that Ninja should expect to be output by a compiler.

const (
	DepsNone Deps = iota
	DepsGCC
	DepsMSVC
)

func (Deps) String

func (d Deps) String() string

type DynamicDependerModule

type DynamicDependerModule interface {
	Module

	// DynamicDependencies is called by the Context that created the
	// DynamicDependerModule during its generate phase.  This call should return
	// the list of module names that the DynamicDependerModule depends on
	// dynamically.  Module names that already appear in the "deps" property may
	// but do not need to be included in the returned list.
	DynamicDependencies(DynamicDependerModuleContext) []string
}

A DynamicDependerModule is a Module that may add dependencies that do not appear in its "deps" property. Any Module that implements this interface will have its DynamicDependencies method called by the Context that created it during generate phase.

type DynamicDependerModuleContext

type DynamicDependerModuleContext interface {
	BaseModuleContext

	AddVariationDependencies([]Variation, ...string)
	AddFarVariationDependencies([]Variation, ...string)
}

type EarlyMutator

type EarlyMutator func(mctx EarlyMutatorContext)

type EarlyMutatorContext

type EarlyMutatorContext interface {
	CreateVariations(...string) []Module
	CreateLocalVariations(...string) []Module
	// contains filtered or unexported methods
}

type Error

type Error struct {
	Err error            // the error that occurred
	Pos scanner.Position // the relevant Blueprints file location
}

An Error describes a problem that was encountered that is related to a particular location in a Blueprints file.

func (*Error) Error

func (e *Error) Error() string

type Module

type Module interface {
	// GenerateBuildActions is called by the Context that created the Module
	// during its generate phase.  This call should generate all Ninja build
	// actions (rules, pools, and build statements) needed to build the module.
	GenerateBuildActions(ModuleContext)
}

A Module handles generating all of the Ninja build actions needed to build a single module based on properties defined in a Blueprints file. Module objects are initially created during the parse phase of a Context using one of the registered module types (and the associated ModuleFactory function). The Module's properties struct is automatically filled in with the property values specified in the Blueprints file (see Context.RegisterModuleType for more information on this).

A Module can be split into multiple Modules by a Mutator. All existing properties set on the module will be duplicated to the new Module, and then modified as necessary by the Mutator.

The Module implementation can access the build configuration as well as any modules on which on which it depends (as defined by the "deps" property specified in the Blueprints file or dynamically added by implementing the DynamicDependerModule interface) using the ModuleContext passed to GenerateBuildActions. This ModuleContext is also used to create Ninja build actions and to report errors to the user.

In addition to implementing the GenerateBuildActions method, a Module should implement methods that provide dependant modules and singletons information they need to generate their build actions. These methods will only be called after GenerateBuildActions is called because the Context calls GenerateBuildActions in dependency-order (and singletons are invoked after all the Modules). The set of methods a Module supports will determine how dependant Modules interact with it.

For example, consider a Module that is responsible for generating a library that other modules can link against. The library Module might implement the following interface:

type LibraryProducer interface {
    LibraryFileName() string
}

func IsLibraryProducer(module blueprint.Module) {
    _, ok := module.(LibraryProducer)
    return ok
}

A binary-producing Module that depends on the library Module could then do:

func (m *myBinaryModule) GenerateBuildActions(ctx blueprint.ModuleContext) {
    ...
    var libraryFiles []string
    ctx.VisitDepsDepthFirstIf(IsLibraryProducer,
        func(module blueprint.Module) {
            libProducer := module.(LibraryProducer)
            libraryFiles = append(libraryFiles, libProducer.LibraryFileName())
        })
    ...
}

to build the list of library file names that should be included in its link command.

GenerateBuildActions may be called from multiple threads. It is guaranteed to be called after it has finished being called on all dependencies and on all variants of that appear earlier in the ModuleContext.VisitAllModuleVariants list. Any accesses to global variables or to Module objects that are not dependencies or variants of the current Module must be synchronized by the implementation of GenerateBuildActions.

type ModuleContext

type ModuleContext interface {
	BaseModuleContext

	OtherModuleName(m Module) string
	OtherModuleErrorf(m Module, fmt string, args ...interface{})

	VisitDirectDeps(visit func(Module))
	VisitDirectDepsIf(pred func(Module) bool, visit func(Module))
	VisitDepsDepthFirst(visit func(Module))
	VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module))

	ModuleSubDir() string

	Variable(pctx *PackageContext, name, value string)
	Rule(pctx *PackageContext, name string, params RuleParams, argNames ...string) Rule
	Build(pctx *PackageContext, params BuildParams)

	AddNinjaFileDeps(deps ...string)

	PrimaryModule() Module
	FinalModule() Module
	VisitAllModuleVariants(visit func(Module))
}

type ModuleFactory

type ModuleFactory func() (m Module, propertyStructs []interface{})

A ModuleFactory function creates a new Module object. See the Context.RegisterModuleType method for details about how a registered ModuleFactory is used by a Context.

type PackageContext

type PackageContext struct {
	// contains filtered or unexported fields
}

A PackageContext provides a way to create package-scoped Ninja pools, rules, and variables. A Go package should create a single unexported package-scoped PackageContext variable that it uses to create all package- scoped Ninja object definitions. This PackageContext object should then be passed to all calls to define module- or singleton-specific Ninja definitions. For example:

package blah

import (
    "blueprint"
)

var (
    pctx = NewPackageContext("path/to/blah")

    myPrivateVar = pctx.StaticVariable("myPrivateVar", "abcdef")
    MyExportedVar = pctx.StaticVariable("MyExportedVar", "$myPrivateVar 123456!")

    SomeRule = pctx.StaticRule(...)
)

// ...

func (m *MyModule) GenerateBuildActions(ctx blueprint.Module) {
    ctx.Build(pctx, blueprint.BuildParams{
        Rule:    SomeRule,
        Outputs: []string{"$myPrivateVar"},
    })
}

func NewPackageContext

func NewPackageContext(pkgPath string) *PackageContext

NewPackageContext creates a PackageContext object for a given package. The pkgPath argument should always be set to the full path used to import the package. This function may only be called from a Go package's init() function or as part of a package-scoped variable initialization.

func (*PackageContext) Import

func (p *PackageContext) Import(pkgPath string)

Import enables access to the exported Ninja pools, rules, and variables that are defined at the package scope of another Go package. Go's visibility rules apply to these references - capitalized names indicate that something is exported. It may only be called from a Go package's init() function. The Go package path passed to Import must have already been imported into the Go package using a Go import statement. The imported variables may then be accessed from Ninja strings as "${pkg.Variable}", while the imported rules can simply be accessed as exported Go variables from the package. For example:

import (
    "blueprint"
    "foo/bar"
)

var pctx = NewPackagePath("blah")

func init() {
    pctx.Import("foo/bar")
}

...

func (m *MyModule) GenerateBuildActions(ctx blueprint.Module) {
    ctx.Build(pctx, blueprint.BuildParams{
        Rule:    bar.SomeRule,
        Outputs: []string{"${bar.SomeVariable}"},
    })
}

Note that the local name used to refer to the package in Ninja variable names is derived from pkgPath by extracting the last path component. This differs from Go's import declaration, which derives the local name from the package clause in the imported package. By convention these names are made to match, but this is not required.

func (*PackageContext) ImportAs

func (p *PackageContext) ImportAs(as, pkgPath string)

ImportAs provides the same functionality as Import, but it allows the local name that will be used to refer to the package to be specified explicitly. It may only be called from a Go package's init() function.

func (*PackageContext) PoolFunc

func (p *PackageContext) PoolFunc(name string, f func(interface{}) (PoolParams,
	error)) Pool

PoolFunc returns a Pool whose value is determined by a function that takes a config object as input and returns either the pool parameters or an error. It may only be called during a Go package's initialization - either from the init() function or as part of a package-scoped variable's initialization.

This function is usually used to initialize a package-scoped Go variable that represents a Ninja pool that will be output. The name argument should exactly match the Go variable name, and the string fields of the PoolParams returned by f may reference other Ninja variables that are visible within the calling Go package.

func (*PackageContext) RuleFunc

func (p *PackageContext) RuleFunc(name string, f func(interface{}) (RuleParams,
	error), argNames ...string) Rule

RuleFunc returns a Rule whose value is determined by a function that takes a config object as input and returns either the rule parameters or an error. It may only be called during a Go package's initialization - either from the init() function or as part of a package-scoped variable's initialization.

This function is usually used to initialize a package-scoped Go variable that represents a Ninja rule that will be output. The name argument should exactly match the Go variable name, and the string fields of the RuleParams returned by f may reference other Ninja variables that are visible within the calling Go package.

The argNames arguments list Ninja variables that may be overridden by Ninja build statements that invoke the rule. These arguments may be referenced in any of the string fields of the RuleParams returned by f. Arguments can shadow package-scoped variables defined within the caller's Go package, but they may not shadow those defined in another package. Shadowing a package- scoped variable results in the package-scoped variable's value being used for build statements that do not override the argument. For argument names that do not shadow package-scoped variables the default value is an empty string.

func (*PackageContext) StaticPool

func (p *PackageContext) StaticPool(name string, params PoolParams) Pool

StaticPool returns a Pool whose value does not depend on any configuration information. It may only be called during a Go package's initialization - either from the init() function or as part of a package-scoped Go variable's initialization.

This function is usually used to initialize a package-scoped Go variable that represents a Ninja pool that will be output. The name argument should exactly match the Go variable name, and the params fields may reference other Ninja variables that are visible within the calling Go package.

func (*PackageContext) StaticRule

func (p *PackageContext) StaticRule(name string, params RuleParams,
	argNames ...string) Rule

StaticRule returns a Rule whose value does not depend on any configuration information. It may only be called during a Go package's initialization - either from the init() function or as part of a package-scoped Go variable's initialization.

This function is usually used to initialize a package-scoped Go variable that represents a Ninja rule that will be output. The name argument should exactly match the Go variable name, and the params fields may reference other Ninja variables that are visible within the calling Go package.

The argNames arguments list Ninja variables that may be overridden by Ninja build statements that invoke the rule. These arguments may be referenced in any of the string fields of params. Arguments can shadow package-scoped variables defined within the caller's Go package, but they may not shadow those defined in another package. Shadowing a package-scoped variable results in the package-scoped variable's value being used for build statements that do not override the argument. For argument names that do not shadow package-scoped variables the default value is an empty string.

func (*PackageContext) StaticVariable

func (p *PackageContext) StaticVariable(name, value string) Variable

StaticVariable returns a Variable whose value does not depend on any configuration information. It may only be called during a Go package's initialization - either from the init() function or as part of a package- scoped variable's initialization.

This function is usually used to initialize a package-scoped Go variable that represents a Ninja variable that will be output. The name argument should exactly match the Go variable name, and the value string may reference other Ninja variables that are visible within the calling Go package.

func (*PackageContext) VariableConfigMethod

func (p *PackageContext) VariableConfigMethod(name string,
	method interface{}) Variable

VariableConfigMethod returns a Variable whose value is determined by calling a method on the config object. The method must take no arguments and return a single string that will be the variable's value. It may only be called during a Go package's initialization - either from the init() function or as part of a package-scoped variable's initialization.

This function is usually used to initialize a package-scoped Go variable that represents a Ninja variable that will be output. The name argument should exactly match the Go variable name, and the value string returned by method may reference other Ninja variables that are visible within the calling Go package.

func (*PackageContext) VariableFunc

func (p *PackageContext) VariableFunc(name string,
	f func(config interface{}) (string, error)) Variable

VariableFunc returns a Variable whose value is determined by a function that takes a config object as input and returns either the variable value or an error. It may only be called during a Go package's initialization - either from the init() function or as part of a package-scoped variable's initialization.

This function is usually used to initialize a package-scoped Go variable that represents a Ninja variable that will be output. The name argument should exactly match the Go variable name, and the value string returned by f may reference other Ninja variables that are visible within the calling Go package.

type Pool

type Pool interface {
	String() string
	// contains filtered or unexported methods
}

A Pool represents a Ninja pool that will be written to the output .ninja file.

var Console Pool = &builtinPool{
	name_: "console",
}

type PoolParams

type PoolParams struct {
	Comment string // The comment that will appear above the definition.
	Depth   int    // The Ninja pool depth.
}

A PoolParams object contains the set of parameters that make up a Ninja pool definition.

type Rule

type Rule interface {
	String() string
	// contains filtered or unexported methods
}

A Rule represents a Ninja build rule that will be written to the output .ninja file.

var Phony Rule = &builtinRule{
	name_: "phony",
}

type RuleParams

type RuleParams struct {
	Comment        string // The comment that will appear above the definition.
	Command        string // The command that Ninja will run for the rule.
	Depfile        string // The dependency file name.
	Deps           Deps   // The format of the dependency file.
	Description    string // The description that Ninja will print for the rule.
	Generator      bool   // Whether the rule generates the Ninja manifest file.
	Pool           Pool   // The Ninja pool to which the rule belongs.
	Restat         bool   // Whether Ninja should re-stat the rule's outputs.
	Rspfile        string // The response file.
	RspfileContent string // The response file content.
}

A RuleParams object contains the set of parameters that make up a Ninja rule definition. Each field except for Comment corresponds with a Ninja variable of the same name.

type Singleton

type Singleton interface {
	GenerateBuildActions(SingletonContext)
}

type SingletonContext

type SingletonContext interface {
	Config() interface{}

	ModuleName(module Module) string
	ModuleDir(module Module) string
	BlueprintFile(module Module) string

	ModuleErrorf(module Module, format string, args ...interface{})
	Errorf(format string, args ...interface{})

	Variable(pctx *PackageContext, name, value string)
	Rule(pctx *PackageContext, name string, params RuleParams, argNames ...string) Rule
	Build(pctx *PackageContext, params BuildParams)
	RequireNinjaVersion(major, minor, micro int)

	// SetBuildDir sets the value of the top-level "builddir" Ninja variable
	// that controls where Ninja stores its build log files.  This value can be
	// set at most one time for a single build.  Setting it multiple times (even
	// across different singletons) will result in a panic.
	SetBuildDir(pctx *PackageContext, value string)

	VisitAllModules(visit func(Module))
	VisitAllModulesIf(pred func(Module) bool, visit func(Module))
	VisitDepsDepthFirst(module Module, visit func(Module))
	VisitDepsDepthFirstIf(module Module, pred func(Module) bool,
		visit func(Module))

	AddNinjaFileDeps(deps ...string)
}

type SingletonFactory

type SingletonFactory func() Singleton

A SingletonFactory function creates a new Singleton object. See the Context.RegisterSingletonType method for details about how a registered SingletonFactory is used by a Context.

type TopDownMutator

type TopDownMutator func(mctx TopDownMutatorContext)

A Mutator function is called for each Module, and can use MutatorContext.CreateVariations to split a Module into multiple Modules, modifying properties on the new modules to differentiate them. It is called after parsing all Blueprint files, but before generating any build rules, and is always called on dependencies before being called on the depending module.

The Mutator function should only modify members of properties structs, and not members of the module struct itself, to ensure the modified values are copied if a second Mutator chooses to split the module a second time.

type TopDownMutatorContext

type TopDownMutatorContext interface {
	VisitDirectDeps(visit func(Module))
	VisitDirectDepsIf(pred func(Module) bool, visit func(Module))
	VisitDepsDepthFirst(visit func(Module))
	VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module))
	// contains filtered or unexported methods
}

type Variable

type Variable interface {
	String() string
	// contains filtered or unexported methods
}

A Variable represents a global Ninja variable definition that will be written to the output .ninja file. A variable may contain references to other global Ninja variables, but circular variable references are not allowed.

type Variation

type Variation struct {
	// Mutator is the axis on which this variation applies, i.e. "arch" or "link"
	Mutator string
	// Variation is the name of the variation on the axis, i.e. "arm" or "arm64" for arch, or
	// "shared" or "static" for link.
	Variation string
}

A Variation is a way that a variant of a module differs from other variants of the same module. For example, two variants of the same module might have Variation{"arch","arm"} and Variation{"arch","arm64"}

Directories

Path Synopsis
The Blueprint bootstrapping mechanism is intended to enable building a source tree using a Blueprint-based build system that is embedded (as source) in that source tree.
The Blueprint bootstrapping mechanism is intended to enable building a source tree using a Blueprint-based build system that is embedded (as source) in that source tree.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL