Analysis is run as part of the Fuchsia build.
For each dart_library
target, an analysis script gets
also generated in the output directory under:
out/<build-type>/gen/path/to/package/package.analyzer.sh
Running this script will perform an analysis of the target's sources.
Note that other templates usually define a Dart library they build upon. For
example, a flutter_app
//foo/bar
will yield a //foo/bar:bar_dart_library
target which can also be analyzed.
As with standard Dart packages, analysis options are defined in an
analysis_options.yaml
file, which must be placed at the package root.
This file may refer to a common set of options by way of an include
directive:
include: relative/path/to/options.file
A canonical set is available at //topaz/tools/analysis_options.yaml
.
It is customary to merely include that set from a local options file:
include: path/to/topaz/tools/analysis_options.yaml
Analysis may be disabled altogether for a given target with:
dart_library("foo") {
disable_analysis = true
}
The //scripts/run-dart-action.py
script makes it easy to run the analysis over
multiple targets:
scripts/run-dart-action.py analyze --out out/<build-type> --tree //topaz/shell/*
Regular analyzer flags may also be passed:
scripts/run-dart-action.py analyze --out out/<build-type> --fatal-warnings --lints
This holds true for the individual analysis scripts.