diff options
Diffstat (limited to 'java/java.go')
| -rw-r--r-- | java/java.go | 114 | 
1 files changed, 92 insertions, 22 deletions
| diff --git a/java/java.go b/java/java.go index ec778966d..9830c51f6 100644 --- a/java/java.go +++ b/java/java.go @@ -324,6 +324,10 @@ type CompilerDeviceProperties struct {  	Stem *string  	IsSDKLibrary bool `blueprint:"mutated"` + +	// If true, generate the signature file of APK Signing Scheme V4, along side the signed APK file. +	// Defaults to false. +	V4_signature *bool  }  // Functionality common to Module and Import @@ -437,6 +441,7 @@ type Module struct {  	hiddenAPI  	dexer  	dexpreopter +	usesLibrary  	linter  	// list of the xref extraction files @@ -452,6 +457,7 @@ func (j *Module) addHostProperties() {  	j.AddProperties(  		&j.properties,  		&j.protoProperties, +		&j.usesLibraryProperties,  	)  } @@ -564,6 +570,7 @@ var (  	certificateTag        = dependencyTag{name: "certificate"}  	instrumentationForTag = dependencyTag{name: "instrumentation_for"}  	usesLibTag            = dependencyTag{name: "uses-library"} +	usesLibCompatTag      = dependencyTag{name: "uses-library-compat"}  	extraLintCheckTag     = dependencyTag{name: "extra-lint-check"}  ) @@ -679,25 +686,29 @@ func (j *Module) AvailableFor(what string) bool {  	return j.ApexModuleBase.AvailableFor(what)  } +func sdkDeps(ctx android.BottomUpMutatorContext, sdkContext sdkContext, d dexer) { +	sdkDep := decodeSdkDep(ctx, sdkContext) +	if sdkDep.useModule { +		ctx.AddVariationDependencies(nil, bootClasspathTag, sdkDep.bootclasspath...) +		ctx.AddVariationDependencies(nil, java9LibTag, sdkDep.java9Classpath...) +		ctx.AddVariationDependencies(nil, libTag, sdkDep.classpath...) +		if d.effectiveOptimizeEnabled() && sdkDep.hasStandardLibs() { +			ctx.AddVariationDependencies(nil, proguardRaiseTag, config.LegacyCorePlatformBootclasspathLibraries...) +		} +		if d.effectiveOptimizeEnabled() && sdkDep.hasFrameworkLibs() { +			ctx.AddVariationDependencies(nil, proguardRaiseTag, config.FrameworkLibraries...) +		} +	} +	if sdkDep.systemModules != "" { +		ctx.AddVariationDependencies(nil, systemModulesTag, sdkDep.systemModules) +	} +} +  func (j *Module) deps(ctx android.BottomUpMutatorContext) {  	if ctx.Device() {  		j.linter.deps(ctx) -		sdkDep := decodeSdkDep(ctx, sdkContext(j)) -		if sdkDep.useModule { -			ctx.AddVariationDependencies(nil, bootClasspathTag, sdkDep.bootclasspath...) -			ctx.AddVariationDependencies(nil, java9LibTag, sdkDep.java9Classpath...) -			ctx.AddVariationDependencies(nil, libTag, sdkDep.classpath...) -			if j.effectiveOptimizeEnabled() && sdkDep.hasStandardLibs() { -				ctx.AddVariationDependencies(nil, proguardRaiseTag, config.LegacyCorePlatformBootclasspathLibraries...) -			} -			if j.effectiveOptimizeEnabled() && sdkDep.hasFrameworkLibs() { -				ctx.AddVariationDependencies(nil, proguardRaiseTag, config.FrameworkLibraries...) -			} -		} -		if sdkDep.systemModules != "" { -			ctx.AddVariationDependencies(nil, systemModulesTag, sdkDep.systemModules) -		} +		sdkDeps(ctx, sdkContext(j), j.dexer)  	}  	syspropPublicStubs := syspropPublicStubs(ctx.Config()) @@ -991,7 +1002,7 @@ func (j *Module) collectDeps(ctx android.ModuleContext) deps {  			case libTag:  				deps.classpath = append(deps.classpath, dep.SdkHeaderJars(ctx, j.sdkVersion())...)  				// names of sdk libs that are directly depended are exported -				j.exportedSdkLibs.AddLibraryPath(ctx, dep.OptionalImplicitSdkLibrary(), dep.DexJarBuildPath(), dep.DexJarInstallPath()) +				j.exportedSdkLibs.MaybeAddLibraryPath(ctx, dep.OptionalImplicitSdkLibrary(), dep.DexJarBuildPath(), dep.DexJarInstallPath())  			case staticLibTag:  				ctx.ModuleErrorf("dependency on java_sdk_library %q can only be in libs", otherName)  			} @@ -1483,7 +1494,7 @@ func (j *Module) compile(ctx android.ModuleContext, aaptSrcJar android.Path) {  		args := map[string]string{  			"jarArgs": "-P META-INF/services/ " + strings.Join(proptools.NinjaAndShellEscapeList(zipargs), " "),  		} -		if ctx.Config().IsEnvTrue("RBE_ZIP") { +		if ctx.Config().UseRBE() && ctx.Config().IsEnvTrue("RBE_ZIP") {  			rule = zipRE  			args["implicits"] = strings.Join(services.Strings(), ",")  		} @@ -1970,7 +1981,12 @@ func (j *Library) GenerateAndroidBuildActions(ctx android.ModuleContext) {  	// add the name of that java_sdk_library to the exported sdk libs to make sure  	// that, if necessary, a <uses-library> element for that java_sdk_library is  	// added to the Android manifest. -	j.exportedSdkLibs.AddLibraryPath(ctx, j.OptionalImplicitSdkLibrary(), j.DexJarBuildPath(), j.DexJarInstallPath()) +	j.exportedSdkLibs.MaybeAddLibraryPath(ctx, j.OptionalImplicitSdkLibrary(), j.DexJarBuildPath(), j.DexJarInstallPath()) + +	// A non-SDK library may provide a <uses-library> (the name may be different from the module name). +	if lib := proptools.String(j.usesLibraryProperties.Provides_uses_lib); lib != "" { +		j.exportedSdkLibs.AddLibraryPath(ctx, lib, j.DexJarBuildPath(), j.DexJarInstallPath()) +	}  	j.distFiles = j.GenerateTaggedDistFiles(ctx)  } @@ -2209,6 +2225,7 @@ type JavaTestImport struct {  	prebuiltTestProperties prebuiltTestProperties  	testConfig android.Path +	dexJarFile android.Path  }  func (j *TestHost) DepsMutator(ctx android.BottomUpMutatorContext) { @@ -2531,8 +2548,14 @@ type Import struct {  	// Functionality common to Module and Import.  	embeddableInModuleAndImport +	hiddenAPI +	dexer +  	properties ImportProperties +	// output file containing classes.dex and resources +	dexJarFile android.Path +  	combinedClasspathFile android.Path  	exportedSdkLibs       dexpreopt.LibraryPaths  	exportAidlIncludeDirs android.Paths @@ -2542,10 +2565,22 @@ func (j *Import) sdkVersion() sdkSpec {  	return sdkSpecFrom(String(j.properties.Sdk_version))  } +func (j *Import) makeSdkVersion() string { +	return j.sdkVersion().raw +} + +func (j *Import) systemModules() string { +	return "none" +} +  func (j *Import) minSdkVersion() sdkSpec {  	return j.sdkVersion()  } +func (j *Import) targetSdkVersion() sdkSpec { +	return j.sdkVersion() +} +  func (j *Import) MinSdkVersion() string {  	return j.minSdkVersion().version.String()  } @@ -2572,6 +2607,10 @@ func (a *Import) JacocoReportClassesFile() android.Path {  func (j *Import) DepsMutator(ctx android.BottomUpMutatorContext) {  	ctx.AddVariationDependencies(nil, libTag, j.properties.Libs...) + +	if ctx.Device() && Bool(j.dexProperties.Compile_dex) { +		sdkDeps(ctx, sdkContext(j), j.dexer) +	}  }  func (j *Import) GenerateAndroidBuildActions(ctx android.ModuleContext) { @@ -2589,6 +2628,8 @@ func (j *Import) GenerateAndroidBuildActions(ctx android.ModuleContext) {  	j.combinedClasspathFile = outputFile  	j.exportedSdkLibs = make(dexpreopt.LibraryPaths) +	var flags javaBuilderFlags +  	ctx.VisitDirectDeps(func(module android.Module) {  		otherName := ctx.OtherModuleName(module)  		tag := ctx.OtherModuleDependencyTag(module) @@ -2597,14 +2638,18 @@ func (j *Import) GenerateAndroidBuildActions(ctx android.ModuleContext) {  		case Dependency:  			switch tag {  			case libTag, staticLibTag: +				flags.classpath = append(flags.classpath, dep.HeaderJars()...)  				// sdk lib names from dependencies are re-exported  				j.exportedSdkLibs.AddLibraryPaths(dep.ExportedSdkLibs()) +			case bootClasspathTag: +				flags.bootClasspath = append(flags.bootClasspath, dep.HeaderJars()...)  			}  		case SdkLibraryDependency:  			switch tag {  			case libTag: +				flags.classpath = append(flags.classpath, dep.SdkHeaderJars(ctx, j.sdkVersion())...)  				// names of sdk libs that are directly depended are exported -				j.exportedSdkLibs.AddLibraryPath(ctx, &otherName, dep.DexJarBuildPath(), dep.DexJarInstallPath()) +				j.exportedSdkLibs.AddLibraryPath(ctx, otherName, dep.DexJarBuildPath(), dep.DexJarInstallPath())  			}  		}  	}) @@ -2619,9 +2664,29 @@ func (j *Import) GenerateAndroidBuildActions(ctx android.ModuleContext) {  	// add the name of that java_sdk_library to the exported sdk libs to make sure  	// that, if necessary, a <uses-library> element for that java_sdk_library is  	// added to the Android manifest. -	j.exportedSdkLibs.AddLibraryPath(ctx, j.OptionalImplicitSdkLibrary(), outputFile, installFile) +	j.exportedSdkLibs.MaybeAddLibraryPath(ctx, j.OptionalImplicitSdkLibrary(), outputFile, installFile)  	j.exportAidlIncludeDirs = android.PathsForModuleSrc(ctx, j.properties.Aidl.Export_include_dirs) + +	if ctx.Device() && Bool(j.dexProperties.Compile_dex) { +		sdkDep := decodeSdkDep(ctx, sdkContext(j)) +		if sdkDep.invalidVersion { +			ctx.AddMissingDependencies(sdkDep.bootclasspath) +			ctx.AddMissingDependencies(sdkDep.java9Classpath) +		} else if sdkDep.useFiles { +			// sdkDep.jar is actually equivalent to turbine header.jar. +			flags.classpath = append(flags.classpath, sdkDep.jars...) +		} + +		// Dex compilation +		var dexOutputFile android.ModuleOutPath +		dexOutputFile = j.dexer.compileDex(ctx, flags, j.minSdkVersion(), outputFile, jarName) +		if ctx.Failed() { +			return +		} + +		j.dexJarFile = dexOutputFile +	}  }  var _ Dependency = (*Import)(nil) @@ -2652,7 +2717,7 @@ func (j *Import) ImplementationAndResourcesJars() android.Paths {  }  func (j *Import) DexJarBuildPath() android.Path { -	return nil +	return j.dexJarFile  }  func (j *Import) DexJarInstallPath() android.Path { @@ -2720,10 +2785,15 @@ var _ android.PrebuiltInterface = (*Import)(nil)  func ImportFactory() android.Module {  	module := &Import{} -	module.AddProperties(&module.properties) +	module.AddProperties( +		&module.properties, +		&module.dexer.dexProperties, +	)  	module.initModuleAndImport(&module.ModuleBase) +	module.dexProperties.Optimize.EnabledByDefault = false +  	android.InitPrebuiltModule(module, &module.properties.Jars)  	android.InitApexModule(module)  	android.InitSdkAwareModule(module) |