blob: 65ad2b14e67bb9dd8be227d082be66127c2b8d3d [file] [log] [blame] [view]
# Third-party Dart packages
There are two types of third-party dependencies in the Fuchsia tree:
- Extracted from [pub][pub].
- Synced from Git.
## Pub dependencies
Pub dependencies are hosted at [`//third-party/dart-pkg`][dart-3p]. That project
is regularly kept up-to-date with [a script][dart-3p-script] that relies on the
`pub` tool to resolve versions and fetch sources for the packages that are used
in the tree.
This script uses a set of canonical local packages which are assumed to be
providing the necessary package coverage for the entire tree.
Additionally, projects may request third-party dependencies to be imported
through the following procedure:
1. Create a `dart_dependencies.yaml` file in the project.
2. Add the desired dependencies in that file:
```
name: my_project
dependencies:
foo: ^4.0.0
bar: >=0.1.0
```
3. Add a reference to the file in `//scripts/dart/update_3p_packages.py`.
4. Run that script.
5. Merge your changes to `dart_dependencies.yaml` to master.
6. Merge the files, downloaded by running the `update_3p_packages.py` script, and the script itself to master.
7. In the `//topaz/manifest/dart` manifest, update the project node `third_part/dart-pkg` revision attribute with the SHA from your commit in Step 6.
8. Merge your change to the `//topaz/manifest/dart` manifest file to master.
[pub]: https://pub.dartlang.org/ "Pub"
[dart-3p]: https://fuchsia.googlesource.com/third_party/dart-pkg/+/master "Third-party dependencies"
[dart-3p-script]: /scripts/dart/update_3p_packages.py "Dependencies script"