Pass classpath to d8
d8 requires the full classpath if --min-api requires default method or try-with-resources desugaring. Always pass the full classpath, since it will already have been built to generate the input jar. Bug: 116243313 Test: m checkbuild Change-Id: Ib0c18873880697b7cf942e0548dd2c53ee5ad23c
This commit is contained in:
27
java/dex.go
27
java/dex.go
@@ -25,7 +25,7 @@ import (
|
|||||||
var d8 = pctx.AndroidStaticRule("d8",
|
var d8 = pctx.AndroidStaticRule("d8",
|
||||||
blueprint.RuleParams{
|
blueprint.RuleParams{
|
||||||
Command: `rm -rf "$outDir" && mkdir -p "$outDir" && ` +
|
Command: `rm -rf "$outDir" && mkdir -p "$outDir" && ` +
|
||||||
`${config.D8Cmd} --output $outDir $dxFlags $in && ` +
|
`${config.D8Cmd} --output $outDir $d8Flags $in && ` +
|
||||||
`${config.SoongZipCmd} -o $outDir/classes.dex.jar -C $outDir -D $outDir && ` +
|
`${config.SoongZipCmd} -o $outDir/classes.dex.jar -C $outDir -D $outDir && ` +
|
||||||
`${config.MergeZipsCmd} -D -stripFile "**/*.class" $out $outDir/classes.dex.jar $in`,
|
`${config.MergeZipsCmd} -D -stripFile "**/*.class" $out $outDir/classes.dex.jar $in`,
|
||||||
CommandDeps: []string{
|
CommandDeps: []string{
|
||||||
@@ -34,7 +34,7 @@ var d8 = pctx.AndroidStaticRule("d8",
|
|||||||
"${config.MergeZipsCmd}",
|
"${config.MergeZipsCmd}",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
"outDir", "dxFlags")
|
"outDir", "d8Flags")
|
||||||
|
|
||||||
var r8 = pctx.AndroidStaticRule("r8",
|
var r8 = pctx.AndroidStaticRule("r8",
|
||||||
blueprint.RuleParams{
|
blueprint.RuleParams{
|
||||||
@@ -44,7 +44,7 @@ var r8 = pctx.AndroidStaticRule("r8",
|
|||||||
`--force-proguard-compatibility ` +
|
`--force-proguard-compatibility ` +
|
||||||
`--no-data-resources ` +
|
`--no-data-resources ` +
|
||||||
`-printmapping $outDict ` +
|
`-printmapping $outDict ` +
|
||||||
`$dxFlags $r8Flags && ` +
|
`$r8Flags && ` +
|
||||||
`touch "$outDict" && ` +
|
`touch "$outDict" && ` +
|
||||||
`${config.SoongZipCmd} -o $outDir/classes.dex.jar -C $outDir -D $outDir && ` +
|
`${config.SoongZipCmd} -o $outDir/classes.dex.jar -C $outDir -D $outDir && ` +
|
||||||
`${config.MergeZipsCmd} -D -stripFile "**/*.class" $out $outDir/classes.dex.jar $in`,
|
`${config.MergeZipsCmd} -D -stripFile "**/*.class" $out $outDir/classes.dex.jar $in`,
|
||||||
@@ -54,9 +54,9 @@ var r8 = pctx.AndroidStaticRule("r8",
|
|||||||
"${config.MergeZipsCmd}",
|
"${config.MergeZipsCmd}",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
"outDir", "outDict", "dxFlags", "r8Flags")
|
"outDir", "outDict", "r8Flags")
|
||||||
|
|
||||||
func (j *Module) dxFlags(ctx android.ModuleContext) []string {
|
func (j *Module) dexCommonFlags(ctx android.ModuleContext) []string {
|
||||||
flags := j.deviceProperties.Dxflags
|
flags := j.deviceProperties.Dxflags
|
||||||
// Translate all the DX flags to D8 ones until all the build files have been migrated
|
// Translate all the DX flags to D8 ones until all the build files have been migrated
|
||||||
// to D8 flags. See: b/69377755
|
// to D8 flags. See: b/69377755
|
||||||
@@ -82,6 +82,15 @@ func (j *Module) dxFlags(ctx android.ModuleContext) []string {
|
|||||||
return flags
|
return flags
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (j *Module) d8Flags(ctx android.ModuleContext, flags javaBuilderFlags) []string {
|
||||||
|
d8Flags := j.dexCommonFlags(ctx)
|
||||||
|
|
||||||
|
d8Flags = append(d8Flags, flags.bootClasspath.FormTurbineClasspath("--lib")...)
|
||||||
|
d8Flags = append(d8Flags, flags.classpath.FormTurbineClasspath("--lib")...)
|
||||||
|
|
||||||
|
return d8Flags
|
||||||
|
}
|
||||||
|
|
||||||
func (j *Module) r8Flags(ctx android.ModuleContext, flags javaBuilderFlags) (r8Flags []string, r8Deps android.Paths) {
|
func (j *Module) r8Flags(ctx android.ModuleContext, flags javaBuilderFlags) (r8Flags []string, r8Deps android.Paths) {
|
||||||
opt := j.deviceProperties.Optimize
|
opt := j.deviceProperties.Optimize
|
||||||
|
|
||||||
@@ -97,6 +106,8 @@ func (j *Module) r8Flags(ctx android.ModuleContext, flags javaBuilderFlags) (r8F
|
|||||||
proguardRaiseDeps = append(proguardRaiseDeps, dep.(Dependency).HeaderJars()...)
|
proguardRaiseDeps = append(proguardRaiseDeps, dep.(Dependency).HeaderJars()...)
|
||||||
})
|
})
|
||||||
|
|
||||||
|
r8Flags = append(r8Flags, j.dexCommonFlags(ctx)...)
|
||||||
|
|
||||||
r8Flags = append(r8Flags, proguardRaiseDeps.FormJavaClassPath("-libraryjars"))
|
r8Flags = append(r8Flags, proguardRaiseDeps.FormJavaClassPath("-libraryjars"))
|
||||||
r8Flags = append(r8Flags, flags.bootClasspath.FormJavaClassPath("-libraryjars"))
|
r8Flags = append(r8Flags, flags.bootClasspath.FormJavaClassPath("-libraryjars"))
|
||||||
r8Flags = append(r8Flags, flags.classpath.FormJavaClassPath("-libraryjars"))
|
r8Flags = append(r8Flags, flags.classpath.FormJavaClassPath("-libraryjars"))
|
||||||
@@ -147,8 +158,6 @@ func (j *Module) compileDex(ctx android.ModuleContext, flags javaBuilderFlags,
|
|||||||
|
|
||||||
useR8 := Bool(j.deviceProperties.Optimize.Enabled)
|
useR8 := Bool(j.deviceProperties.Optimize.Enabled)
|
||||||
|
|
||||||
dxFlags := j.dxFlags(ctx)
|
|
||||||
|
|
||||||
// Compile classes.jar into classes.dex and then javalib.jar
|
// Compile classes.jar into classes.dex and then javalib.jar
|
||||||
javalibJar := android.PathForModuleOut(ctx, "dex", jarName)
|
javalibJar := android.PathForModuleOut(ctx, "dex", jarName)
|
||||||
outDir := android.PathForModuleOut(ctx, "dex")
|
outDir := android.PathForModuleOut(ctx, "dex")
|
||||||
@@ -167,20 +176,20 @@ func (j *Module) compileDex(ctx android.ModuleContext, flags javaBuilderFlags,
|
|||||||
Input: classesJar,
|
Input: classesJar,
|
||||||
Implicits: r8Deps,
|
Implicits: r8Deps,
|
||||||
Args: map[string]string{
|
Args: map[string]string{
|
||||||
"dxFlags": strings.Join(dxFlags, " "),
|
|
||||||
"r8Flags": strings.Join(r8Flags, " "),
|
"r8Flags": strings.Join(r8Flags, " "),
|
||||||
"outDict": j.proguardDictionary.String(),
|
"outDict": j.proguardDictionary.String(),
|
||||||
"outDir": outDir.String(),
|
"outDir": outDir.String(),
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
} else {
|
} else {
|
||||||
|
d8Flags := j.d8Flags(ctx, flags)
|
||||||
ctx.Build(pctx, android.BuildParams{
|
ctx.Build(pctx, android.BuildParams{
|
||||||
Rule: d8,
|
Rule: d8,
|
||||||
Description: "d8",
|
Description: "d8",
|
||||||
Output: javalibJar,
|
Output: javalibJar,
|
||||||
Input: classesJar,
|
Input: classesJar,
|
||||||
Args: map[string]string{
|
Args: map[string]string{
|
||||||
"dxFlags": strings.Join(dxFlags, " "),
|
"d8Flags": strings.Join(d8Flags, " "),
|
||||||
"outDir": outDir.String(),
|
"outDir": outDir.String(),
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
|
Reference in New Issue
Block a user