build_runner 2.6.1  build_runner: ^2.6.1 copied to clipboard
build_runner: ^2.6.1 copied to clipboard
A build system for Dart code generation and modular compilation.
2.6.1 #
- Use build3.0.1.
2.6.0 #
- Remove unused deps: analyzer,build_resolvers,collection,http,js,meta,package_config,pool,web,yaml.
- Remove unused dev_deps: http,package_config,web.
- Testing: read build configs using AssetReaderso they're easier to test.
- Use build3.0.0.
- Use build_resolvers3.0.0.
2.6.0-dev.2 #
- Remove unused deps: analyzer,build_resolvers,collection,http,js,meta,package_config,pool,web,yaml.
- Remove unused dev_deps: http,package_config,web.
- Testing: read build configs using AssetReaderso they're easier to test.
2.6.0-dev.1 #
- Use build3.0.0-dev.
- Use build_resolvers3.0.0-dev.
2.5.4 #
- Bug fix: fix incremental build when previous build had package:import of a missing dep or a missing file.
2.5.3 #
- Bug fix: fix corner case with checked in generated output that could cause a crash.
- Bug fix: during initial build cleanup, really delete files that correspond to hidden generated files.
2.5.2 #
- Simplify warnings for outdated analyzer.
2.5.1 #
- Don't log stack traces for subclasses of Exception.
- Bug fix: don't run builders with multiple outputs once per output.
2.5.0 #
User-visible changes:
- Improved performance for large builds. More performance improvements
will follow, if your workflow is affected by slow build_runnerperformance then please consider sharing details at https://github.com/dart-lang/build/discussions.
- Improved logging: show what builders are running and, for long-running builders, where the time is spent.
Versions:
- Bump the min SDK to 3.7.0.
- Use build_test3.0.0.
- Use build_runner_core9.0.0.
Internal changes:
- Start using `package:build/src/internal.dart'.
- Refactor MultiPackageAssetReaderto internalAssetFinder.
- FinalizedReaderno longer implements- AssetReader.
- Refactor CachingAssetReadertoFilesystemCache.
- Refactor FileBasedAssetReaderandFileBasedAssetWritertoReaderWriter.
- Remove OnDeleteWriter, add functionality toReaderWriter.
- Add NodeTypetoAssetNode, remove subtypes. Make mutations explicit.
- Use built_valueforAssetNodeand related types.
- Add details of what changed and what is built to --verboselogging.
- Compute outputs as needed instead of storing them in the asset graph.
- Refactor invalidation to track current build progress in Buildinstead of in the asset graph.
- Remove completeBuildfromRunnerAssetWriteras it's no longer needed.
2.4.15 #
- Update to package:web and dart:js_interop.
- Support the latest package:shelf_web_socket.
- Add hidden --use-experimental-resolverflag for issue #3811 performance work. This flag will be removed.
2.4.14 #
- Write generated assets at the end of a build to avoid invalidating other tools with a file watcher multiple times.
- Bump the min sdk to 3.6.0.
- Allow analyzer version 7.x.
- Hard code the generated build script to language version 3.6.
- Allow dart_style version 4.0.0, require at least 2.3.7.
2.4.13 #
- Bump the min sdk to 3.5.0.
- Bump the mimedependency to allow version 2.x.
2.4.12 #
- Bump the min sdk to 3.5.0-259.0.dev.
- Fix watch mode for workspace repos.
2.4.11 #
- Explicitly pass the current isolates package config instead of assuming the location, to support the upcoming pub workspaces feature.
2.4.10 #
- Support version 1.xand2.xofshelf_web_socketand2.xand3.x
- of web_socket_channel.
- Bump the min sdk to 3.4.0.
2.4.9 #
- Update the package:frontend_server_clientconstraint to>=3.0.0 <5.0.0.
2.4.8 #
- Update README.md to point to the FAQ and other docs.
- Print stack traces for Errorsubtype exceptions in non-verbose mode.
- Support latest version of package:js.
2.4.7 #
- Fix broken link in README.md.
- Bump the min sdk to 3.0.0.
- Add a warning to the doctorcommand if abuild.ymlfile is found (instead of abuild.yamlfile).
2.4.6 #
- Allow the latest analyzer (6.x.x).
2.4.5 #
- Fix a bug handling a builder which has a required_inputthat matches it's own output.
2.4.4 #
- Use a stable order for builders without an order defined by dependencies.
2.4.3 #
- Make the doctorcommand visible.
2.4.2 #
- Support package:build version 2.4.x.
2.4.1 #
- Mention --build-filter option in the README.
- Update to build_daemon 4.0.
- Support enabling experiments in build scripts.
2.4.0 #
- Warn if a package:builder import cannot be resolved and skip it, instead of creating an invalid build script or failing in other obscure ways.
- Require Dart 3.0, drop support for unsound build scripts.
2.3.3 #
- Remove references to NullThrownError.
2.3.2 #
- Add supported platforms to pubspec.
2.3.1 #
- Upgrade to frontend_service_clientversion 3.
2.3.0 #
- Add -das a shorthand for--delete-conflicting-outputs.
2.2.1 #
- Allow the latest package:analyzer.
- Stop ignoring the no_leading_underscores_for_library_prefixes lint in generated build scripts, code_builder now does this for you.
2.2.0 #
- Support global 'runs_before' configuration for builders. This allows users to influence the ordering of builders in their build.
2.1.11 #
- Stop reading or requiring .packagesfiles.
- Use an explicit dynamicgeneric type for collections in default builder options to reduce behavior differences between reading default options and user provided options.
2.1.10 #
- Allow build version 2.3.x.
2.1.9 #
- Fix up the formatting a bit for the error message that is logged when we get errors from the directory watcher.
- Ignore the no_leading_underscores_for_library_prefixes lint in the generated build script.
- Report changed assets when running as a deamon.
- Allow analyzer version 4.x.
2.1.8 #
- Support null stack traces coming from the build runner script isolate.
2.1.7 #
- Allow the latest pkg:build.
2.1.6 #
- Allow the latest analyzer.
2.1.5 #
- Use raw string literals for builder options when generating build scripts.
2.1.4 #
- Minor fixes to the log message when compiling the build script has some output.
- Drop package:pedantic dependency and replace it with package:lints.
2.1.3 #
- Use darttop level command instead ofpubwhen running pub executables.
2.1.2 #
- Support --enable-experimentoption in build daemon.
2.1.1 #
- Don't rethrow file watcher errors - instead log at severe level and continue
going. The file watcher implementation should restart automatically as of
package:watcher version 0.9.7+13.
2.1.0 #
- Add --log-requestsflag to build daemon.
- Log failed asset requests in build_runner server.
- Support the latest build (2.1.0).
2.0.6 #
- Allow analyzer version 2.x.x.
2.0.5 #
- Don't set the content length header or body when responding to HEAD requests.
2.0.4 #
- Allow builders defined as relative imports from the root of a package to run with sound null safety.
2.0.3 #
- Fix a serve mode bug which causes an unhandled exception if the build fails to initialize (usually because it is out of date).
2.0.2 #
- Use the frontend server to improve the performance of generating build script snapshots.
2.0.1 #
- Fix bad cast in build_runner while parsing options for daemon mode.
2.0.0 #
- 
Migrate to null safety. 
- 
Update to the latest build_runner_core.
1.12.2 #
- Allow the latest dart_style.
1.12.1 #
- Allow the latest http_multi_server.
1.12.0 #
- Remove support for hot-reloads. Use package:webdevinstead.
- Support version 2.0.x of the buildpackage
- Update to graphs 1.x
- Support version 1.xofshelf_web_socketand2.xofweb_socket_channel
1.11.5 #
- Fix arg parsing for the cleanandgenerate-build-scriptcommands.
1.11.4 #
- Fix snapshot generation hanging on windows if there is anything on stdout.
1.11.3 #
- Allow the latest build_config.
1.11.2 #
- Update to glob 2.x.
1.11.1+1 #
- Backport of 622c659.
- Don't rethrow file watcher errors - instead log at severe level and continue
going. The file watcher implementation should restart automatically as of
package:watcher version 0.9.7+13.
 
- Don't rethrow file watcher errors - instead log at severe level and continue
going. The file watcher implementation should restart automatically as of
package:watcher version 
1.11.1 #
- Allow the null safe pre-release version of shelf,package_config, andwatcher.
1.11.0 #
- Support generating custom build scripts through
package:build_runner/build_script_generate.dart:- Export generateAndRunto snapshot and run build scripts.
- Export findBuilderApplicationsto find builder applications from a package graph.
 
- Export 
1.10.13 #
- Allow the null safe pre-release version of stream_transform.
1.10.12 #
- Allow the null safe pre-releases of all migrated deps.
- Add a warning if a builderssection is found in when parsing an overridden build.yaml file via the--configflag.
1.10.11 #
- Fix handling of build.yamlgenerateFordefault config for values including a$such as$package$. Use raw strings in the generated build script.
1.10.10 #
- Allow build version 1.6.x.
1.10.9 #
- Allow build_config version '>=0.4.1 <0.4.6'.
- Allow yaml version '>=2.1.11 <4.0.0'.
1.10.7 #
- Allow build_config version 0.4.4.
- Fix a daemon mode issue where we might try to complete a completer twice during build script updates.
1.10.6 #
- Allow build_config version 0.4.3.
1.10.5 #
- Better handle the case where the package config file is deleted while the watcher is running, by waiting for up to 1 second for it to be written again before failing.
1.10.4 #
- Ensure that the generated build script is opted out of null safety, even if the current package supports it.
1.10.3 #
- Remove high sdk constraint, allow >=2.9.0.
- Require latest build_resolvers (which requires the latest analyzer).
- Require the latest build version (1.5.x).
1.10.2 #
Unpin analyzer and set the min sdk to 2.10 to resolve the subsequent issue https://github.com/dart-lang/sdk/issues/42887.
1.10.1 #
Pin analyzer to 0.39.14 to work around Issue #2763.
1.10.0 #
- Add an --enable-experimentflag which enables running builders on code that requires a language experiment to be enabled.
1.9.0 #
- Add a warning if a package is missing some required placeholder files,
including $package$andlib/$lib$.
- Reduce chances for changing apparent build phases across machines with a
different order of packages from package_config.json.
1.8.1 #
- Update to build_runner_coreversion^5.0.0.
- Remove dev dependency on package_resolver.
1.8.0 #
- Kill the watcher script when we see edits to the package_config.json file in the same way that we already do for the .packages file.
1.7.4 #
- Give a warning instead of a stack trace when using a build config override file for a package that does not exist.
- Allow the latest build_config version.
1.7.3 #
- Improve the error message when a --hostnameargument is invalid.
- Require SDK version 2.6.0to enable extension methods.
- Allow the latest stream_transform.
1.7.2 #
- Enable the native windows directory watcher by default.
- Added a --use-polling-watcher option which overrides this to use a polling watcher again.
- Increased the lower bound for the SDK to a version which contains various fixes for the native windows directory watcher.
 
- Give a more consistent ordering for Builders when their ordering is allowed to be arbitrary.
- Handle more --helpinvocations without generating the build script.
1.7.1 #
- Allow buildversion 1.2.x.
1.7.0 #
New Feature: Build Filters #
Build filters allow you to choose explicitly which files to build instead of building entire directories.
A build filter is a combination of a package and a path, with glob syntax supported for each.
Whenever a build filter is provided, only required outputs matching one of the build filters will be built, in addition to the inputs to those outputs.
Command Line Usage #
Build filters are supplied using the new --build-filter option, which accepts
relative paths under the package as well as package: uris.
Glob syntax is allowed in both package names and paths.
Example: The following would build and serve the JS output for an application, as well as copy over the required SDK resources for that app:
pub run build_runner serve \
  --build-filter="web/main.dart.js" \
  --build-filter="package:build_web_compilers/**/*.js"
Build Daemon Usage #
The build daemon now accepts build filters when registering a build target. If no filters are supplied these default filters are used, which is designed to match the previous behavior as closely as possible:
- <target-dir>/**
- package:*/**
Note: There is one small difference compared to the previous behavior, which is that build to source outputs from other top level directories in the root package will no longer be built when they would have before. This should have no meaningful impact other than being more efficient.
Common Use Cases #
Note: For all the listed use cases it is up to the user or tool the user is using to request all the required files for the desired task. This package only provides the core building blocks for these use cases.
Testing
If you have a large number of tests but only want to run a single one you can
now build just that test instead of all tests under the test directory.
This can greatly speed up iteration times in packages with lots of tests.
Example: This will build a single web test and run it:
pub run build_runner test \
  --build-filter="test/my_test.dart.browser_test.dart.js" \
  --build-filter="package:build_web_compilers/**/*.js" \
  -- -p chrome test/my_test.dart
Note: If your test requires any other generated files (css, etc) you will need to add additional filters.
Applications
This feature works as expected with the --output <dir> and the serve
command.  This means you can create an output directory for a single
application in your package instead of all applications under the same
directory.
The serve command also uses the build filters to restrict what files are available, which means it ensures if something works in serve mode it will also work when you create an output directory.
1.6.9 #
- Fix bugs in snapshot invalidation logic that prevented invalidation when core packages changed and always created a new snapshot on the second build.
1.6.8 #
- Improve the manual change detector to do a file system scan on demand instead of using a file watcher.
1.6.7 #
- Set the charsettoutf-8for Dart content returned by theAssetHandler.
1.6.6 #
- Added watch event debouncing to the daemoncommand to line up with thewatchcommand. This makes things work more nicely with swap files as well as "save all" type scenarios (you will only get a single build most times).
1.6.5 #
- Require package:build_config">=0.4.1 <0.4.2". Use new API that improves error information when a build configuration file is malformed.
1.6.4 #
- Fix an issue where warning logs on startup were accidentally upgraded to severe logs in the daemon mode.
1.6.3 #
- Preemptively re-snapshot when the build_runnerorbuild_daemonpackages are updated.
1.6.2 #
- Support the latest build_daemonversion.
- Expose assetServerPortas a top level helper method.
1.6.1 #
- Update the testcommand to wait to exit until the inner test process exits.
1.6.0 #
- Depend on the latest build_daemonand provide a shutdown notification on build script updates.
1.5.2 #
- Use a polling directory watcher by default on windows again.
1.5.1 #
- Fix an issue where exit codes were not set correctly when running the generated build script directly.
1.5.0 #
- Update to the latest build_daemon.
1.4.0 #
- Add a runcommand to execute VM entrypoints with generated sources.
1.3.5 #
- Use the latest build_daemon.
1.3.4 #
- Use the latest build_config.
1.3.3 #
- Use HttpMultiServer.loopbackfor the daemon asset server.
1.3.2 #
- Fix an error where daemon mode would claim support for prompts when it can't actually support them and would hang instead.
- Improve logging when the daemon fails to start up, previously no logs would be shown.
1.3.1 #
- Remove usage of set literals to fix errors on older sdks that don't support them.
1.3.0 #
- Fix an issue where we might re-use stale build snapshots, which could only be
resolved by deleting the .dart_tooldir (or doing aclean).
- Depend on the latest build_runner_coreandbuild_daemonreleases.
1.2.8 #
- Fix issue where daemon command wouldn't properly shutdown.
- Allow running when the root package, or a path dependency, is named test.
1.2.7 #
- Fix issue where daemon command would occasionally color a log.
1.2.6 #
- Prevent terminals being launched when running the daemon command on Windows.
- No longer assumeTty when logging through the daemon command.
- Update build_daemonto version0.4.0.
- Update build_runner_coreto version2.0.3.
- Ensure the daemon command always exits.
1.2.5 #
- Fix a bug with the build daemon where the output options were ignored.
1.2.4 #
- Update build_resolversto version1.0.0.
1.2.3 #
- Fix a bug where changing between --live-reloadand--hot-reloadmight not work due to the etags for the injected JS not changing when they should.
1.2.2 #
- Change the format of Build Daemon messages.
- Build Daemon asset server now properly waits for build results.
- Build Daemon now properly signals the start of a build.
- Fix path issues with Daemon command under Windows.
1.2.1 #
- Update package:build_runner_coreto version2.0.1.
1.2.0 #
- Support building through package:build_daemon.
- Update package:build_runner_coreto version2.0.0.
1.1.3 #
- Update to package:graphsversion0.2.0.
- Fix an issue where when running from source in watch mode the script would delete itself when it shouldn't.
- Add digest string to the asset graph visualization.
- Added a filter box to the asset graph visualization.
- Allow buildversion1.1.x.
1.1.2 #
- Improve error message when the generated build script cannot be parsed or
compiled and exit with code 78to indicate that there is a problem with configuration in the project or a dependency'sbuild.yaml.
1.1.1 #
Bug Fixes #
- Handle re-snapshotting the build script on SDK updates.
- Suppress header for the Bootstraplogger.
1.1.0 #
New Features #
- The build script will now be ran from snapshot, which improves startup times.
- The build script will automatically re-run itself when the build script is changed, instead of requiring the user to re-run it manually.
1.0.0 #
Breaking Changes #
- Massive cleanup of the public api. The only thing exported from this package
is now the runmethod. The goal is to reduce the surface area in order to stabilize this package, since it is directly depended on by all users.- Removed all exports from build_runner_core, if you are creating a custom build script you will need to import build_runner_core directly and add a dependency on it.
- Stopped exporting the buildandwatchfunctions directly, as well as theServeHandler.
- If this has broken your use case please file an issue on the package and request that we export the api you were using previously. These will be considered on an individual basis but the bar for additional exports will be high.
 
- Removed support for the --[no-]assume-tty command line argument as it is no longer needed.
0.10.3 #
- Improve performance tracking and visualization using the timingpackage.
- Handle bad asset graph in the cleancommand.
0.10.2 #
- Added --hot-reloadcli option and appropriate functionality.
- Removed dependency on cli_util.
0.10.1+1 #
- Added better error handling when a socket is already in use in servemode.
0.10.1 #
- Added --live-reloadcli option and appropriate functionality
- Migrated glob tracking to a specialized node type to fix dart-lang/build#1702.
0.10.0 #
Breaking Changes #
- Implementations of BuildEnvironmentmust now implement thefinalizeBuildmethod. There is a default implementation if you extendBuildEnvironmentthat is a no-op.- This method is invoked at the end of the build that allows you to do arbitrary additional work, such as creating merged output directories.
 
- The assumeTtyargument onIOEnvironmenthas moved to a named argument sincenullis an accepted value.
- The outputMapfield onBuildOptionshas moved to theIOEnvironmentclass.
New Features/Updates #
- Added a outputSymlinksOnlyoption toIOEnvironmentconstructor, that causes the merged output directories to contain only symlinks, which is much faster than copying files.
- Added the FinalizedAssetViewclass which provides a list of all available assets to theBuildEnvironmentduring the build finalization phase.- outputMaphas moved from- BuildOptionsto this constructor, as a named argument.
 
- The OverridableEnvironmentnow supports overriding the newfinalizeBuildapi.
- The number of concurrent actions per phase is now limited (currently to 16), which should help with memory and cpu usage for large builds.
0.9.2 #
- Changed the default file caching logic to use an LRU cache.
0.9.1+1 #
- Increased the upper bound for the sdk to <3.0.0.
0.9.1 #
- The hash dir for the asset graph under .dart_tool/buildis now based on a relative path to the build script instead of the absolute path.- This enables .dart_tool/builddirectories to be reused across different computers and directories for the same project.
 
- This enables 
0.9.0 #
New Features #
- Added the --log-performance <dir>option which will dump performance information to<dir>after each build.
- The BuildPerformanceclass is now serializable, it has afromJsonconstructor and atoJsoninstance method.
- Added support for global_optionsinbuild.yamlof the root package.
- Allow overriding the default Resolversimplementation.
- Allows building with symlinked files. Note that changes to the linked files will not trigger rebuilds in watch or serve mode.
Breaking changes #
- BuildPhasePerformance.actionhas been replaced with- BuildPhasePerformance.builderKeys.
- BuilderActionPerformance.builderhas been replaced with- BuilderActionPerformance.builderKey.
- BuildResultno longer has an- exceptionor- stackTracefield.
- The 'test' command through runwill no longer set an exit code. All manual build scripts which callrunshould use theFuture<int>return to set the exit code for the process.
- Dropped failOnSeverearguments and--fail-on-severeflag. Severe logs are always considered failing.
- Severe level logs now go to stdoutalong with other logs rather thanstderr. Uncaught exceptions from thebuild_runnersystem itself still go tostderr.
Other #
- Updated to the latest camel case constants from the sdk.
- Minimum sdk version is now >=2.0.0-dev.61.
0.8.10 #
- All builders with build_to: sourcewill now be ran regardless of which directory is currently being built, see https://github.com/dart-lang/build/issues/1454 for context.
- buildwill now throw instead of returning a failed build result if nothing was built.
- Improve error message when a dependency has a bad build.yamlwith a missing dependency.
- Sources that are not a part of a targetwill no longer appear in the asset graph, so they will not be readable or globbable.
- Updated the generated build script to not rely on json encode/decode for the builder options object. Instead it now directly inlines a map literal.
0.8.9 #
- Added support for building only specified top level directories.
- The build,watchcommands support positional arguments which are the directories to build. For example,pub run build_runner build webwill only build thewebdirectory.
- The servecommand treats positional args as it did before, except it will only build the directories you ask it to serve.
- The testcommand will automatically only build thetestdirectory.
- If using the -ooption, with the<dir-to-build>:<output-dir>syntax, then the<dir-to-build>will be added to the list of directories to build.- If additional directories are supplied with positional arguments, then those will also be built.
 
 
- The 
- Update to latest analyzer and build packages.
- Updated the servelogic to only serve files which were part of the actual build, and not stale assets. This brings the semantics exactly in line with what would be copied to the-ooutput directory.
0.8.8 #
- Improve search behavior on the /$graphpage. Users can now query for paths andAssetIDvalues –pkg_name|lib/pkg_name.dart.
- Commands that don't support trailing args will now appropriately fail with a usage exception.
- Fix a bug where some rebuilds would not happen after adding a new file that has outputs which were missing during the previous build.
- Fix a bug where failing actions which are no longer required can still cause the overall build to fail.
0.8.7 #
- Improve error handling on the /$graphpage.
- Support the latest package:build
0.8.6 #
- Forward default options for PostProcessBuilders in the generated build script.
- If a build appears to be not making progress (no actions completed for 15 seconds), then a warning will now be logged with the pending actions.
- Now fail when a build is requested which does not build anything.
- Clean up some error messages.
0.8.5 #
- Add log message for merged output errors.
0.8.4 #
- Log the number of completed actions on successful builds.
- Support the new isRootfield forBuilderOptionsso that builders can do different things for the root package.
- Deprecated PostProcessBuilderandPostProcessBuildStep. These should be imported frompackage:buildinstead.
0.8.3 #
- Clean and summarize stack traces printed with --verbose.
- Added a cleancommand which deletes generated to source files and the entire build cache directory.
- Bug Fix: Use the same order to compute the digest of input files to a build step when writing it as when comparing it. Previously builds would not be pruned as efficiently as they can be because the inputs erroneously looked different.
0.8.2+2 #
- The .packagesfile is now always created in the root of the output directory instead of under each top level directory.
0.8.2+1 #
- Bug Fix: Correctly parse Window's paths with new --outputsemantics.
0.8.2 #
- Allow passing multiple --outputoptions. Each option will be split on:. The first value will be the root input directory, the second value will be the output directory. If no delimiter is provided, all resources will be copied to the output directory.
- Allow deleting files in the post process build step.
- Bug Fix: Correctly include the default allow list when multiple targets without include are provided.
- Allow logging from within a build factory.
- Allow serving assets from successful build steps if the overall build fails.
- Add a --releaseflag to choose the options fromrelease_optionsinbuild.yaml. This should replace the need to use--configpointing to a release version ofbuild.yaml.
0.8.1 #
- Improved the layout of /$perf, especially after browser window resize.
- pub run build_runnerexits with a error when invoked with an unsupported command.
- Bug Fix: Update outputs in merged directory for sources which are not used
during the build. For example if web/index.htmlis not read to produce any generated outputs changes to this file will now get picked up duringpub run build_runner watch --output build.
- Don't allow a thrown exception from a Builder to take down the entire build process - instead record it as a failed action. The overall build will still be marked as a failure, but it won't crash the process.
0.8.0 #
New Features #
- Added the new PostProcessBuilderclass. These are not supported in bazel, and are different than a normalBuilderin some fundamental ways:- They don't have to declare output extensions, and can output any file as long as it doesn't conflict with an existing one. This is only checked at build time.
- They can only read their primary input.
- They will not cause optional actions to run - they will only run on assets that were built as a part of the normal build.
- They can not be optional themselves, and can only output to cache.
- Because they all run in a single phase, after other builders, none of their outputs can be used as inputs to any actions.
 
- Added applyPostProcessmethod which takesPostProcessBuilderFactorys instead ofBuilderFactorys.
Breaking Changes #
- BuilderApplicationnow has a- builderActionFactoriesgetter instead of a- builderFactoriesgetter.
- The default constructor for BuilderApplicationhas been replaced withBuilderApplication.forBuilderandBuilderApplication.forPostProcessBuilder.
0.7.14 #
- Warn when using --defineorbuild.yamlconfiguration for invalid builders.
0.7.13+1 #
- Fix a concurrent modification error when using listAssetswhen an asset could be written.
0.7.13 #
- Fix a bug where a chain of Builders would fail to run on some outputs from previous steps when the generated asset did not match the target'ssources.
- Added support for serving on IPv4 loopback when the server hostname is 'localhost' (the default).
- Added support for serving on any connection (both IPv4 and IPv6) when the hostname is 'any'.
- Improved stdout output.
0.7.12 #
- Added the --log-requestsflag to theservecommand, which will log all requests to the server.
- Build actions using findAssetswill be more smartly invalidated.
- Added a warning if using servemode but no directories were found to serve.
- The --outputoption now only outputs files that were required for the latest build. Previously when switching js compilers you could end up with ddc modules in your dart2js output, even though they weren't required. See https://github.com/dart-lang/build/issues/1033.
- The experimental create_merged_dirbinary is now removed, it can't be easily supported any more and has been replaced by the--outputoption.
- Builders which write to sourceare no longer guaranteed to run before builders which write tocache.
- Honors runs_beforeconfiguration from Builder definitions.
- Honors applies_buildersconfiguration from Builder definitions.
0.7.11+1 #
- Switch to use a PollingDirectoryWatcheron windows, which should fix file watching with the--outputoption. Follow along at https://github.com/dart-lang/tools/issues/1713 for more details.
0.7.11 #
- Performance tracking is now disabled by default, and you must pass the
--track-performanceflag to enable it.
- The heartbeat logger will now log the current number of completed versus scheduled actions, and it will log once a second instead of every 5 seconds.
- Builds will now be invalidated when the dart SDK is updated.
- Fixed the error message when missing a build_test dependency but trying to run
the testcommand.
- The build script will now exit on changes to build.yamlfiles.
0.7.10+1 #
- Fix bug where relative imports in a dependencies build.yaml would break all downstream users, https://github.com/dart-lang/build/issues/995.
0.7.10 #
New Features #
- Added a basic performance visualization. When running with serveyou can now navigate to/$perfand get a timeline of all actions. If you are experiencing slow builds (especially incremental ones), you can save the html of that page and attach it to bug reports!
Bug Fixes #
- When using --outputwe will only clean up files we know we previously output to the specified directory. This should allow running long lived processes such as servers in that directory (as long as they don't hold open file handles).
0.7.9+2 #
- Fixed a bug with build to source and watch mode that would result in an infinite build loop, #962.
0.7.9+1 #
- Support the latest analyzerpackage.
0.7.9 #
New Features #
- Added command line args to override config for builders globally. The format
is --define "<builder_key>=<option>=<value>". As an example, enabling the dart2js compiler for thebuild_web_compilers|entrypointbuilder would look like this:--define "build_web_compilers|entrypoint=compiler=dart2js".
Bug Fixes #
- Fixed an issue with mixed mode builds, see https://github.com/dart-lang/build/issues/924.
- Fixed some issues with exit codes and --fail-on-severe, although there are still some outstanding problems. See https://github.com/dart-lang/build/issues/910 for status updates.
- Fixed an issue where the process would hang on exceptions, see https://github.com/dart-lang/build/issues/883.
- Fixed an issue with etags not getting updated for source files that weren't inputs to any build actions, https://github.com/dart-lang/build/issues/894.
- Fixed an issue with hidden .DS_Store files on mac in the generated directory, https://github.com/dart-lang/build/issues/902.
- Fixed test output so it will use the compact reporter, https://github.com/dart-lang/build/issues/821.
0.7.8 #
- Add --configoption to use a differentbuild.yamlat build time.
0.7.7+1 #
- Avoid watching hosted dependencies for file changes.
0.7.7 #
- The top level runmethod now returns anintwhich represents anexitCodefor the command that was executed.- For now we still set the exitCode manually as well but this will likely
change in the next breaking release. In manual scripts you should awaitthe call torunand assign that toexitCodeto be future-proofed.
 
- For now we still set the exitCode manually as well but this will likely
change in the next breaking release. In manual scripts you should 
0.7.6 #
- Update to package:build version 0.12.0.
- Removed the DigestAssetReaderinterface, thedigestmethod has now moved to the coreAssetReaderinterface. We are treating this as a non-breaking change because there are no known users of this interface.
0.7.5+1 #
- Bug fix for using the --outputflag when you have notestdirectory.
0.7.5 #
- Add more human friendly duration printing.
- Added the --output <dir>(or-o) argument which will create a merged output directory after each build.
- Added the --verbose(or-v) flag which enables verbose logging.- Disables stack trace folding and terse stack traces.
- Disables the overwriting of previous info logs.
- Sets the default log level to Level.ALL.
 
- Added pubspec.yamlandpubspec.lockto the allow list for the root package sources.
0.7.4 #
- Allows using files in any build targets in the root package as sources if they fall outside the hardcoded allow list.
- Changes to the root .packagesfile during watch mode will now cause the build script to exit and prompt the user to restart the build.
0.7.3 #
- Added the flag --low-resources-mode, which defaults tofalse.
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 allow list 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 transitive 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.