diff options
Diffstat (limited to 'java/androidmk.go')
| -rw-r--r-- | java/androidmk.go | 113 | 
1 files changed, 59 insertions, 54 deletions
| diff --git a/java/androidmk.go b/java/androidmk.go index 9c21633fb..a1bc90494 100644 --- a/java/androidmk.go +++ b/java/androidmk.go @@ -17,9 +17,10 @@ package java  import (  	"fmt"  	"io" -	"strings"  	"android/soong/android" + +	"github.com/google/blueprint/proptools"  )  func (library *Library) AndroidMkEntriesHostDex() android.AndroidMkEntries { @@ -79,6 +80,9 @@ func (library *Library) AndroidMkEntries() []android.AndroidMkEntries {  	} else if !library.ApexModuleBase.AvailableFor(android.AvailableToPlatform) {  		// Platform variant.  If not available for the platform, we don't need Make module.  		entriesList = append(entriesList, android.AndroidMkEntries{Disabled: true}) +	} else if proptools.Bool(library.properties.Headers_only) { +		// If generating headers only then don't expose to Make. +		entriesList = append(entriesList, android.AndroidMkEntries{Disabled: true})  	} else {  		entriesList = append(entriesList, android.AndroidMkEntries{  			Class:      "JAVA_LIBRARIES", @@ -87,11 +91,7 @@ func (library *Library) AndroidMkEntries() []android.AndroidMkEntries {  			ExtraEntries: []android.AndroidMkExtraEntriesFunc{  				func(ctx android.AndroidMkExtraEntriesContext, entries *android.AndroidMkEntries) {  					if len(library.logtagsSrcs) > 0 { -						var logtags []string -						for _, l := range library.logtagsSrcs { -							logtags = append(logtags, l.Rel()) -						} -						entries.AddStrings("LOCAL_LOGTAGS_FILES", logtags...) +						entries.AddStrings("LOCAL_SOONG_LOGTAGS_FILES", library.logtagsSrcs.Strings()...)  					}  					if library.installFile == nil { @@ -200,26 +200,24 @@ func (j *TestHelperLibrary) AndroidMkEntries() []android.AndroidMkEntries {  func (prebuilt *Import) AndroidMkEntries() []android.AndroidMkEntries {  	if prebuilt.hideApexVariantFromMake { -		// For a library imported from a prebuilt APEX, we don't need a Make module for itself, as we -		// don't need to install it. However, we need to add its dexpreopt outputs as sub-modules, if it -		// is preopted. -		dexpreoptEntries := prebuilt.dexpreopter.AndroidMkEntriesForApex() -		return append(dexpreoptEntries, android.AndroidMkEntries{Disabled: true}) +		return []android.AndroidMkEntries{}  	}  	return []android.AndroidMkEntries{android.AndroidMkEntries{ -		Class:      "JAVA_LIBRARIES", -		OutputFile: android.OptionalPathForPath(prebuilt.combinedClasspathFile), -		Include:    "$(BUILD_SYSTEM)/soong_java_prebuilt.mk", +		Class:        "JAVA_LIBRARIES", +		OverrideName: prebuilt.BaseModuleName(), +		OutputFile:   android.OptionalPathForPath(prebuilt.combinedImplementationFile), +		Include:      "$(BUILD_SYSTEM)/soong_java_prebuilt.mk",  		ExtraEntries: []android.AndroidMkExtraEntriesFunc{  			func(ctx android.AndroidMkExtraEntriesContext, entries *android.AndroidMkEntries) {  				entries.SetBool("LOCAL_UNINSTALLABLE_MODULE", !Bool(prebuilt.properties.Installable))  				if prebuilt.dexJarFile.IsSet() {  					entries.SetPath("LOCAL_SOONG_DEX_JAR", prebuilt.dexJarFile.Path())  				} -				entries.SetPath("LOCAL_SOONG_HEADER_JAR", prebuilt.combinedClasspathFile) -				entries.SetPath("LOCAL_SOONG_CLASSES_JAR", prebuilt.combinedClasspathFile) +				entries.SetPath("LOCAL_SOONG_HEADER_JAR", prebuilt.combinedHeaderFile) +				entries.SetPath("LOCAL_SOONG_CLASSES_JAR", prebuilt.combinedImplementationFile)  				entries.SetString("LOCAL_SDK_VERSION", prebuilt.sdkVersion.String())  				entries.SetString("LOCAL_MODULE_STEM", prebuilt.Stem()) +				// TODO(b/289117800): LOCAL_ACONFIG_FILES for prebuilts  			},  		},  	}} @@ -244,6 +242,7 @@ func (prebuilt *DexImport) AndroidMkEntries() []android.AndroidMkEntries {  					entries.SetString("LOCAL_SOONG_BUILT_INSTALLED", prebuilt.dexpreopter.builtInstalled)  				}  				entries.SetString("LOCAL_MODULE_STEM", prebuilt.Stem()) +				// TODO(b/289117800): LOCAL_ACONFIG_FILES for prebuilts  			},  		},  	}} @@ -257,18 +256,20 @@ func (prebuilt *AARImport) AndroidMkEntries() []android.AndroidMkEntries {  	}  	return []android.AndroidMkEntries{android.AndroidMkEntries{  		Class:      "JAVA_LIBRARIES", -		OutputFile: android.OptionalPathForPath(prebuilt.classpathFile), +		OutputFile: android.OptionalPathForPath(prebuilt.implementationJarFile),  		Include:    "$(BUILD_SYSTEM)/soong_java_prebuilt.mk",  		ExtraEntries: []android.AndroidMkExtraEntriesFunc{  			func(ctx android.AndroidMkExtraEntriesContext, entries *android.AndroidMkEntries) {  				entries.SetBool("LOCAL_UNINSTALLABLE_MODULE", true) -				entries.SetPath("LOCAL_SOONG_HEADER_JAR", prebuilt.classpathFile) -				entries.SetPath("LOCAL_SOONG_CLASSES_JAR", prebuilt.classpathFile) +				entries.SetPath("LOCAL_SOONG_HEADER_JAR", prebuilt.headerJarFile) +				entries.SetPath("LOCAL_SOONG_CLASSES_JAR", prebuilt.implementationJarFile)  				entries.SetPath("LOCAL_SOONG_RESOURCE_EXPORT_PACKAGE", prebuilt.exportPackage) +				entries.SetPath("LOCAL_SOONG_TRANSITIVE_RES_PACKAGES", prebuilt.transitiveAaptResourcePackagesFile)  				entries.SetPath("LOCAL_SOONG_EXPORT_PROGUARD_FLAGS", prebuilt.proguardFlags)  				entries.SetPath("LOCAL_SOONG_STATIC_LIBRARY_EXTRA_PACKAGES", prebuilt.extraAaptPackagesFile)  				entries.SetPath("LOCAL_FULL_MANIFEST_FILE", prebuilt.manifest)  				entries.SetString("LOCAL_SDK_VERSION", prebuilt.sdkVersion.String()) +				// TODO(b/289117800): LOCAL_ACONFIG_FILES for prebuilts  			},  		},  	}} @@ -331,15 +332,23 @@ func (app *AndroidApp) AndroidMkEntries() []android.AndroidMkEntries {  			Disabled: true,  		}}  	} +	var required []string +	if proptools.Bool(app.appProperties.Generate_product_characteristics_rro) { +		required = []string{app.productCharacteristicsRROPackageName()} +	}  	return []android.AndroidMkEntries{android.AndroidMkEntries{  		Class:      "APPS",  		OutputFile: android.OptionalPathForPath(app.outputFile),  		Include:    "$(BUILD_SYSTEM)/soong_app_prebuilt.mk", +		Required:   required,  		ExtraEntries: []android.AndroidMkExtraEntriesFunc{  			func(ctx android.AndroidMkExtraEntriesContext, entries *android.AndroidMkEntries) {  				// App module names can be overridden.  				entries.SetString("LOCAL_MODULE", app.installApkName)  				entries.SetBoolIfTrue("LOCAL_UNINSTALLABLE_MODULE", app.appProperties.PreventInstall) +				if app.headerJarFile != nil { +					entries.SetPath("LOCAL_SOONG_HEADER_JAR", app.headerJarFile) +				}  				entries.SetPath("LOCAL_SOONG_RESOURCE_EXPORT_PACKAGE", app.exportPackage)  				if app.dexJarFile.IsSet() {  					entries.SetPath("LOCAL_SOONG_DEX_JAR", app.dexJarFile.Path()) @@ -368,8 +377,13 @@ func (app *AndroidApp) AndroidMkEntries() []android.AndroidMkEntries {  				filterRRO := func(filter overlayType) android.Paths {  					var paths android.Paths -					for _, d := range app.rroDirs { +					seen := make(map[android.Path]bool) +					for _, d := range app.rroDirsDepSet.ToList() {  						if d.overlayType == filter { +							if seen[d.path] { +								continue +							} +							seen[d.path] = true  							paths = append(paths, d.path)  						}  					} @@ -399,22 +413,11 @@ func (app *AndroidApp) AndroidMkEntries() []android.AndroidMkEntries {  					jniSymbols := app.JNISymbolsInstalls(app.installPathForJNISymbols.String())  					entries.SetString("LOCAL_SOONG_JNI_LIBS_SYMBOLS", jniSymbols.String())  				} else { +					var names []string  					for _, jniLib := range app.jniLibs { -						entries.AddStrings("LOCAL_SOONG_JNI_LIBS_"+jniLib.target.Arch.ArchType.String(), jniLib.name) -						var partitionTag string - -						// Mimic the creation of partition_tag in build/make, -						// which defaults to an empty string when the partition is system. -						// Otherwise, capitalize with a leading _ -						if jniLib.partition == "system" { -							partitionTag = "" -						} else { -							split := strings.Split(jniLib.partition, "/") -							partitionTag = "_" + strings.ToUpper(split[len(split)-1]) -						} -						entries.AddStrings("LOCAL_SOONG_JNI_LIBS_PARTITION_"+jniLib.target.Arch.ArchType.String(), -							jniLib.name+":"+partitionTag) +						names = append(names, jniLib.name)  					} +					entries.AddStrings("LOCAL_REQUIRED_MODULES", names...)  				}  				if len(app.jniCoverageOutputs) > 0 { @@ -432,6 +435,8 @@ func (app *AndroidApp) AndroidMkEntries() []android.AndroidMkEntries {  				}  				entries.SetOptionalPaths("LOCAL_SOONG_LINT_REPORTS", app.linter.reports) + +				entries.AddStrings("LOCAL_SOONG_LOGTAGS_FILES", app.logtagsSrcs.Strings()...)  			},  		},  		ExtraFooters: []android.AndroidMkExtraFootersFunc{ @@ -450,11 +455,6 @@ func (a *AndroidApp) getOverriddenPackages() []string {  	if len(a.overridableAppProperties.Overrides) > 0 {  		overridden = append(overridden, a.overridableAppProperties.Overrides...)  	} -	// When APK name is overridden via PRODUCT_PACKAGE_NAME_OVERRIDES -	// ensure that the original name is overridden. -	if a.Stem() != a.installApkName { -		overridden = append(overridden, a.Stem()) -	}  	return overridden  } @@ -508,9 +508,10 @@ func (a *AndroidLibrary) AndroidMkEntries() []android.AndroidMkEntries {  		}  		entries.SetPath("LOCAL_SOONG_RESOURCE_EXPORT_PACKAGE", a.exportPackage) +		entries.SetPath("LOCAL_SOONG_TRANSITIVE_RES_PACKAGES", a.transitiveAaptResourcePackagesFile)  		entries.SetPath("LOCAL_SOONG_STATIC_LIBRARY_EXTRA_PACKAGES", a.extraAaptPackagesFile)  		entries.SetPath("LOCAL_FULL_MANIFEST_FILE", a.mergedManifestFile) -		entries.AddStrings("LOCAL_SOONG_EXPORT_PROGUARD_FLAGS", a.exportedProguardFlagFiles.Strings()...) +		entries.SetPath("LOCAL_SOONG_EXPORT_PROGUARD_FLAGS", a.combinedExportedProguardFlagsFile)  		entries.SetBoolIfTrue("LOCAL_UNINSTALLABLE_MODULE", true)  	}) @@ -527,8 +528,8 @@ func (jd *Javadoc) AndroidMkEntries() []android.AndroidMkEntries {  				if BoolDefault(jd.properties.Installable, true) {  					entries.SetPath("LOCAL_DROIDDOC_DOC_ZIP", jd.docZip)  				} -				if jd.stubsSrcJar != nil { -					entries.SetPath("LOCAL_DROIDDOC_STUBS_SRCJAR", jd.stubsSrcJar) +				if jd.exportableStubsSrcJar != nil { +					entries.SetPath("LOCAL_DROIDDOC_STUBS_SRCJAR", jd.exportableStubsSrcJar)  				}  			},  		}, @@ -566,7 +567,7 @@ func (dstubs *Droidstubs) AndroidMkEntries() []android.AndroidMkEntries {  		outputFile = android.OptionalPathForPath(dstubs.apiFile)  	}  	if !outputFile.Valid() { -		outputFile = android.OptionalPathForPath(dstubs.apiVersionsXml) +		outputFile = android.OptionalPathForPath(dstubs.everythingArtifacts.apiVersionsXml)  	}  	return []android.AndroidMkEntries{android.AndroidMkEntries{  		Class:      "JAVA_LIBRARIES", @@ -574,17 +575,17 @@ func (dstubs *Droidstubs) AndroidMkEntries() []android.AndroidMkEntries {  		Include:    "$(BUILD_SYSTEM)/soong_droiddoc_prebuilt.mk",  		ExtraEntries: []android.AndroidMkExtraEntriesFunc{  			func(ctx android.AndroidMkExtraEntriesContext, entries *android.AndroidMkEntries) { -				if dstubs.Javadoc.stubsSrcJar != nil { -					entries.SetPath("LOCAL_DROIDDOC_STUBS_SRCJAR", dstubs.Javadoc.stubsSrcJar) +				if dstubs.Javadoc.exportableStubsSrcJar != nil { +					entries.SetPath("LOCAL_DROIDDOC_STUBS_SRCJAR", dstubs.Javadoc.exportableStubsSrcJar)  				} -				if dstubs.apiVersionsXml != nil { -					entries.SetPath("LOCAL_DROIDDOC_API_VERSIONS_XML", dstubs.apiVersionsXml) +				if dstubs.everythingArtifacts.apiVersionsXml != nil { +					entries.SetPath("LOCAL_DROIDDOC_API_VERSIONS_XML", dstubs.exportableArtifacts.apiVersionsXml)  				} -				if dstubs.annotationsZip != nil { -					entries.SetPath("LOCAL_DROIDDOC_ANNOTATIONS_ZIP", dstubs.annotationsZip) +				if dstubs.everythingArtifacts.annotationsZip != nil { +					entries.SetPath("LOCAL_DROIDDOC_ANNOTATIONS_ZIP", dstubs.exportableArtifacts.annotationsZip)  				} -				if dstubs.metadataZip != nil { -					entries.SetPath("LOCAL_DROIDDOC_METADATA_ZIP", dstubs.metadataZip) +				if dstubs.everythingArtifacts.metadataZip != nil { +					entries.SetPath("LOCAL_DROIDDOC_METADATA_ZIP", dstubs.exportableArtifacts.metadataZip)  				}  			},  		}, @@ -669,9 +670,10 @@ func (a *AndroidAppImport) AndroidMkEntries() []android.AndroidMkEntries {  		return nil  	}  	return []android.AndroidMkEntries{android.AndroidMkEntries{ -		Class:      "APPS", -		OutputFile: android.OptionalPathForPath(a.outputFile), -		Include:    "$(BUILD_SYSTEM)/soong_app_prebuilt.mk", +		Class:        "APPS", +		OutputFile:   android.OptionalPathForPath(a.outputFile), +		OverrideName: a.BaseModuleName(), // TODO (spandandas): Add a test +		Include:      "$(BUILD_SYSTEM)/soong_app_prebuilt.mk",  		ExtraEntries: []android.AndroidMkExtraEntriesFunc{  			func(ctx android.AndroidMkExtraEntriesContext, entries *android.AndroidMkEntries) {  				entries.SetBoolIfTrue("LOCAL_PRIVILEGED_MODULE", a.Privileged()) @@ -684,6 +686,7 @@ func (a *AndroidAppImport) AndroidMkEntries() []android.AndroidMkEntries {  				if Bool(a.properties.Export_package_resources) {  					entries.SetPath("LOCAL_SOONG_RESOURCE_EXPORT_PACKAGE", a.outputFile)  				} +				// TODO(b/289117800): LOCAL_ACONFIG_FILES for prebuilts  			},  		},  	}} @@ -717,6 +720,7 @@ func (r *RuntimeResourceOverlay) AndroidMkEntries() []android.AndroidMkEntries {  				entries.SetString("LOCAL_CERTIFICATE", r.certificate.AndroidMkString())  				entries.SetPath("LOCAL_MODULE_PATH", r.installDir)  				entries.AddStrings("LOCAL_OVERRIDES_PACKAGES", r.properties.Overrides...) +				// TODO: LOCAL_ACONFIG_FILES -- Might eventually need aconfig flags?  			},  		},  	}} @@ -734,6 +738,7 @@ func (apkSet *AndroidAppSet) AndroidMkEntries() []android.AndroidMkEntries {  					entries.SetPath("LOCAL_APK_SET_INSTALL_FILE", apkSet.PackedAdditionalOutputs())  					entries.SetPath("LOCAL_APKCERTS_FILE", apkSet.apkcertsFile)  					entries.AddStrings("LOCAL_OVERRIDES_PACKAGES", apkSet.properties.Overrides...) +					// TODO(b/289117800): LOCAL_ACONFIG_FILES for prebuilts -- Both declarations and values  				},  			},  		}, |