build_runner 0.7.2  build_runner: ^0.7.2 copied to clipboard
build_runner: ^0.7.2 copied to clipboard
Tools to write binaries that run builders.
0.7.2 #
- Added the flag --fail-on-severe, which defaults tofalse. In a future version this will default totrue, which means that logging a message vialog.severewill fail the build instead of just printing to the terminal. This would match the current behavior inbazel_codegen.
- Added the testcommand to thebuild_runnerbinary.
0.7.1+1 #
- BUG FIX: Running the build_runnerbinary without arguments no longer causes a crash sayingCould not find an option named "assume-tty"..
0.7.1 #
- Run Builders which write to the source tree before those which write to the build cache.
0.7.0 #
New Features #
- Added toRootPackage filter.
- Actions are now invalidated at a fine grained level when BuilderOptionschange.
- Added magic placeholder files in all packages, which can be used when your
builder doesn't have a clear primary input file.
- For non-root packages the placeholder exists at lib/$lib$, you should declare yourbuildExtensionslike this{r'$lib$': 'my_output_file.txt'}, which would result in an output file atlib/my_output_file.txtin the package.
- For the root package there are also placeholders at web/$web$andtest/$test$which should cover most use cases. Please file an issue if you need additional placeholders.
- Note that these placeholders are not real assets and attempting to read them
will result in an AssetNotFoundException.
 
- For non-root packages the placeholder exists at 
Breaking Changes #
- Removed BuildAction. Changedbuildandwatchto take aList<BuilderApplication>. SeeapplyandapplyToRootto set these up.
- Changed applyto take a single String argument - a Builder key frompackage:build_configrather than a separate package and builder name.
- Changed the default value of hideOutputfromfalsetotrueforapply. WithapplyToRootthe value remainsfalse.
- There is now a whitelist of top level directories that will be used as a part
of the build, and other files will be ignored. For now those directories
include 'benchmark', 'bin', 'example', 'lib', 'test', 'tool', and 'web'.
- If this breaks your workflow please file an issue and we can look at either adding additional directories or making the list configurable per project.
 
- Remove PackageGraph.orderedPackagesandPackageGraph.dependentsOf.
- Remove writeToCacheargument ofbuildandwatch. Eachapplycall should specifyhideOutputto keep this behavior.
- Removed PackageBuilderandPackageBuildActionsclasses. Use the new magic placeholder files instead (see new features section for this release).
The following changes are technically breaking but should not impact most clients:
- Upgrade to build_barbackv0.5.0 which uses strong mode analysis and no longer analyzes method bodies.
- Removed dependencyType,version,includes, andexcludesfromPackageNode.
- Removed PackageNode.noPubspecconstructor.
- Removed InputSet.
- PackageGraph instances enforce that the rootnode is the only node withisRoot == true.
0.6.1 #
New Features #
- Add an enableLowResourcesModeoption tobuildandwatch, which will consume less memory at the cost of slower builds. This is intended for use in resource constrained environments such as Travis.
- Add createBuildActions. After finding a list of Builders to run, and defining which packages need them applied, use this tool to apply them in the correct order across the package graph.
Deprecations #
- Deprecate PackageGraph.orderedPackagesandPackageGraph.dependentsOf.
Internal Improvements #
- Outputs will no longer be rebuilt unless their inputs actually changed, previously if any transtive dependency changed they would be invalidated.
- Switched to using semantic analyzer summaries, this combined with the better input validation means that, ddc/summary builds are much faster on non-api affecting edits (dependent modules will no longer be rebuilt).
- Build script invalidation is now much faster, which speeds up all builds.
Bug Fixes #
- The build actions are now checked against the previous builds actions, and if they do not match then a full build is performed. Previously the behavior in this case was undefined.
- Fixed an issue where once an edge between an output and an input was created it was never removed, causing extra builds to happen that weren't necessary.
- Build actions are now checked for overlapping outputs in non-checked mode, previously this was only an assert.
- Fixed an issue where nodes could get in an inconsistent state for short periods of time, leading to various errors.
- Fixed an issue on windows where incremental builds didn't work.
0.6.0+1 #
0.6.0 #
New features #
- Added orderedPackagesanddependentsOfutilities toPackageGraph.
- Added the noPubspecconstructor toPackageNode.
- Added the PackageBuilderandPackageBuildActionclasses. These builders only run once per package, and have no primary input. Outputs must be well known ahead of time and are declared with theIterable<String> get outputsfield, which returns relative paths under the current package.
- Added the isOptionalfield toBuildAction. Setting this totruemeans that the action will not run unless some other non-optional action tries to read one of the outputs of the action.
- Breaking: PackageNode.locationhas becomePackageNode.path, and is now aString(absolute path) instead of aUri; this prevents needing conversions to/fromUriacross the package.
- Breaking: RunnerAssetReaderinterface requires you to implementMultiPackageAssetReaderandDigestAssetReader. This means thepackageNamenamed argument has changed topackage, and you have to add theFuture<Digest> digest(AssetId id)method. While technically breaking most users do not rely on this interface explicitly.- You also no longer have to implement the
Future<DateTime> lastModified(AssetId id)method, as it has been replaced with theDigestAssetReaderinterface.
 
