diff --git a/go/tools/gopackagesdriver/bazel_json_builder.go b/go/tools/gopackagesdriver/bazel_json_builder.go index 55b235eeb1..ad6e6dedea 100644 --- a/go/tools/gopackagesdriver/bazel_json_builder.go +++ b/go/tools/gopackagesdriver/bazel_json_builder.go @@ -119,11 +119,13 @@ func (b *BazelJSONBuilder) Build(ctx context.Context, mode LoadMode) ([]string, return nil, fmt.Errorf("found no labels matching the requests") } + aspects := append(additionalAspects, goDefaultAspect) + buildArgs := concatStringsArrays([]string{ "--experimental_convenience_symlinks=ignore", "--ui_event_filters=-info,-stderr", "--noshow_progress", - "--aspects=" + customAspect, + "--aspects=" + strings.Join(aspects, ","), "--output_groups=" + b.outputGroupsForMode(mode), "--keep_going", // Build all possible packages }, bazelFlags, bazelBuildFlags, labels) diff --git a/go/tools/gopackagesdriver/main.go b/go/tools/gopackagesdriver/main.go index ff9f9621ad..9d36c8a85a 100644 --- a/go/tools/gopackagesdriver/main.go +++ b/go/tools/gopackagesdriver/main.go @@ -52,13 +52,14 @@ var ( // It seems https://github.com/bazelbuild/bazel/issues/3115 isn't fixed when specifying // the aspect from the command line. Use this trick in the mean time. rulesGoRepositoryName = getenvDefault("GOPACKAGESDRIVER_RULES_GO_REPOSITORY_NAME", "@io_bazel_rules_go") + goDefaultAspect = rulesGoRepositoryName + "//go/tools/gopackagesdriver:aspect.bzl%go_pkg_info_aspect" bazelBin = getenvDefault("GOPACKAGESDRIVER_BAZEL", "bazel") bazelFlags = strings.Fields(os.Getenv("GOPACKAGESDRIVER_BAZEL_FLAGS")) bazelQueryFlags = strings.Fields(os.Getenv("GOPACKAGESDRIVER_BAZEL_QUERY_FLAGS")) bazelQueryScope = getenvDefault("GOPACKAGESDRIVER_BAZEL_QUERY_SCOPE", "") bazelBuildFlags = strings.Fields(os.Getenv("GOPACKAGESDRIVER_BAZEL_BUILD_FLAGS")) workspaceRoot = os.Getenv("BUILD_WORKSPACE_DIRECTORY") - customAspect = getenvDefault("GOPACKAGESDRIVER_BAZEL_ASPECT", rulesGoRepositoryName+"//go/tools/gopackagesdriver:aspect.bzl%go_pkg_info_aspect") + additionalAspects = strings.Fields(os.Getenv("GOPACKAGESDRIVER_BAZEL_ADDTL_ASPECTS")) additionalKinds = strings.Fields(os.Getenv("GOPACKAGESDRIVER_BAZEL_KINDS")) emptyResponse = &driverResponse{ NotHandled: false,