dart-sdk/pkg
Sam Rawlins 032738141e Fix constructor references in assignments
I maintain the choice to _not_ rewrite a PrefixedIdentifier to a
ConstructorReference in the case that it is the left side of an
AssignmentExpression, because doing so requires extra additional
checking during assignment verification, and probably a new error code
saying a constructor cannot be assigned to, similar to the error code
saying that a method cannot be assigned to. This is all feasible, but
I think it is very reasonable, in AstRewrite, to say, "This prefixed
identifier does seem to refer to a constructor, but it's the left
side of an assignment, so I'm not going to confidently do a rewrite;
instead I will leave this alone and let the assignment verification
code handle it."

Bug: b/200948019
Change-Id: I90c6a157c2992d4935acfb593f38518f0388bced
Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/214320
Reviewed-by: Konstantin Shcheglov <scheglov@google.com>
Reviewed-by: Brian Wilkerson <brianwilkerson@google.com>
Commit-Queue: Samuel Rawlins <srawlins@google.com>
2021-09-23 19:38:49 +00:00
..
_fe_analyzer_shared [cfe] Handle potentially constant types in instantiations 2021-09-23 09:04:12 +00:00
_js_interop_checks Add external extension methods. 2021-09-22 19:52:10 +00:00
analysis_server Revert "Stop using available suggestions for already imported libraries" 2021-09-23 18:39:07 +00:00
analysis_server_client analysis_server_client: remove unused JenkinsSmiHash class 2021-09-22 20:20:24 +00:00
analyzer Fix constructor references in assignments 2021-09-23 19:38:49 +00:00
analyzer_cli Issue 45267. Support for --packages in analysis server. 2021-09-02 17:33:15 +00:00
analyzer_plugin Deprecated TypeName, use NamedType instead. 2021-09-23 06:08:34 +00:00
analyzer_utilities Rename AnalysisSession.getXyz2() into getXyz(). 2021-07-12 22:42:58 +00:00
async_helper
build_integration Migrate pkg/build_integration to null safety 2021-07-17 15:45:04 +00:00
compiler [dart2js] dart format --fix on remaining lib/src/ files 2021-09-22 20:39:14 +00:00
dart2js_info dart2js_info: drop pre-migrate CI status in readme 2021-09-02 02:28:24 +00:00
dart2js_runtime_metrics [dart2js_runtime_metrics] Allow exporting internal library 2021-08-12 22:47:22 +00:00
dart2js_tools Revert "[dart2js] Migrate dart2js_tools to null safety" 2021-08-19 01:23:15 +00:00
dart2native Discontinue dart2native (use dart compile) 2021-08-23 20:53:09 +00:00
dart_internal Bump dart_internal to support Dart 2.15. 2021-08-12 21:21:01 +00:00
dartdev [dartdev] Add a "dart debug_adapter" command to run the DAP server from DDS 2021-09-17 16:09:49 +00:00
dds [dartdev] Add a "dart debug_adapter" command to run the DAP server from DDS 2021-09-17 16:09:49 +00:00
dev_compiler Reland "[ddc] Add web library environment variables" 2021-09-22 23:47:40 +00:00
diagnostic master branch to main 2021-09-15 06:22:23 +00:00
expect
front_end [CFE] Enable avoid_void_async lint 2021-09-23 11:58:18 +00:00
frontend_server Reland "[ddc] Add web library environment variables" 2021-09-22 23:47:40 +00:00
js
js_ast [js_ast] dart format --fix 2021-08-25 03:08:21 +00:00
js_runtime [dart2js] Add dart:_dart2js_runtime_metrics library and package 2021-08-03 18:25:00 +00:00
kernel [cfe] Don't serialize an empty show/hide clause 2021-09-23 14:01:54 +00:00
language_versioning_2.7_test
meta "master->main" migration 2021-09-09 18:14:36 +00:00
modular_test
native_stack_traces Discontinue dart2native (use dart compile) 2021-08-23 20:53:09 +00:00
nnbd_migration Deprecate getters that return TypeName, replace with returning NamedType. 2021-09-22 21:01:58 +00:00
scrape Add script to scrape metadata annotation arguments. 2021-07-12 23:41:32 +00:00
smith Migrate pkg/smith to null safety. 2021-08-12 22:50:50 +00:00
sourcemap_testing Updating pkg:sourcemap_testing function resolution for method definition syntax. 2021-07-08 22:59:17 +00:00
status_file Migrate pkg/status_file to null safety. 2021-08-12 20:33:30 +00:00
telemetry analyzer: use Object.hash functions, deprecate JenkinsSmiHash 2021-09-22 19:11:24 +00:00
test_runner [testing] Fix logic for detecting invalid named configurations 2021-09-22 09:34:46 +00:00
testing [testing] Migrate pkg/testing to null safety 2021-07-27 19:45:38 +00:00
vm [kernel] Rename isFieldFormal to isInitializingFormal 2021-09-22 15:56:07 +00:00
vm_service master branch to main 2021-09-15 06:22:23 +00:00
vm_snapshot_analysis Fix windows extension 2021-08-24 18:01:23 +00:00
.gitignore
BUILD.gn
pkg.status [dart2js_info] Fix tests after migration. 2021-08-13 18:47:41 +00:00
README.md

Package validation

The packages in pkg/ are automatically validated on the LUCI CI bots. The validation is largely done by the tools/package_deps package; it can be tested locally via:

dart tools/package_deps/bin/package_deps.dart

Packages which are published

There are several packages developed in pkg/ which are published to pub. Validation of these packages is particularly important because the pub tools are not used for these packages during development; we get our dependency versions from the DEPS file. Its very easy for the dependencies specified in a package's pubspec file to get out of date wrt the packages and versions actually used.

In order to better ensure we're publishing correct packages, we validate some properties of the pubspec files on our CI system. These validations include:

  • that the dependencies listed in the pubspec are used in the package
  • that all the packages used by the source are listed in the pubspec
  • that we don't use relative path deps to pkg/ or third_party/ packages

Packages which are not published

For packages in pkg/ which we do not intend to be published, we put the following comment in the pubspec.yaml file:

# This package is not intended for consumption on pub.dev. DO NOT publish.
publish_to: none

These pubspecs are still validated by the package validation tool. The contents are more informational as the pubspecs for these packages are not consumed by the pub tool or ecosystem.

We validate:

  • that the dependencies listed in the pubspec are used in the package
  • that all the packages used by the source are listed in the pubspec
  • that a reference to a pkg/ package is done via a relative path dependency