dart-sdk/pkg
Danny Tuppeny ec8918c20c [dds/dap] Handle errors parsing/casting launch/attach arguments and provide useful errors
Fixes https://github.com/dart-lang/sdk/issues/50709.

Change-Id: I35a7593ced462ab81d52069db831e5f95a9a4ba7
Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/275623
Commit-Queue: Ben Konyi <bkonyi@google.com>
Reviewed-by: Ben Konyi <bkonyi@google.com>
2022-12-14 17:19:05 +00:00
..
_fe_analyzer_shared [analyzer/cfe] Parse 'mixin class' behind sealed flag. 2022-12-14 15:41:58 +00:00
_js_interop_checks Add bindings emitter for web libraries 2022-12-09 19:23:31 +00:00
analysis_server Re-categorize all SDK_VERSION_* codes as StaticWarningCode 2022-12-14 16:14:38 +00:00
analysis_server_client Remove all support for super-mixins option 2022-12-13 18:13:37 +00:00
analyzer Re-categorize all SDK_VERSION_* codes as StaticWarningCode 2022-12-14 16:14:38 +00:00
analyzer_cli [3.0 alpha] Remove deprecated dart:core apis 2022-12-12 11:46:58 +00:00
analyzer_plugin Remove some unnecessary ignore comments in analyzer packages 2022-12-09 21:33:18 +00:00
analyzer_utilities Remove some unnecessary ignore comments in analyzer packages 2022-12-09 21:33:18 +00:00
async_helper
build_integration
compiler [kernel] Rename View* to Inline* 2022-12-14 08:36:57 +00:00
dart2js_info
dart2js_runtime_metrics Stop using strong-mode options in dart2js_runtime_metrics and scrape 2022-12-13 18:27:22 +00:00
dart2js_tools
dart2native Remove some unnecessary ignore comments in dart2native 2022-12-13 21:29:26 +00:00
dart2wasm [dart2wasm] Chunk copying large strings to JS. 2022-12-14 17:16:01 +00:00
dart_internal
dartdev Revert "[VM/CLI] Remove dartdev.dill" 2022-12-13 15:28:19 +00:00
dds [dds/dap] Handle errors parsing/casting launch/attach arguments and provide useful errors 2022-12-14 17:19:05 +00:00
dds_service_extensions
dev_compiler [kernel] Rename View* to Inline* 2022-12-14 08:36:57 +00:00
expect
front_end [analyzer/cfe] Parse 'mixin class' behind sealed flag. 2022-12-14 15:41:58 +00:00
frontend_server Remove some unnecessary ignore comments in frontend_server 2022-12-12 18:40:40 +00:00
js
js_ast
js_runtime
js_shared
kernel Only set isExplicitlyExhaustive on switch statements without default clauses. 2022-12-14 14:38:50 +00:00
language_versioning_2_7_test
meta
modular_test
native_stack_traces
nnbd_migration Shared patterns analysis API: remove matchedType from method calls. 2022-12-14 14:06:30 +00:00
scrape Stop using strong-mode options in dart2js_runtime_metrics and scrape 2022-12-13 18:27:22 +00:00
smith
sourcemap_testing
status_file
telemetry
test_runner Remove some unnecessary ignore comments in test_runner 2022-12-12 18:21:00 +00:00
testing
vm [cfe] Compute noSuchMethod forwarders in members builder 2022-12-14 09:25:57 +00:00
vm_service Remove some unnecessary ignore comments in vm_service 2022-12-12 20:03:59 +00:00
vm_snapshot_analysis
wasm_builder [dart2wasm] Put function types of imports in singleton rec groups 2022-12-13 20:43:22 +00:00
.gitignore
BUILD.gn
OWNERS
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. 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