diff options
Diffstat (limited to 'java/java.go')
| -rw-r--r-- | java/java.go | 100 | 
1 files changed, 84 insertions, 16 deletions
| diff --git a/java/java.go b/java/java.go index 499a6b6cd..97d55146c 100644 --- a/java/java.go +++ b/java/java.go @@ -388,6 +388,8 @@ var (  	jniLibTag               = dependencyTag{name: "jnilib", runtimeLinked: true}  	r8LibraryJarTag         = dependencyTag{name: "r8-libraryjar", runtimeLinked: true}  	syspropPublicStubDepTag = dependencyTag{name: "sysprop public stub"} +	javaApiContributionTag  = dependencyTag{name: "java-api-contribution"} +	depApiSrcsTag           = dependencyTag{name: "dep-api-srcs"}  	jniInstallTag           = installDependencyTag{name: "jni install"}  	binaryInstallTag        = installDependencyTag{name: "binary install"}  	usesLibReqTag           = makeUsesLibraryDependencyTag(dexpreopt.AnySdkVersion, false) @@ -1609,6 +1611,13 @@ func (ap *JavaApiContribution) GenerateAndroidBuildActions(ctx android.ModuleCon  	})  } +type JavaApiLibraryDepsInfo struct { +	StubsJar    android.Path +	StubsSrcJar android.Path +} + +var JavaApiLibraryDepsProvider = blueprint.NewProvider(JavaApiLibraryDepsInfo{}) +  type ApiLibrary struct {  	android.ModuleBase  	android.DefaultableModuleBase @@ -1618,8 +1627,10 @@ type ApiLibrary struct {  	properties JavaApiLibraryProperties -	stubsSrcJar android.WritablePath -	stubsJar    android.WritablePath +	stubsSrcJar               android.WritablePath +	stubsJar                  android.WritablePath +	stubsJarWithoutStaticLibs android.WritablePath +	extractedSrcJar           android.WritablePath  	// .dex of stubs, used for hiddenapi processing  	dexJarFile OptionalDexJarPath  } @@ -1645,8 +1656,13 @@ type JavaApiLibraryProperties struct {  	Libs []string  	// List of java libs that this module has static dependencies to and will be -	// passed in metalava invocation +	// merge zipped after metalava invocation  	Static_libs []string + +	// Java Api library to provide the full API surface text files and jar file. +	// If this property is set, the provided full API surface text files and +	// jar file are passed to metalava invocation. +	Dep_api_srcs *string  }  func ApiLibraryFactory() android.Module { @@ -1725,7 +1741,36 @@ func (al *ApiLibrary) stubsFlags(ctx android.ModuleContext, cmd *android.RuleBui  	}  } -var javaApiContributionTag = dependencyTag{name: "java-api-contribution"} +// This method extracts the stub java files from the srcjar file provided from dep_api_srcs module +// and replaces the java stubs generated by invoking metalava in this module. +// This method is used because metalava can generate compilable from-text stubs only when +// the codebase encompasses all classes listed in the input API text file, but a class can extend +// a class that is not within the same API domain. +func (al *ApiLibrary) extractApiSrcs(ctx android.ModuleContext, rule *android.RuleBuilder, stubsDir android.OptionalPath, depApiSrcsSrcJar android.Path) { +	generatedStubsList := android.PathForModuleOut(ctx, "metalava", "sources.txt") +	unzippedSrcJarDir := android.PathForModuleOut(ctx, "metalava", "unzipDir") + +	rule.Command(). +		BuiltTool("list_files"). +		Text(stubsDir.String()). +		FlagWithOutput("--out ", generatedStubsList). +		FlagWithArg("--extensions ", ".java"). +		FlagWithArg("--root ", unzippedSrcJarDir.String()) + +	rule.Command(). +		Text("unzip"). +		Flag("-q"). +		Input(depApiSrcsSrcJar). +		FlagWithArg("-d ", unzippedSrcJarDir.String()) + +	rule.Command(). +		BuiltTool("soong_zip"). +		Flag("-srcjar"). +		Flag("-write_if_changed"). +		FlagWithArg("-C ", unzippedSrcJarDir.String()). +		FlagWithInput("-l ", generatedStubsList). +		FlagWithOutput("-o ", al.stubsSrcJar) +}  func (al *ApiLibrary) DepsMutator(ctx android.BottomUpMutatorContext) {  	apiContributions := al.properties.Api_contributions @@ -1734,6 +1779,9 @@ func (al *ApiLibrary) DepsMutator(ctx android.BottomUpMutatorContext) {  	}  	ctx.AddVariationDependencies(nil, libTag, al.properties.Libs...)  	ctx.AddVariationDependencies(nil, staticLibTag, al.properties.Static_libs...) +	if al.properties.Dep_api_srcs != nil { +		ctx.AddVariationDependencies(nil, depApiSrcsTag, String(al.properties.Dep_api_srcs)) +	}  }  func (al *ApiLibrary) GenerateAndroidBuildActions(ctx android.ModuleContext) { @@ -1754,6 +1802,7 @@ func (al *ApiLibrary) GenerateAndroidBuildActions(ctx android.ModuleContext) {  	var srcFiles android.Paths  	var classPaths android.Paths  	var staticLibs android.Paths +	var depApiSrcsStubsSrcJar android.Path  	ctx.VisitDirectDeps(func(dep android.Module) {  		tag := ctx.OtherModuleDependencyTag(dep)  		switch tag { @@ -1770,6 +1819,10 @@ func (al *ApiLibrary) GenerateAndroidBuildActions(ctx android.ModuleContext) {  		case staticLibTag:  			provider := ctx.OtherModuleProvider(dep, JavaInfoProvider).(JavaInfo)  			staticLibs = append(staticLibs, provider.HeaderJars...) +		case depApiSrcsTag: +			provider := ctx.OtherModuleProvider(dep, JavaApiLibraryDepsProvider).(JavaApiLibraryDepsInfo) +			classPaths = append(classPaths, provider.StubsJar) +			depApiSrcsStubsSrcJar = provider.StubsSrcJar  		}  	}) @@ -1780,21 +1833,31 @@ func (al *ApiLibrary) GenerateAndroidBuildActions(ctx android.ModuleContext) {  		srcFiles = append(srcFiles, android.MaybeExistentPathForSource(ctx, ctx.ModuleDir(), api))  	} +	if srcFiles == nil { +		ctx.ModuleErrorf("Error: %s has an empty api file.", ctx.ModuleName()) +	} +  	cmd := metalavaStubCmd(ctx, rule, srcFiles, homeDir)  	al.stubsFlags(ctx, cmd, stubsDir)  	al.stubsSrcJar = android.PathForModuleOut(ctx, "metalava", ctx.ModuleName()+"-"+"stubs.srcjar") -	rule.Command(). -		BuiltTool("soong_zip"). -		Flag("-write_if_changed"). -		Flag("-jar"). -		FlagWithOutput("-o ", al.stubsSrcJar). -		FlagWithArg("-C ", stubsDir.String()). -		FlagWithArg("-D ", stubsDir.String()) + +	if depApiSrcsStubsSrcJar != nil { +		al.extractApiSrcs(ctx, rule, stubsDir, depApiSrcsStubsSrcJar) +	} else { +		rule.Command(). +			BuiltTool("soong_zip"). +			Flag("-write_if_changed"). +			Flag("-jar"). +			FlagWithOutput("-o ", al.stubsSrcJar). +			FlagWithArg("-C ", stubsDir.String()). +			FlagWithArg("-D ", stubsDir.String()) +	}  	rule.Build("metalava", "metalava merged") -	compiledStubs := android.PathForModuleOut(ctx, ctx.ModuleName(), "stubs.jar") + +	al.stubsJarWithoutStaticLibs = android.PathForModuleOut(ctx, ctx.ModuleName(), "stubs.jar")  	al.stubsJar = android.PathForModuleOut(ctx, ctx.ModuleName(), fmt.Sprintf("%s.jar", ctx.ModuleName()))  	var flags javaBuilderFlags @@ -1802,14 +1865,14 @@ func (al *ApiLibrary) GenerateAndroidBuildActions(ctx android.ModuleContext) {  	flags.javacFlags = strings.Join(al.properties.Javacflags, " ")  	flags.classpath = classpath(classPaths) -	TransformJavaToClasses(ctx, compiledStubs, 0, android.Paths{}, +	TransformJavaToClasses(ctx, al.stubsJarWithoutStaticLibs, 0, android.Paths{},  		android.Paths{al.stubsSrcJar}, flags, android.Paths{})  	builder := android.NewRuleBuilder(pctx, ctx)  	builder.Command().  		BuiltTool("merge_zips").  		Output(al.stubsJar). -		Inputs(android.Paths{compiledStubs}). +		Inputs(android.Paths{al.stubsJarWithoutStaticLibs}).  		Inputs(staticLibs)  	builder.Build("merge_zips", "merge jar files") @@ -1835,6 +1898,11 @@ func (al *ApiLibrary) GenerateAndroidBuildActions(ctx android.ModuleContext) {  		ImplementationJars:             android.PathsIfNonNil(al.stubsJar),  		AidlIncludeDirs:                android.Paths{},  	}) + +	ctx.SetProvider(JavaApiLibraryDepsProvider, JavaApiLibraryDepsInfo{ +		StubsJar:    al.stubsJar, +		StubsSrcJar: al.stubsSrcJar, +	})  }  func (al *ApiLibrary) DexJarBuildPath() OptionalDexJarPath { @@ -2772,7 +2840,7 @@ func (m *Library) convertLibraryAttrsBp2Build(ctx android.TopDownMutatorContext)  			ctx.CreateBazelTargetModule(  				bazel.BazelTargetModuleProperties{  					Rule_class:        "aidl_library", -					Bzl_load_location: "//build/bazel/rules/aidl:library.bzl", +					Bzl_load_location: "//build/bazel/rules/aidl:aidl_library.bzl",  				},  				android.CommonAttributes{Name: aidlLibName},  				&aidlLibraryAttributes{ @@ -2787,7 +2855,7 @@ func (m *Library) convertLibraryAttrsBp2Build(ctx android.TopDownMutatorContext)  		ctx.CreateBazelTargetModule(  			bazel.BazelTargetModuleProperties{  				Rule_class:        "java_aidl_library", -				Bzl_load_location: "//build/bazel/rules/java:aidl_library.bzl", +				Bzl_load_location: "//build/bazel/rules/java:java_aidl_library.bzl",  			},  			android.CommonAttributes{Name: javaAidlLibName},  			&javaAidlLibraryAttributes{ |