Refactor java compileDex
We want to support a compile_dex property for java_import. This splits dex-related properties into a dexer struct which can be embedded in relevant modules. Test: m Test: soong tests Bug: 160455085 Change-Id: If56a51dac43f630d49483a36db29cd50e9ccd529
This commit is contained in:
parent
bbec4c4325
commit
a7a64f3c5b
|
@ -127,8 +127,8 @@ func (library *Library) AndroidMkEntries() []android.AndroidMkEntries {
|
||||||
entries.AddStrings("LOCAL_ADDITIONAL_CHECKED_MODULE", library.additionalCheckedModules.Strings()...)
|
entries.AddStrings("LOCAL_ADDITIONAL_CHECKED_MODULE", library.additionalCheckedModules.Strings()...)
|
||||||
}
|
}
|
||||||
|
|
||||||
if library.proguardDictionary != nil {
|
if library.dexer.proguardDictionary.Valid() {
|
||||||
entries.SetPath("LOCAL_SOONG_PROGUARD_DICT", library.proguardDictionary)
|
entries.SetPath("LOCAL_SOONG_PROGUARD_DICT", library.dexer.proguardDictionary.Path())
|
||||||
}
|
}
|
||||||
entries.SetString("LOCAL_MODULE_STEM", library.Stem())
|
entries.SetString("LOCAL_MODULE_STEM", library.Stem())
|
||||||
|
|
||||||
|
@ -332,8 +332,8 @@ func (app *AndroidApp) AndroidMkEntries() []android.AndroidMkEntries {
|
||||||
if app.jacocoReportClassesFile != nil {
|
if app.jacocoReportClassesFile != nil {
|
||||||
entries.SetPath("LOCAL_SOONG_JACOCO_REPORT_CLASSES_JAR", app.jacocoReportClassesFile)
|
entries.SetPath("LOCAL_SOONG_JACOCO_REPORT_CLASSES_JAR", app.jacocoReportClassesFile)
|
||||||
}
|
}
|
||||||
if app.proguardDictionary != nil {
|
if app.dexer.proguardDictionary.Valid() {
|
||||||
entries.SetPath("LOCAL_SOONG_PROGUARD_DICT", app.proguardDictionary)
|
entries.SetPath("LOCAL_SOONG_PROGUARD_DICT", app.dexer.proguardDictionary.Path())
|
||||||
}
|
}
|
||||||
|
|
||||||
if app.Name() == "framework-res" {
|
if app.Name() == "framework-res" {
|
||||||
|
|
14
java/app.go
14
java/app.go
|
@ -588,11 +588,11 @@ func (a *AndroidApp) installPath(ctx android.ModuleContext) android.InstallPath
|
||||||
|
|
||||||
func (a *AndroidApp) dexBuildActions(ctx android.ModuleContext) android.Path {
|
func (a *AndroidApp) dexBuildActions(ctx android.ModuleContext) android.Path {
|
||||||
a.dexpreopter.installPath = a.installPath(ctx)
|
a.dexpreopter.installPath = a.installPath(ctx)
|
||||||
if a.deviceProperties.Uncompress_dex == nil {
|
if a.dexProperties.Uncompress_dex == nil {
|
||||||
// If the value was not force-set by the user, use reasonable default based on the module.
|
// If the value was not force-set by the user, use reasonable default based on the module.
|
||||||
a.deviceProperties.Uncompress_dex = proptools.BoolPtr(a.shouldUncompressDex(ctx))
|
a.dexProperties.Uncompress_dex = proptools.BoolPtr(a.shouldUncompressDex(ctx))
|
||||||
}
|
}
|
||||||
a.dexpreopter.uncompressedDex = *a.deviceProperties.Uncompress_dex
|
a.dexpreopter.uncompressedDex = *a.dexProperties.Uncompress_dex
|
||||||
a.dexpreopter.enforceUsesLibs = a.usesLibrary.enforceUsesLibraries()
|
a.dexpreopter.enforceUsesLibs = a.usesLibrary.enforceUsesLibraries()
|
||||||
a.dexpreopter.usesLibs = a.usesLibrary.usesLibraryProperties.Uses_libs
|
a.dexpreopter.usesLibs = a.usesLibrary.usesLibraryProperties.Uses_libs
|
||||||
a.dexpreopter.optionalUsesLibs = a.usesLibrary.presentOptionalUsesLibs(ctx)
|
a.dexpreopter.optionalUsesLibs = a.usesLibrary.presentOptionalUsesLibs(ctx)
|
||||||
|
@ -995,8 +995,8 @@ var _ cc.Coverage = (*AndroidApp)(nil)
|
||||||
func AndroidAppFactory() android.Module {
|
func AndroidAppFactory() android.Module {
|
||||||
module := &AndroidApp{}
|
module := &AndroidApp{}
|
||||||
|
|
||||||
module.Module.deviceProperties.Optimize.EnabledByDefault = true
|
module.Module.dexProperties.Optimize.EnabledByDefault = true
|
||||||
module.Module.deviceProperties.Optimize.Shrink = proptools.BoolPtr(true)
|
module.Module.dexProperties.Optimize.Shrink = proptools.BoolPtr(true)
|
||||||
|
|
||||||
module.Module.properties.Instrument = true
|
module.Module.properties.Instrument = true
|
||||||
module.Module.properties.Installable = proptools.BoolPtr(true)
|
module.Module.properties.Installable = proptools.BoolPtr(true)
|
||||||
|
@ -1110,7 +1110,7 @@ func (a *AndroidTest) OverridablePropertiesDepsMutator(ctx android.BottomUpMutat
|
||||||
func AndroidTestFactory() android.Module {
|
func AndroidTestFactory() android.Module {
|
||||||
module := &AndroidTest{}
|
module := &AndroidTest{}
|
||||||
|
|
||||||
module.Module.deviceProperties.Optimize.EnabledByDefault = true
|
module.Module.dexProperties.Optimize.EnabledByDefault = true
|
||||||
|
|
||||||
module.Module.properties.Instrument = true
|
module.Module.properties.Instrument = true
|
||||||
module.Module.properties.Installable = proptools.BoolPtr(true)
|
module.Module.properties.Installable = proptools.BoolPtr(true)
|
||||||
|
@ -1161,7 +1161,7 @@ func (a *AndroidTestHelperApp) InstallInTestcases() bool {
|
||||||
func AndroidTestHelperAppFactory() android.Module {
|
func AndroidTestHelperAppFactory() android.Module {
|
||||||
module := &AndroidTestHelperApp{}
|
module := &AndroidTestHelperApp{}
|
||||||
|
|
||||||
module.Module.deviceProperties.Optimize.EnabledByDefault = true
|
module.Module.dexProperties.Optimize.EnabledByDefault = true
|
||||||
|
|
||||||
module.Module.properties.Installable = proptools.BoolPtr(true)
|
module.Module.properties.Installable = proptools.BoolPtr(true)
|
||||||
module.appProperties.Use_embedded_native_libs = proptools.BoolPtr(true)
|
module.appProperties.Use_embedded_native_libs = proptools.BoolPtr(true)
|
||||||
|
|
107
java/dex.go
107
java/dex.go
|
@ -24,6 +24,60 @@ import (
|
||||||
"android/soong/remoteexec"
|
"android/soong/remoteexec"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
type DexProperties struct {
|
||||||
|
// If set to true, compile dex regardless of installable. Defaults to false.
|
||||||
|
Compile_dex *bool
|
||||||
|
|
||||||
|
// list of module-specific flags that will be used for dex compiles
|
||||||
|
Dxflags []string `android:"arch_variant"`
|
||||||
|
|
||||||
|
Optimize struct {
|
||||||
|
// If false, disable all optimization. Defaults to true for android_app and android_test
|
||||||
|
// modules, false for java_library and java_test modules.
|
||||||
|
Enabled *bool
|
||||||
|
// True if the module containing this has it set by default.
|
||||||
|
EnabledByDefault bool `blueprint:"mutated"`
|
||||||
|
|
||||||
|
// If true, optimize for size by removing unused code. Defaults to true for apps,
|
||||||
|
// false for libraries and tests.
|
||||||
|
Shrink *bool
|
||||||
|
|
||||||
|
// If true, optimize bytecode. Defaults to false.
|
||||||
|
Optimize *bool
|
||||||
|
|
||||||
|
// If true, obfuscate bytecode. Defaults to false.
|
||||||
|
Obfuscate *bool
|
||||||
|
|
||||||
|
// If true, do not use the flag files generated by aapt that automatically keep
|
||||||
|
// classes referenced by the app manifest. Defaults to false.
|
||||||
|
No_aapt_flags *bool
|
||||||
|
|
||||||
|
// Flags to pass to proguard.
|
||||||
|
Proguard_flags []string
|
||||||
|
|
||||||
|
// Specifies the locations of files containing proguard flags.
|
||||||
|
Proguard_flags_files []string `android:"path"`
|
||||||
|
}
|
||||||
|
|
||||||
|
// Keep the data uncompressed. We always need uncompressed dex for execution,
|
||||||
|
// so this might actually save space by avoiding storing the same data twice.
|
||||||
|
// This defaults to reasonable value based on module and should not be set.
|
||||||
|
// It exists only to support ART tests.
|
||||||
|
Uncompress_dex *bool
|
||||||
|
}
|
||||||
|
|
||||||
|
type dexer struct {
|
||||||
|
dexProperties DexProperties
|
||||||
|
|
||||||
|
// list of extra proguard flag files
|
||||||
|
extraProguardFlagFiles android.Paths
|
||||||
|
proguardDictionary android.OptionalPath
|
||||||
|
}
|
||||||
|
|
||||||
|
func (d *dexer) effectiveOptimizeEnabled() bool {
|
||||||
|
return BoolDefault(d.dexProperties.Optimize.Enabled, d.dexProperties.Optimize.EnabledByDefault)
|
||||||
|
}
|
||||||
|
|
||||||
var d8, d8RE = remoteexec.MultiCommandStaticRules(pctx, "d8",
|
var d8, d8RE = remoteexec.MultiCommandStaticRules(pctx, "d8",
|
||||||
blueprint.RuleParams{
|
blueprint.RuleParams{
|
||||||
Command: `rm -rf "$outDir" && mkdir -p "$outDir" && ` +
|
Command: `rm -rf "$outDir" && mkdir -p "$outDir" && ` +
|
||||||
|
@ -86,8 +140,8 @@ var r8, r8RE = remoteexec.MultiCommandStaticRules(pctx, "r8",
|
||||||
},
|
},
|
||||||
}, []string{"outDir", "outDict", "r8Flags", "zipFlags"}, []string{"implicits"})
|
}, []string{"outDir", "outDict", "r8Flags", "zipFlags"}, []string{"implicits"})
|
||||||
|
|
||||||
func (j *Module) dexCommonFlags(ctx android.ModuleContext) []string {
|
func (d *dexer) dexCommonFlags(ctx android.ModuleContext, minSdkVersion sdkSpec) []string {
|
||||||
flags := j.deviceProperties.Dxflags
|
flags := d.dexProperties.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
|
||||||
flags = android.RemoveListFromList(flags,
|
flags = android.RemoveListFromList(flags,
|
||||||
|
@ -103,30 +157,27 @@ func (j *Module) dexCommonFlags(ctx android.ModuleContext) []string {
|
||||||
"--verbose")
|
"--verbose")
|
||||||
}
|
}
|
||||||
|
|
||||||
minSdkVersion, err := j.minSdkVersion().effectiveVersion(ctx)
|
effectiveVersion, err := minSdkVersion.effectiveVersion(ctx)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
ctx.PropertyErrorf("min_sdk_version", "%s", err)
|
ctx.PropertyErrorf("min_sdk_version", "%s", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
flags = append(flags, "--min-api "+minSdkVersion.asNumberString())
|
flags = append(flags, "--min-api "+effectiveVersion.asNumberString())
|
||||||
return flags
|
return flags
|
||||||
}
|
}
|
||||||
|
|
||||||
func (j *Module) d8Flags(ctx android.ModuleContext, flags javaBuilderFlags) ([]string, android.Paths) {
|
func d8Flags(flags javaBuilderFlags) (d8Flags []string, d8Deps android.Paths) {
|
||||||
d8Flags := j.dexCommonFlags(ctx)
|
|
||||||
|
|
||||||
d8Flags = append(d8Flags, flags.bootClasspath.FormRepeatedClassPath("--lib ")...)
|
d8Flags = append(d8Flags, flags.bootClasspath.FormRepeatedClassPath("--lib ")...)
|
||||||
d8Flags = append(d8Flags, flags.classpath.FormRepeatedClassPath("--lib ")...)
|
d8Flags = append(d8Flags, flags.classpath.FormRepeatedClassPath("--lib ")...)
|
||||||
|
|
||||||
var d8Deps android.Paths
|
|
||||||
d8Deps = append(d8Deps, flags.bootClasspath...)
|
d8Deps = append(d8Deps, flags.bootClasspath...)
|
||||||
d8Deps = append(d8Deps, flags.classpath...)
|
d8Deps = append(d8Deps, flags.classpath...)
|
||||||
|
|
||||||
return d8Flags, d8Deps
|
return d8Flags, d8Deps
|
||||||
}
|
}
|
||||||
|
|
||||||
func (j *Module) r8Flags(ctx android.ModuleContext, flags javaBuilderFlags) (r8Flags []string, r8Deps android.Paths) {
|
func (d *dexer) r8Flags(ctx android.ModuleContext, flags javaBuilderFlags) (r8Flags []string, r8Deps android.Paths) {
|
||||||
opt := j.deviceProperties.Optimize
|
opt := d.dexProperties.Optimize
|
||||||
|
|
||||||
// When an app contains references to APIs that are not in the SDK specified by
|
// When an app contains references to APIs that are not in the SDK specified by
|
||||||
// its LOCAL_SDK_VERSION for example added by support library or by runtime
|
// its LOCAL_SDK_VERSION for example added by support library or by runtime
|
||||||
|
@ -140,8 +191,6 @@ 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"))
|
||||||
|
@ -154,15 +203,10 @@ func (j *Module) r8Flags(ctx android.ModuleContext, flags javaBuilderFlags) (r8F
|
||||||
android.PathForSource(ctx, "build/make/core/proguard.flags"),
|
android.PathForSource(ctx, "build/make/core/proguard.flags"),
|
||||||
}
|
}
|
||||||
|
|
||||||
if j.shouldInstrumentStatic(ctx) {
|
flagFiles = append(flagFiles, d.extraProguardFlagFiles...)
|
||||||
flagFiles = append(flagFiles,
|
|
||||||
android.PathForSource(ctx, "build/make/core/proguard.jacoco.flags"))
|
|
||||||
}
|
|
||||||
|
|
||||||
flagFiles = append(flagFiles, j.extraProguardFlagFiles...)
|
|
||||||
// TODO(ccross): static android library proguard files
|
// TODO(ccross): static android library proguard files
|
||||||
|
|
||||||
flagFiles = append(flagFiles, android.PathsForModuleSrc(ctx, j.deviceProperties.Optimize.Proguard_flags_files)...)
|
flagFiles = append(flagFiles, android.PathsForModuleSrc(ctx, opt.Proguard_flags_files)...)
|
||||||
|
|
||||||
r8Flags = append(r8Flags, android.JoinWithPrefix(flagFiles.Strings(), "-include "))
|
r8Flags = append(r8Flags, android.JoinWithPrefix(flagFiles.Strings(), "-include "))
|
||||||
r8Deps = append(r8Deps, flagFiles...)
|
r8Deps = append(r8Deps, flagFiles...)
|
||||||
|
@ -171,7 +215,7 @@ func (j *Module) r8Flags(ctx android.ModuleContext, flags javaBuilderFlags) (r8F
|
||||||
r8Deps = append(r8Deps, android.PathForSource(ctx,
|
r8Deps = append(r8Deps, android.PathForSource(ctx,
|
||||||
"build/make/core/proguard_basic_keeps.flags"))
|
"build/make/core/proguard_basic_keeps.flags"))
|
||||||
|
|
||||||
r8Flags = append(r8Flags, j.deviceProperties.Optimize.Proguard_flags...)
|
r8Flags = append(r8Flags, opt.Proguard_flags...)
|
||||||
|
|
||||||
// TODO(ccross): Don't shrink app instrumentation tests by default.
|
// TODO(ccross): Don't shrink app instrumentation tests by default.
|
||||||
if !Bool(opt.Shrink) {
|
if !Bool(opt.Shrink) {
|
||||||
|
@ -197,29 +241,30 @@ func (j *Module) r8Flags(ctx android.ModuleContext, flags javaBuilderFlags) (r8F
|
||||||
return r8Flags, r8Deps
|
return r8Flags, r8Deps
|
||||||
}
|
}
|
||||||
|
|
||||||
func (j *Module) compileDex(ctx android.ModuleContext, flags javaBuilderFlags,
|
func (d *dexer) compileDex(ctx android.ModuleContext, flags javaBuilderFlags, minSdkVersion sdkSpec,
|
||||||
classesJar android.Path, jarName string) android.ModuleOutPath {
|
classesJar android.Path, jarName string) android.ModuleOutPath {
|
||||||
|
|
||||||
useR8 := j.deviceProperties.EffectiveOptimizeEnabled()
|
|
||||||
|
|
||||||
// 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")
|
||||||
|
|
||||||
zipFlags := "--ignore_missing_files"
|
zipFlags := "--ignore_missing_files"
|
||||||
if proptools.Bool(j.deviceProperties.Uncompress_dex) {
|
if proptools.Bool(d.dexProperties.Uncompress_dex) {
|
||||||
zipFlags += " -L 0"
|
zipFlags += " -L 0"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
commonFlags := d.dexCommonFlags(ctx, minSdkVersion)
|
||||||
|
|
||||||
|
useR8 := d.effectiveOptimizeEnabled()
|
||||||
if useR8 {
|
if useR8 {
|
||||||
proguardDictionary := android.PathForModuleOut(ctx, "proguard_dictionary")
|
proguardDictionary := android.PathForModuleOut(ctx, "proguard_dictionary")
|
||||||
j.proguardDictionary = proguardDictionary
|
d.proguardDictionary = android.OptionalPathForPath(proguardDictionary)
|
||||||
r8Flags, r8Deps := j.r8Flags(ctx, flags)
|
r8Flags, r8Deps := d.r8Flags(ctx, flags)
|
||||||
rule := r8
|
rule := r8
|
||||||
args := map[string]string{
|
args := map[string]string{
|
||||||
"r8Flags": strings.Join(r8Flags, " "),
|
"r8Flags": strings.Join(append(commonFlags, r8Flags...), " "),
|
||||||
"zipFlags": zipFlags,
|
"zipFlags": zipFlags,
|
||||||
"outDict": j.proguardDictionary.String(),
|
"outDict": proguardDictionary.String(),
|
||||||
"outDir": outDir.String(),
|
"outDir": outDir.String(),
|
||||||
}
|
}
|
||||||
if ctx.Config().IsEnvTrue("RBE_R8") {
|
if ctx.Config().IsEnvTrue("RBE_R8") {
|
||||||
|
@ -236,7 +281,7 @@ func (j *Module) compileDex(ctx android.ModuleContext, flags javaBuilderFlags,
|
||||||
Args: args,
|
Args: args,
|
||||||
})
|
})
|
||||||
} else {
|
} else {
|
||||||
d8Flags, d8Deps := j.d8Flags(ctx, flags)
|
d8Flags, d8Deps := d8Flags(flags)
|
||||||
rule := d8
|
rule := d8
|
||||||
if ctx.Config().IsEnvTrue("RBE_D8") {
|
if ctx.Config().IsEnvTrue("RBE_D8") {
|
||||||
rule = d8RE
|
rule = d8RE
|
||||||
|
@ -248,13 +293,13 @@ func (j *Module) compileDex(ctx android.ModuleContext, flags javaBuilderFlags,
|
||||||
Input: classesJar,
|
Input: classesJar,
|
||||||
Implicits: d8Deps,
|
Implicits: d8Deps,
|
||||||
Args: map[string]string{
|
Args: map[string]string{
|
||||||
"d8Flags": strings.Join(d8Flags, " "),
|
"d8Flags": strings.Join(append(commonFlags, d8Flags...), " "),
|
||||||
"zipFlags": zipFlags,
|
"zipFlags": zipFlags,
|
||||||
"outDir": outDir.String(),
|
"outDir": outDir.String(),
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
if proptools.Bool(j.deviceProperties.Uncompress_dex) {
|
if proptools.Bool(d.dexProperties.Uncompress_dex) {
|
||||||
alignedJavalibJar := android.PathForModuleOut(ctx, "aligned", jarName)
|
alignedJavalibJar := android.PathForModuleOut(ctx, "aligned", jarName)
|
||||||
TransformZipAlign(ctx, alignedJavalibJar, javalibJar)
|
TransformZipAlign(ctx, alignedJavalibJar, javalibJar)
|
||||||
javalibJar = alignedJavalibJar
|
javalibJar = alignedJavalibJar
|
||||||
|
|
84
java/java.go
84
java/java.go
|
@ -264,9 +264,6 @@ type CompilerProperties struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
type CompilerDeviceProperties struct {
|
type CompilerDeviceProperties struct {
|
||||||
// list of module-specific flags that will be used for dex compiles
|
|
||||||
Dxflags []string `android:"arch_variant"`
|
|
||||||
|
|
||||||
// if not blank, set to the version of the sdk to compile against.
|
// if not blank, set to the version of the sdk to compile against.
|
||||||
// Defaults to compiling against the current platform.
|
// Defaults to compiling against the current platform.
|
||||||
Sdk_version *string
|
Sdk_version *string
|
||||||
|
@ -312,37 +309,6 @@ type CompilerDeviceProperties struct {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// If set to true, compile dex regardless of installable. Defaults to false.
|
|
||||||
Compile_dex *bool
|
|
||||||
|
|
||||||
Optimize struct {
|
|
||||||
// If false, disable all optimization. Defaults to true for android_app and android_test
|
|
||||||
// modules, false for java_library and java_test modules.
|
|
||||||
Enabled *bool
|
|
||||||
// True if the module containing this has it set by default.
|
|
||||||
EnabledByDefault bool `blueprint:"mutated"`
|
|
||||||
|
|
||||||
// If true, optimize for size by removing unused code. Defaults to true for apps,
|
|
||||||
// false for libraries and tests.
|
|
||||||
Shrink *bool
|
|
||||||
|
|
||||||
// If true, optimize bytecode. Defaults to false.
|
|
||||||
Optimize *bool
|
|
||||||
|
|
||||||
// If true, obfuscate bytecode. Defaults to false.
|
|
||||||
Obfuscate *bool
|
|
||||||
|
|
||||||
// If true, do not use the flag files generated by aapt that automatically keep
|
|
||||||
// classes referenced by the app manifest. Defaults to false.
|
|
||||||
No_aapt_flags *bool
|
|
||||||
|
|
||||||
// Flags to pass to proguard.
|
|
||||||
Proguard_flags []string
|
|
||||||
|
|
||||||
// Specifies the locations of files containing proguard flags.
|
|
||||||
Proguard_flags_files []string `android:"path"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// When targeting 1.9 and above, override the modules to use with --system,
|
// When targeting 1.9 and above, override the modules to use with --system,
|
||||||
// otherwise provides defaults libraries to add to the bootclasspath.
|
// otherwise provides defaults libraries to add to the bootclasspath.
|
||||||
System_modules *string
|
System_modules *string
|
||||||
|
@ -356,19 +322,9 @@ type CompilerDeviceProperties struct {
|
||||||
// set the name of the output
|
// set the name of the output
|
||||||
Stem *string
|
Stem *string
|
||||||
|
|
||||||
// Keep the data uncompressed. We always need uncompressed dex for execution,
|
|
||||||
// so this might actually save space by avoiding storing the same data twice.
|
|
||||||
// This defaults to reasonable value based on module and should not be set.
|
|
||||||
// It exists only to support ART tests.
|
|
||||||
Uncompress_dex *bool
|
|
||||||
|
|
||||||
IsSDKLibrary bool `blueprint:"mutated"`
|
IsSDKLibrary bool `blueprint:"mutated"`
|
||||||
}
|
}
|
||||||
|
|
||||||
func (me *CompilerDeviceProperties) EffectiveOptimizeEnabled() bool {
|
|
||||||
return BoolDefault(me.Optimize.Enabled, me.Optimize.EnabledByDefault)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Functionality common to Module and Import
|
// Functionality common to Module and Import
|
||||||
//
|
//
|
||||||
// It is embedded in Module so its functionality can be used by methods in Module
|
// It is embedded in Module so its functionality can be used by methods in Module
|
||||||
|
@ -437,9 +393,6 @@ type Module struct {
|
||||||
// output file containing uninstrumented classes that will be instrumented by jacoco
|
// output file containing uninstrumented classes that will be instrumented by jacoco
|
||||||
jacocoReportClassesFile android.Path
|
jacocoReportClassesFile android.Path
|
||||||
|
|
||||||
// output file containing mapping of obfuscated names
|
|
||||||
proguardDictionary android.Path
|
|
||||||
|
|
||||||
// output file of the module, which may be a classes jar or a dex jar
|
// output file of the module, which may be a classes jar or a dex jar
|
||||||
outputFile android.Path
|
outputFile android.Path
|
||||||
extraOutputFiles android.Paths
|
extraOutputFiles android.Paths
|
||||||
|
@ -455,9 +408,6 @@ type Module struct {
|
||||||
compiledJavaSrcs android.Paths
|
compiledJavaSrcs android.Paths
|
||||||
compiledSrcJars android.Paths
|
compiledSrcJars android.Paths
|
||||||
|
|
||||||
// list of extra progurad flag files
|
|
||||||
extraProguardFlagFiles android.Paths
|
|
||||||
|
|
||||||
// manifest file to use instead of properties.Manifest
|
// manifest file to use instead of properties.Manifest
|
||||||
overrideManifest android.OptionalPath
|
overrideManifest android.OptionalPath
|
||||||
|
|
||||||
|
@ -484,6 +434,7 @@ type Module struct {
|
||||||
extraResources android.Paths
|
extraResources android.Paths
|
||||||
|
|
||||||
hiddenAPI
|
hiddenAPI
|
||||||
|
dexer
|
||||||
dexpreopter
|
dexpreopter
|
||||||
linter
|
linter
|
||||||
|
|
||||||
|
@ -507,6 +458,7 @@ func (j *Module) addHostAndDeviceProperties() {
|
||||||
j.addHostProperties()
|
j.addHostProperties()
|
||||||
j.AddProperties(
|
j.AddProperties(
|
||||||
&j.deviceProperties,
|
&j.deviceProperties,
|
||||||
|
&j.dexer.dexProperties,
|
||||||
&j.dexpreoptProperties,
|
&j.dexpreoptProperties,
|
||||||
&j.linter.properties,
|
&j.linter.properties,
|
||||||
)
|
)
|
||||||
|
@ -519,7 +471,10 @@ func (j *Module) OutputFiles(tag string) (android.Paths, error) {
|
||||||
case ".jar":
|
case ".jar":
|
||||||
return android.Paths{j.implementationAndResourcesJar}, nil
|
return android.Paths{j.implementationAndResourcesJar}, nil
|
||||||
case ".proguard_map":
|
case ".proguard_map":
|
||||||
return android.Paths{j.proguardDictionary}, nil
|
if j.dexer.proguardDictionary.Valid() {
|
||||||
|
return android.Paths{j.dexer.proguardDictionary.Path()}, nil
|
||||||
|
}
|
||||||
|
return nil, fmt.Errorf("%q was requested, but no output file was found.", tag)
|
||||||
default:
|
default:
|
||||||
return nil, fmt.Errorf("unsupported module reference tag %q", tag)
|
return nil, fmt.Errorf("unsupported module reference tag %q", tag)
|
||||||
}
|
}
|
||||||
|
@ -728,10 +683,10 @@ func (j *Module) deps(ctx android.BottomUpMutatorContext) {
|
||||||
ctx.AddVariationDependencies(nil, bootClasspathTag, sdkDep.bootclasspath...)
|
ctx.AddVariationDependencies(nil, bootClasspathTag, sdkDep.bootclasspath...)
|
||||||
ctx.AddVariationDependencies(nil, java9LibTag, sdkDep.java9Classpath...)
|
ctx.AddVariationDependencies(nil, java9LibTag, sdkDep.java9Classpath...)
|
||||||
ctx.AddVariationDependencies(nil, libTag, sdkDep.classpath...)
|
ctx.AddVariationDependencies(nil, libTag, sdkDep.classpath...)
|
||||||
if j.deviceProperties.EffectiveOptimizeEnabled() && sdkDep.hasStandardLibs() {
|
if j.effectiveOptimizeEnabled() && sdkDep.hasStandardLibs() {
|
||||||
ctx.AddVariationDependencies(nil, proguardRaiseTag, config.LegacyCorePlatformBootclasspathLibraries...)
|
ctx.AddVariationDependencies(nil, proguardRaiseTag, config.LegacyCorePlatformBootclasspathLibraries...)
|
||||||
}
|
}
|
||||||
if j.deviceProperties.EffectiveOptimizeEnabled() && sdkDep.hasFrameworkLibs() {
|
if j.effectiveOptimizeEnabled() && sdkDep.hasFrameworkLibs() {
|
||||||
ctx.AddVariationDependencies(nil, proguardRaiseTag, config.FrameworkLibraries...)
|
ctx.AddVariationDependencies(nil, proguardRaiseTag, config.FrameworkLibraries...)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1647,8 +1602,8 @@ func (j *Module) compile(ctx android.ModuleContext, aaptSrcJar android.Path) {
|
||||||
|
|
||||||
// Enable dex compilation for the APEX variants, unless it is disabled explicitly
|
// Enable dex compilation for the APEX variants, unless it is disabled explicitly
|
||||||
if android.DirectlyInAnyApex(ctx, ctx.ModuleName()) && !j.IsForPlatform() {
|
if android.DirectlyInAnyApex(ctx, ctx.ModuleName()) && !j.IsForPlatform() {
|
||||||
if j.deviceProperties.Compile_dex == nil {
|
if j.dexProperties.Compile_dex == nil {
|
||||||
j.deviceProperties.Compile_dex = proptools.BoolPtr(true)
|
j.dexProperties.Compile_dex = proptools.BoolPtr(true)
|
||||||
}
|
}
|
||||||
if j.deviceProperties.Hostdex == nil {
|
if j.deviceProperties.Hostdex == nil {
|
||||||
j.deviceProperties.Hostdex = proptools.BoolPtr(true)
|
j.deviceProperties.Hostdex = proptools.BoolPtr(true)
|
||||||
|
@ -1656,10 +1611,14 @@ func (j *Module) compile(ctx android.ModuleContext, aaptSrcJar android.Path) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if ctx.Device() && j.hasCode(ctx) &&
|
if ctx.Device() && j.hasCode(ctx) &&
|
||||||
(Bool(j.properties.Installable) || Bool(j.deviceProperties.Compile_dex)) {
|
(Bool(j.properties.Installable) || Bool(j.dexProperties.Compile_dex)) {
|
||||||
|
if j.shouldInstrumentStatic(ctx) {
|
||||||
|
j.dexer.extraProguardFlagFiles = append(j.dexer.extraProguardFlagFiles,
|
||||||
|
android.PathForSource(ctx, "build/make/core/proguard.jacoco.flags"))
|
||||||
|
}
|
||||||
// Dex compilation
|
// Dex compilation
|
||||||
var dexOutputFile android.ModuleOutPath
|
var dexOutputFile android.ModuleOutPath
|
||||||
dexOutputFile = j.compileDex(ctx, flags, outputFile, jarName)
|
dexOutputFile = j.dexer.compileDex(ctx, flags, j.minSdkVersion(), outputFile, jarName)
|
||||||
if ctx.Failed() {
|
if ctx.Failed() {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
@ -1669,7 +1628,7 @@ func (j *Module) compile(ctx android.ModuleContext, aaptSrcJar android.Path) {
|
||||||
|
|
||||||
// Hidden API CSV generation and dex encoding
|
// Hidden API CSV generation and dex encoding
|
||||||
dexOutputFile = j.hiddenAPI.hiddenAPI(ctx, configurationName, primary, dexOutputFile, j.implementationJarFile,
|
dexOutputFile = j.hiddenAPI.hiddenAPI(ctx, configurationName, primary, dexOutputFile, j.implementationJarFile,
|
||||||
proptools.Bool(j.deviceProperties.Uncompress_dex))
|
proptools.Bool(j.dexProperties.Uncompress_dex))
|
||||||
|
|
||||||
// merge dex jar with resources if necessary
|
// merge dex jar with resources if necessary
|
||||||
if j.resourceJar != nil {
|
if j.resourceJar != nil {
|
||||||
|
@ -1677,7 +1636,7 @@ func (j *Module) compile(ctx android.ModuleContext, aaptSrcJar android.Path) {
|
||||||
combinedJar := android.PathForModuleOut(ctx, "dex-withres", jarName)
|
combinedJar := android.PathForModuleOut(ctx, "dex-withres", jarName)
|
||||||
TransformJarsToJar(ctx, combinedJar, "for dex resources", jars, android.OptionalPath{},
|
TransformJarsToJar(ctx, combinedJar, "for dex resources", jars, android.OptionalPath{},
|
||||||
false, nil, nil)
|
false, nil, nil)
|
||||||
if *j.deviceProperties.Uncompress_dex {
|
if *j.dexProperties.Uncompress_dex {
|
||||||
combinedAlignedJar := android.PathForModuleOut(ctx, "dex-withres-aligned", jarName)
|
combinedAlignedJar := android.PathForModuleOut(ctx, "dex-withres-aligned", jarName)
|
||||||
TransformZipAlign(ctx, combinedAlignedJar, combinedJar)
|
TransformZipAlign(ctx, combinedAlignedJar, combinedJar)
|
||||||
dexOutputFile = combinedAlignedJar
|
dexOutputFile = combinedAlignedJar
|
||||||
|
@ -2008,11 +1967,11 @@ func (j *Library) GenerateAndroidBuildActions(ctx android.ModuleContext) {
|
||||||
j.checkSdkVersions(ctx)
|
j.checkSdkVersions(ctx)
|
||||||
j.dexpreopter.installPath = android.PathForModuleInstall(ctx, "framework", j.Stem()+".jar")
|
j.dexpreopter.installPath = android.PathForModuleInstall(ctx, "framework", j.Stem()+".jar")
|
||||||
j.dexpreopter.isSDKLibrary = j.deviceProperties.IsSDKLibrary
|
j.dexpreopter.isSDKLibrary = j.deviceProperties.IsSDKLibrary
|
||||||
if j.deviceProperties.Uncompress_dex == nil {
|
if j.dexProperties.Uncompress_dex == nil {
|
||||||
// If the value was not force-set by the user, use reasonable default based on the module.
|
// If the value was not force-set by the user, use reasonable default based on the module.
|
||||||
j.deviceProperties.Uncompress_dex = proptools.BoolPtr(shouldUncompressDex(ctx, &j.dexpreopter))
|
j.dexProperties.Uncompress_dex = proptools.BoolPtr(shouldUncompressDex(ctx, &j.dexpreopter))
|
||||||
}
|
}
|
||||||
j.dexpreopter.uncompressedDex = *j.deviceProperties.Uncompress_dex
|
j.dexpreopter.uncompressedDex = *j.dexProperties.Uncompress_dex
|
||||||
j.compile(ctx, nil)
|
j.compile(ctx, nil)
|
||||||
|
|
||||||
// Collect the module directory for IDE info in java/jdeps.go.
|
// Collect the module directory for IDE info in java/jdeps.go.
|
||||||
|
@ -2970,6 +2929,7 @@ func DefaultsFactory() android.Module {
|
||||||
module.AddProperties(
|
module.AddProperties(
|
||||||
&CompilerProperties{},
|
&CompilerProperties{},
|
||||||
&CompilerDeviceProperties{},
|
&CompilerDeviceProperties{},
|
||||||
|
&DexProperties{},
|
||||||
&DexpreoptProperties{},
|
&DexpreoptProperties{},
|
||||||
&android.ProtoProperties{},
|
&android.ProtoProperties{},
|
||||||
&aaptProperties{},
|
&aaptProperties{},
|
||||||
|
|
|
@ -1112,6 +1112,7 @@ func (module *SdkLibrary) createImplLibrary(mctx android.DefaultableHookContext)
|
||||||
&module.properties,
|
&module.properties,
|
||||||
&module.protoProperties,
|
&module.protoProperties,
|
||||||
&module.deviceProperties,
|
&module.deviceProperties,
|
||||||
|
&module.dexProperties,
|
||||||
&module.dexpreoptProperties,
|
&module.dexpreoptProperties,
|
||||||
&module.linter.properties,
|
&module.linter.properties,
|
||||||
&props,
|
&props,
|
||||||
|
@ -1171,8 +1172,8 @@ func (module *SdkLibrary) createStubsLibrary(mctx android.DefaultableHookContext
|
||||||
// We compile the stubs for 1.8 in line with the main android.jar stubs, and potential
|
// We compile the stubs for 1.8 in line with the main android.jar stubs, and potential
|
||||||
// interop with older developer tools that don't support 1.9.
|
// interop with older developer tools that don't support 1.9.
|
||||||
props.Java_version = proptools.StringPtr("1.8")
|
props.Java_version = proptools.StringPtr("1.8")
|
||||||
if module.deviceProperties.Compile_dex != nil {
|
if module.dexProperties.Compile_dex != nil {
|
||||||
props.Compile_dex = module.deviceProperties.Compile_dex
|
props.Compile_dex = module.dexProperties.Compile_dex
|
||||||
}
|
}
|
||||||
|
|
||||||
// Dist the class jar artifact for sdk builds.
|
// Dist the class jar artifact for sdk builds.
|
||||||
|
|
Loading…
Reference in New Issue