- You also no longer have to implement the
- Breaking: ServeHandler.handlehas been replaced withHandler ServeHandler.handleFor(String rootDir). This allows you to create separate handlers per directory you want to serve, which maintains pub serve conventions and allows interoperation withpub run test --pub-serve=$PORT.
Bug fixes #
- Breaking: All AssetReader#findAssetsimplementations now return aStream<AssetId>to match the latestbuildpackage. This should not affect most users unless you are extending the built inAssetReaders or using them in a custom way.
- Fixed an issue where findAssetscould return declared outputs from previous phases that did not actually output the asset.
- Fixed two issues with writeToCache:- Over-declared outputs will no longer attempt to build on each startup.
- Unrecognized files in the cache dir will no longer be treated as inputs.
 
- Asset invalidation has changed from using last modified timestamps to content hashes. This is generally much more reliable, and unblocks other desired features.
Internal changes #
- Added PackageGraphWatcherandPackageNodeWatcheras a wrapper API, including anAssetChangeclass that is now consistently used across the package.
0.5.0 #
- Breaking: Removed buildTypefield fromBuildResult.
- Breaking: watchnow returns aServeHandlerinstead of aStream<BuildResult>. UseServeHandler.buildResultsto get back to the original stream.
- Breaking: servehas been removed. Instead usewatchand use the resultingServeHandler.handlemethod along with a server created in the client script to start a server.
- Prevent reads into .dart_toolfor more hermetic builds.
- Bug Fix: Rebuild entire asset graph if the build script changes.
- Add writeToCacheargument tobuildandwatchwhich separates generated files from the source directory and allows running builders against other packages.
- Allow the latest version of package:shelf.
0.4.0+3 #
- Bug fix: Don't try to delete files generated for other packages.
0.4.0+2 #
- Bug fix: Don't crash after a Builder reads a file from another package.
0.4.0+1 #
- Depend on build0.10.x andbuild_barback0.4.x
0.4.0 #
- Breaking: The PhaseGroupclass has been replaced with aList<BuildAction>inbuild,watch, andserve. ThePhaseGroupandPhaseclasses are removed. If your current build has multiple actions in a single phase which are depending on not seeing the outputs from other actions in the phase you will need to instead set up theInputSets so that the outputs are filtered out.
- Breaking: The resolversargument has been removed frombuild,watch, andserve.
- Allow package:buildv0.10.x
0.3.4+1 #
- Support the latest release of build_barback.
0.3.4 #
- Support the latest release of analyzer.
0.3.2 #
- Support for build 0.9.0
0.3.1+1 #
- Bug Fix: Update AssetGraph version so builds can be run without manually deleting old build directory.
- Bug Fix: Check for unreadable assets in an async method rather than throw synchronously
0.3.1 #
- Internal refactoring of RunnerAssetReader.
- Support for build 0.8.0
- Add findAssets on AssetReader implementations
- Limit Asset reads to those which were available at the start of the phase. This might cause some reads which uses to succeed to fail.
0.3.0 #
0.2.0 #
Add support for the new bytes apis in build.
New Features #
- FileBasedAssetReaderand- FileBasedAssetWriternow support reading/writing as bytes.
Breaking Changes #
- Removed the AssetCache,CachedAssetReader, andCachedAssetWriter. These may come back at a later time if deemed necessary, but for now they just complicate things unnecessarily without proven benefits.
- BuildResult#outputsnow has a type of- List<AssetId>instead of- List<Asset>, since the- Assetclass no longer exists. Additionally this was wasting memory by keeping all output contents around when it's not generally a very useful thing outside of tests (which retain this information in other ways).
0.0.1 #
- Initial separate release - split off from buildpackage.