Clean up bootclasspath handling
PiperOrigin-RevId: 294769663
diff --git a/src/main/java/com/google/devtools/build/lib/rules/android/AndroidCommon.java b/src/main/java/com/google/devtools/build/lib/rules/android/AndroidCommon.java
index 3cd1ddb..21b1806 100644
--- a/src/main/java/com/google/devtools/build/lib/rules/android/AndroidCommon.java
+++ b/src/main/java/com/google/devtools/build/lib/rules/android/AndroidCommon.java
@@ -22,6 +22,7 @@
import com.google.devtools.build.lib.analysis.AnalysisUtils;
import com.google.devtools.build.lib.analysis.FileProvider;
import com.google.devtools.build.lib.analysis.OutputGroupInfo;
+import com.google.devtools.build.lib.analysis.PrerequisiteArtifacts;
import com.google.devtools.build.lib.analysis.RuleConfiguredTargetBuilder;
import com.google.devtools.build.lib.analysis.RuleContext;
import com.google.devtools.build.lib.analysis.Runfiles;
@@ -463,20 +464,13 @@
classJar = ruleContext.getImplicitOutputArtifact(AndroidRuleClasses.ANDROID_LIBRARY_CLASS_JAR);
idlHelper = new AndroidIdlHelper(ruleContext, classJar);
- ImmutableList<Artifact> bootclasspath;
+ NestedSetBuilder<Artifact> bootclasspath = NestedSetBuilder.<Artifact>stableOrder();
if (getAndroidConfig(ruleContext).desugarJava8()) {
- bootclasspath =
- ImmutableList.<Artifact>builder()
- .addAll(
- ruleContext
- .getPrerequisiteArtifacts("$desugar_java8_extra_bootclasspath", Mode.HOST)
- .list())
- .add(AndroidSdkProvider.fromRuleContext(ruleContext).getAndroidJar())
- .build();
- } else {
- bootclasspath =
- ImmutableList.of(AndroidSdkProvider.fromRuleContext(ruleContext).getAndroidJar());
+ bootclasspath.addTransitive(
+ PrerequisiteArtifacts.nestedSet(
+ ruleContext, "$desugar_java8_extra_bootclasspath", Mode.HOST));
}
+ bootclasspath.add(AndroidSdkProvider.fromRuleContext(ruleContext).getAndroidJar());
ImmutableList.Builder<String> javacopts = ImmutableList.builder();
javacopts.addAll(androidSemantics.getCompatibleJavacOptions(ruleContext));
@@ -486,8 +480,7 @@
JavaTargetAttributes.Builder attributesBuilder =
javaCommon
.initCommon(idlHelper.getIdlGeneratedJavaSources(), javacopts.build())
- .setBootClassPath(
- NestedSetBuilder.<Artifact>wrap(Order.NAIVE_LINK_ORDER, bootclasspath));
+ .setBootClassPath(bootclasspath.build());
resourceApk
.asDataBindingContext()