diff options
author | 2021-05-07 18:34:52 +0000 | |
---|---|---|
committer | 2021-05-07 18:34:52 +0000 | |
commit | 3b755d4560d2d12b91d9648a0061e2467b120116 (patch) | |
tree | 010acd449a41368f1494755afb49fa270585aadf /java/classpath_fragment.go | |
parent | aa4c7129894f13841231b475cdd2bd5f24fa9d17 (diff) | |
parent | 95e9c5bbfa8a1a46433183830a2429ac83979d33 (diff) |
Merge "Split SYSTEMSERVERCLASSPATH entries from platform_bootclasspath."
Diffstat (limited to 'java/classpath_fragment.go')
-rw-r--r-- | java/classpath_fragment.go | 19 |
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) |