dart-sdk/pkg
Konstantin Shcheglov d047d44bf0 Macro. Issue 55611. Support for type parameters as diagnostic targets.
Bug: https://github.com/dart-lang/sdk/issues/55611
Change-Id: I429de25be81f8d51bfe57131e19ffb4ad737f467
Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/368700
Commit-Queue: Konstantin Shcheglov <scheglov@google.com>
Reviewed-by: Brian Wilkerson <brianwilkerson@google.com>
2024-05-29 19:58:09 +00:00
..
_fe_analyzer_shared Prepare to publish analyzer 6.5.1 and _fe_analyzer_shared 69.0.0 2024-05-28 19:38:28 +00:00
_js_interop_checks
_macros update macros and _macros versions to reflect breaking change for implementations 2024-05-28 14:40:29 +00:00
analysis_server quick fix for ABSTRACT_STATIC_METHOD 2024-05-29 14:32:28 +00:00
analysis_server_client
analysis_server_plugin DAS: Move CorrectionProducer and Selection classes 2024-05-28 04:54:08 +00:00
analyzer Macro. Issue 55611. Support for type parameters as diagnostic targets. 2024-05-29 19:58:09 +00:00
analyzer_cli
analyzer_plugin
analyzer_utilities linter: Make some allowances in avoid_catches_without_on_clauses 2024-05-28 18:36:58 +00:00
async_helper
bisect_dart
build_integration
compiler replace logging.warn with logging.warning 2024-05-29 19:07:56 +00:00
dart2js_info
dart2js_runtime_metrics
dart2js_tools
dart2native [dartdev] Add --depfile option to dart compile 2024-05-23 12:58:29 +00:00
dart2wasm [dart2wasm] Remove unused diagnosticReporter argument 2024-05-29 08:21:05 +00:00
dart_internal
dart_service_protocol_shared
dartdev [dartdev]/[analysis_server] Report server errors to "dart analyze" to prevent misleading output for parse/analysis exceptions 2024-05-28 19:10:40 +00:00
dds [DDS] Start running tests that are currently getting skipped 2024-05-29 19:56:57 +00:00
dds_service_extensions
dev_compiler [ddc] Library level expression evaluation for the Dart SDK. 2024-05-24 20:08:37 +00:00
dtd
dtd_impl
expect
front_end Remove OperationsCfe.omittedNullabilityValue. 2024-05-29 16:56:09 +00:00
frontend_server
heap_snapshot
js
js_ast
js_runtime
js_shared
json package:json - drop vendored packages, prep to release 2024-05-24 15:41:05 +00:00
kernel [kernel] Fix uri on some constants 2024-05-29 14:01:32 +00:00
language_versioning_2_12_test
linter linter: Make some allowances in avoid_catches_without_on_clauses 2024-05-28 18:36:58 +00:00
macros update macros and _macros versions to reflect breaking change for implementations 2024-05-28 14:40:29 +00:00
meta meta: Add TargetKinds for @immutable; narrow error range for "invalid annotation" warnings. 2024-05-28 18:28:49 +00:00
mmap
modular_test
native_stack_traces
reload_test
scrape
server_plugin
smith
sourcemap_testing
status_file
telemetry
test_runner [infra] Add configurations for ARM64 sanitizer testing. 2024-05-17 16:57:13 +00:00
testing
vm [tools] Allow precompiling gen_kernel and compile_platform 2024-05-24 09:40:39 +00:00
vm_service [VM/Debugger] Prevent FindBestFit from considering closures that were 2024-05-16 21:57:18 +00:00
vm_service_interface
vm_service_protos
vm_snapshot_analysis
wasm_builder [wasm_builder] Update incorrect docs, some minor refactoring 2024-05-15 09:49:02 +00:00
.gitignore
analysis_options.yaml
BUILD.gn
OWNERS
pkg.dart
pkg.status
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. It's 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