From 8b82fe1a5529306096fd7522d75f50b2a3f02098 Mon Sep 17 00:00:00 2001 From: Dmitry Ivankov Date: Wed, 26 Jan 2022 11:53:52 +0100 Subject: [PATCH] Document artifact macro and dependencies list in README Also document strict_visibility_value from #649 --- README.md | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) diff --git a/README.md b/README.md index b276742b3..58dc9585b 100644 --- a/README.md +++ b/README.md @@ -452,6 +452,9 @@ To use it, add the load statement to the top of your BUILD file: load("@rules_jvm_external//:defs.bzl", "artifact") ``` +Full `group:artifact:[packaging:[classifier:]]version` maven coordinates are also +supported and translate to corresponding versionless target. + Note that usage of this macro makes BUILD file refactoring with tools like `buildozer` more difficult, because the macro hides the actual target label at the syntax level. @@ -855,6 +858,31 @@ maven_install( ) ``` +It is also possible to change strict visibility value from default `//visibility:private` +to a value specified by `strict_visibility_value` attribute. + +### Accessing transitive dependencies list + +It is possible to retrieve full list of dependencies in the dependency tree, including +transitive, source, javadoc and other artifacts. `maven_artifacts` list contains full +versioned maven coordinate strings of all dependencies. + +For example: +```python +load("@maven//:defs.bzl", "maven_artifacts") + +load("@rules_jvm_external//:defs.bzl", "artifact") +load("@rules_jvm_external//:specs.bzl", "parse") + +all_jar_coordinates = [c for c in maven_artifacts if parse.parse_maven_coordinate(c).get("packaging", "jar") == "jar"] +all_jar_targets = [artifact(c) for c in all_jar_coordinates] + +java_library( + name = "depends_on_everything", + runtime_deps = all_jar_targets, +) +``` + ### Fetch and resolve timeout The default timeout to fetch and resolve artifacts is 600 seconds. If you need