summaryrefslogtreecommitdiff
path: root/java/classpath_fragment.go
diff options
context:
space:
mode:
author Treehugger Robot <treehugger-gerrit@google.com> 2021-05-07 18:34:52 +0000
committer Gerrit Code Review <noreply-gerritcodereview@google.com> 2021-05-07 18:34:52 +0000
commit3b755d4560d2d12b91d9648a0061e2467b120116 (patch)
tree010acd449a41368f1494755afb49fa270585aadf /java/classpath_fragment.go
parentaa4c7129894f13841231b475cdd2bd5f24fa9d17 (diff)
parent95e9c5bbfa8a1a46433183830a2429ac83979d33 (diff)
Merge "Split SYSTEMSERVERCLASSPATH entries from platform_bootclasspath."
Diffstat (limited to 'java/classpath_fragment.go')
-rw-r--r--java/classpath_fragment.go19
1 files changed, 15 insertions, 4 deletions
diff --git a/java/classpath_fragment.go b/java/classpath_fragment.go
index 460cc3ef4..00e95913b 100644
--- a/java/classpath_fragment.go
+++ b/java/classpath_fragment.go
@@ -58,6 +58,8 @@ type classpathFragment interface {
type ClasspathFragmentBase struct {
properties classpathFragmentProperties
+ classpathType classpathType
+
outputFilepath android.OutputPath
installDirPath android.InstallPath
}
@@ -67,8 +69,9 @@ func (c *ClasspathFragmentBase) classpathFragmentBase() *ClasspathFragmentBase {
}
// Initializes ClasspathFragmentBase struct. Must be called by all modules that include ClasspathFragmentBase.
-func initClasspathFragment(c classpathFragment) {
+func initClasspathFragment(c classpathFragment, classpathType classpathType) {
base := c.classpathFragmentBase()
+ base.classpathType = classpathType
c.AddProperties(&base.properties)
}
@@ -87,9 +90,17 @@ func (c *ClasspathFragmentBase) generateClasspathProtoBuildActions(ctx android.M
c.installDirPath = android.PathForModuleInstall(ctx, "etc", "classpaths")
var jars []classpathJar
- jars = appendClasspathJar(jars, BOOTCLASSPATH, defaultBootclasspath(ctx)...)
- jars = appendClasspathJar(jars, DEX2OATBOOTCLASSPATH, defaultBootImageConfig(ctx).getAnyAndroidVariant().dexLocationsDeps...)
- jars = appendClasspathJar(jars, SYSTEMSERVERCLASSPATH, systemServerClasspath(ctx)...)
+ switch c.classpathType {
+ case BOOTCLASSPATH:
+ jars = appendClasspathJar(jars, BOOTCLASSPATH, defaultBootclasspath(ctx)...)
+ jars = appendClasspathJar(jars, DEX2OATBOOTCLASSPATH, defaultBootImageConfig(ctx).getAnyAndroidVariant().dexLocationsDeps...)
+ case SYSTEMSERVERCLASSPATH:
+ jars = appendClasspathJar(jars, SYSTEMSERVERCLASSPATH, systemServerClasspath(ctx)...)
+ default:
+ // Only supported classpath fragments are BOOTCLASSPATH and SYSTEMSERVERCLASSPATH.
+ // DEX2OATBOOTCLASSPATH is a special case of BOOTCLASSPATH and is auto-generated.
+ panic(fmt.Errorf("found %v, expected either BOOTCLASSPATH or SYSTEMSERVERCLASSPATH", c.classpathType))
+ }
generatedJson := android.PathForModuleOut(ctx, outputFilename+".json")
writeClasspathsJson(ctx, generatedJson, jars)