diff options
author | dbabkin <dbabkin@google.com> | 2018-06-07 05:19:54 -0700 |
---|---|---|
committer | Copybara-Service <copybara-piper@google.com> | 2018-06-07 05:22:04 -0700 |
commit | 2df323407b1df9c50b12d9de9febf7a6f0cd19bd (patch) | |
tree | a5e726f8b0f35afbb04f4be5973e52bedac6a863 /src/main/java/com/google/devtools/build/lib/analysis/BaseRuleClasses.java | |
parent | f137cea0ac74334013e7b064e59d1624cf032ac4 (diff) |
Add LabelLateBoundDefault to :coverage_report_generator attribute
RELNOTES:none
PiperOrigin-RevId: 199619691
Diffstat (limited to 'src/main/java/com/google/devtools/build/lib/analysis/BaseRuleClasses.java')
-rw-r--r-- | src/main/java/com/google/devtools/build/lib/analysis/BaseRuleClasses.java | 19 |
1 files changed, 17 insertions, 2 deletions
diff --git a/src/main/java/com/google/devtools/build/lib/analysis/BaseRuleClasses.java b/src/main/java/com/google/devtools/build/lib/analysis/BaseRuleClasses.java index e38a5e41d6..86c5cd62d2 100644 --- a/src/main/java/com/google/devtools/build/lib/analysis/BaseRuleClasses.java +++ b/src/main/java/com/google/devtools/build/lib/analysis/BaseRuleClasses.java @@ -95,6 +95,19 @@ public class BaseRuleClasses { TestConfiguration.class, defaultValue, COVERAGE_SUPPORT_CONFIGURATION_RESOLVER); } + public static final String DEFAULT_COVERAGE_REPORT_GENERATOR_VALUE = + "//tools/test:coverage_report_generator"; + + @AutoCodec + static final Resolver<TestConfiguration, Label> COVERAGE_REPORT_GENERATOR_CONFIGURATION_RESOLVER = + (rule, attributes, configuration) -> configuration.getCoverageReportGenerator(); + + public static LabelLateBoundDefault<TestConfiguration> coverageReportGeneratorAttribute( + Label defaultValue) { + return LabelLateBoundDefault.fromTargetConfiguration( + TestConfiguration.class, defaultValue, COVERAGE_REPORT_GENERATOR_CONFIGURATION_RESOLVER); + } + // TODO(b/65746853): provide a way to do this without passing the entire configuration /** Implementation for the :run_under attribute. */ @AutoCodec @@ -170,9 +183,11 @@ public class BaseRuleClasses { coverageSupportAttribute(env.getToolsLabel(DEFAULT_COVERAGE_SUPPORT_VALUE)))) // Used in the one-per-build coverage report generation action. .add( - attr("$coverage_report_generator", LABEL) + attr(":coverage_report_generator", LABEL) .cfg(HostTransition.INSTANCE) - .value(env.getLabel("//tools/defaults:coverage_report_generator")) + .value( + coverageReportGeneratorAttribute( + env.getToolsLabel(DEFAULT_COVERAGE_REPORT_GENERATOR_VALUE))) .singleArtifact()) // The target itself and run_under both run on the same machine. We use the DATA config |