86ecb7185e
Contains quite a bit of refactoring. One big change is that `PubspecValidator.validate()` now also finds lints. Not sure we want this, but it seemed desirable to me. (Otherwise there was no central place to filter the lints through the ignores). Change-Id: Ic8a463a9718fb29bec0d4f7e849b6da7799aebc6 Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/311980 Reviewed-by: Brian Wilkerson <brianwilkerson@google.com> Commit-Queue: Sigurd Meldgaard <sigurdm@google.com> Reviewed-by: Samuel Rawlins <srawlins@google.com> |
||
---|---|---|
.. | ||
bin | ||
lib | ||
test | ||
tool | ||
.gitignore | ||
analysis_options.yaml | ||
LICENSE | ||
OWNERS | ||
pubspec.yaml | ||
README.md |
SDK development code analysis
dartanalyzer used to be the tool for statically analyzing dart code
at the command line. However, this tool has been replaced with
dart analyze
for this purpose in current SDKs and will no longer
be published on pub.
Do not depend on the command line interface or other semantics in
this directory as it is now an internal tool for SDK development, used
as the dart2analyzer
"compiler" for tools/test.py
in the SDK.
It is configured as part of the test runner,
here.
SDK development usage
For SDK development, run analysis from the test tool to validate analysis conclusions on language samples in the testing directory. From the root of the SDK:
tools/test.py --build --use-sdk -c dart2analyzer co19_2 language_2
This will build the Dart VM and compile dartanalyzer into a snapshot, then use
that snapshot while analyzing those directories under testing/
. Without
--use-sdk
, test.py will use the source code version of the analyzer
instead of the compiled one, which can be useful for debugging.