diff --git a/site/en/external/extension.md b/site/en/external/extension.md index dfb5c8b52c0804..0d973ab830fcac 100644 --- a/site/en/external/extension.md +++ b/site/en/external/extension.md @@ -167,6 +167,14 @@ several repo visibility rules: the apparent name `foo`, and the extension generates a repo with the specified name `foo`, then for all repos generated by that extension `foo` refers to the former. +* Similarly, in a module extension's implementation function, repos created + by the extension can refer to each other by their apparent names in + attributes, regardless of the order in which they are created. + * In case of a conflict with a repository visible to the module, labels + passed to repository rule attributes can be wrapped in a call to + [`Label`](/rules/lib/toplevel/attr#label) to ensure that they refer to + the repo visible to the module instead of the extension-generated repo + of the same name. ## Best practices diff --git a/src/main/java/com/google/devtools/build/lib/bazel/bzlmod/AttributeValues.java b/src/main/java/com/google/devtools/build/lib/bazel/bzlmod/AttributeValues.java index 9fb17dd01891e2..c1cac5542f8233 100644 --- a/src/main/java/com/google/devtools/build/lib/bazel/bzlmod/AttributeValues.java +++ b/src/main/java/com/google/devtools/build/lib/bazel/bzlmod/AttributeValues.java @@ -45,14 +45,15 @@ public static AttributeValues create(Map attribs) { public abstract Dict attributes(); - public static void validateAttrs(AttributeValues attributes, String what) throws EvalException { + public static void validateAttrs(AttributeValues attributes, String where, String what) + throws EvalException { for (var entry : attributes.attributes().entrySet()) { - validateSingleAttr(entry.getKey(), entry.getValue(), what); + validateSingleAttr(entry.getKey(), entry.getValue(), where, what); } } - public static void validateSingleAttr(String attrName, Object attrValue, String what) - throws EvalException { + public static void validateSingleAttr( + String attrName, Object attrValue, String where, String what) throws EvalException { var maybeNonVisibleLabel = getFirstNonVisibleLabel(attrValue); if (maybeNonVisibleLabel.isEmpty()) { return; @@ -60,17 +61,9 @@ public static void validateSingleAttr(String attrName, Object attrValue, String Label label = maybeNonVisibleLabel.get(); String repoName = label.getRepository().getName(); throw Starlark.errorf( - "no repository visible as '@%s' to the %s, but referenced by label '@%s//%s:%s' in" - + " attribute '%s' of %s. Is the %s missing a bazel_dep or use_repo(..., \"%s\")?", - repoName, - label.getRepository().getOwnerRepoDisplayString(), - repoName, - label.getPackageName(), - label.getName(), - attrName, - what, - label.getRepository().getOwnerModuleDisplayString(), - repoName); + "no repository visible as '@%s' %s, but referenced by label '@%s//%s:%s' in" + + " attribute '%s' of %s.", + repoName, where, repoName, label.getPackageName(), label.getName(), attrName, what); } private static Optional