12598e6b0f
Noteworthy: * deprecates the `sdkVersionConstraint` getter and updates uses * migrates tests for sdk contstraints in the absence of a pubspec from context_builder_test to analysis_context_collection_test * makes `pubPackages` getter broadly visible Next step: remove the code that sets the `sdkVersionConstraint` in the analysis options object and remove the getter. Change-Id: I443cdd15ec8d28ac6fa6786e06c1e4b027eee747 Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/341084 Reviewed-by: Konstantin Shcheglov <scheglov@google.com> Reviewed-by: Keerti Parthasarathy <keertip@google.com> Commit-Queue: Phil Quitslund <pquitslund@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 language
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.