diff options
Diffstat (limited to 'java/java.go')
| -rw-r--r-- | java/java.go | 71 | 
1 files changed, 43 insertions, 28 deletions
| diff --git a/java/java.go b/java/java.go index be1ad874f..83e9fe1cb 100644 --- a/java/java.go +++ b/java/java.go @@ -21,7 +21,6 @@ package java  import (  	"fmt"  	"path/filepath" -	"strings"  	"github.com/google/blueprint"  	"github.com/google/blueprint/proptools" @@ -581,6 +580,10 @@ type librarySdkMemberProperties struct {  	JarToExport     android.Path `android:"arch_variant"`  	AidlIncludeDirs android.Paths + +	// The list of permitted packages that need to be passed to the prebuilts as they are used to +	// create the updatable-bcp-packages.txt file. +	PermittedPackages []string  }  func (p *librarySdkMemberProperties) PopulateFromVariant(ctx android.SdkMemberContext, variant android.Module) { @@ -589,6 +592,8 @@ func (p *librarySdkMemberProperties) PopulateFromVariant(ctx android.SdkMemberCo  	p.JarToExport = ctx.MemberType().(*librarySdkMemberType).jarToExportGetter(ctx, j)  	p.AidlIncludeDirs = j.AidlIncludeDirs() + +	p.PermittedPackages = j.PermittedPackagesForUpdatableBootJars()  }  func (p *librarySdkMemberProperties) AddToPropertySet(ctx android.SdkMemberContext, propertySet android.BpPropertySet) { @@ -607,6 +612,10 @@ func (p *librarySdkMemberProperties) AddToPropertySet(ctx android.SdkMemberConte  		propertySet.AddProperty("jars", []string{snapshotRelativeJavaLibPath})  	} +	if len(p.PermittedPackages) > 0 { +		propertySet.AddProperty("permitted_packages", p.PermittedPackages) +	} +  	// Do not copy anything else to the snapshot.  	if memberType.onlyCopyJarToSnapshot {  		return @@ -1127,6 +1136,10 @@ type ImportProperties struct {  	Installable *bool +	// If not empty, classes are restricted to the specified packages and their sub-packages. +	// This information is used to generate the updatable-bcp-packages.txt file. +	Permitted_packages []string +  	// List of shared java libs that this module has dependencies to  	Libs []string @@ -1166,7 +1179,8 @@ type Import struct {  	properties ImportProperties  	// output file containing classes.dex and resources -	dexJarFile android.Path +	dexJarFile        android.Path +	dexJarInstallFile android.Path  	combinedClasspathFile android.Path  	classLoaderContexts   dexpreopt.ClassLoaderContextMap @@ -1178,6 +1192,12 @@ type Import struct {  	minSdkVersion android.SdkSpec  } +var _ PermittedPackagesForUpdatableBootJars = (*Import)(nil) + +func (j *Import) PermittedPackagesForUpdatableBootJars() []string { +	return j.properties.Permitted_packages +} +  func (j *Import) SdkVersion(ctx android.EarlyModuleContext) android.SdkSpec {  	return android.SdkSpecFrom(ctx, String(j.properties.Sdk_version))  } @@ -1311,6 +1331,7 @@ func (j *Import) GenerateAndroidBuildActions(ctx android.ModuleContext) {  			di := ctx.OtherModuleProvider(deapexerModule, android.DeapexerProvider).(android.DeapexerInfo)  			if dexOutputPath := di.PrebuiltExportPath(apexRootRelativePathToJavaLib(j.BaseModuleName())); dexOutputPath != nil {  				j.dexJarFile = dexOutputPath +				j.dexJarInstallFile = android.PathForModuleInPartitionInstall(ctx, "apex", ai.ApexVariationName, apexRootRelativePathToJavaLib(j.BaseModuleName()))  				// Initialize the hiddenapi structure.  				j.initHiddenAPI(ctx, dexOutputPath, outputFile, nil) @@ -1351,6 +1372,7 @@ func (j *Import) GenerateAndroidBuildActions(ctx android.ModuleContext) {  			dexOutputFile = j.hiddenAPIEncodeDex(ctx, dexOutputFile)  			j.dexJarFile = dexOutputFile +			j.dexJarInstallFile = android.PathForModuleInstall(ctx, "framework", jarName)  		}  	} @@ -1392,7 +1414,7 @@ func (j *Import) DexJarBuildPath() android.Path {  }  func (j *Import) DexJarInstallPath() android.Path { -	return nil +	return j.dexJarInstallFile  }  func (j *Import) ClassLoaderContexts() dexpreopt.ClassLoaderContextMap { @@ -1462,11 +1484,7 @@ func (j *Import) IDECustomizedModuleName() string {  	// TODO(b/113562217): Extract the base module name from the Import name, often the Import name  	// has a prefix "prebuilt_". Remove the prefix explicitly if needed until we find a better  	// solution to get the Import name. -	name := j.Name() -	if strings.HasPrefix(name, removedPrefix) { -		name = strings.TrimPrefix(name, removedPrefix) -	} -	return name +	return android.RemoveOptionalPrebuiltPrefix(j.Name())  }  var _ android.PrebuiltInterface = (*Import)(nil) @@ -1768,22 +1786,16 @@ func addCLCFromDep(ctx android.ModuleContext, depModule android.Module,  		return  	} -	// Find out if the dependency is either an SDK library or an ordinary library that is disguised -	// as an SDK library by the means of `provides_uses_lib` property. If yes, the library is itself -	// a <uses-library> and should be added as a node in the CLC tree, and its CLC should be added -	// as subtree of that node. Otherwise the library is not a <uses_library> and should not be -	// added to CLC, but the transitive <uses-library> dependencies from its CLC should be added to -	// the current CLC. -	var implicitSdkLib *string -	comp, isComp := depModule.(SdkLibraryComponentDependency) -	if isComp { -		implicitSdkLib = comp.OptionalImplicitSdkLibrary() -		// OptionalImplicitSdkLibrary() may be nil so need to fall through to ProvidesUsesLib(). -	} -	if implicitSdkLib == nil { -		if ulib, ok := depModule.(ProvidesUsesLib); ok { -			implicitSdkLib = ulib.ProvidesUsesLib() -		} +	depName := android.RemoveOptionalPrebuiltPrefix(ctx.OtherModuleName(depModule)) + +	var sdkLib *string +	if lib, ok := depModule.(SdkLibraryDependency); ok && lib.sharedLibrary() { +		// A shared SDK library. This should be added as a top-level CLC element. +		sdkLib = &depName +	} else if ulib, ok := depModule.(ProvidesUsesLib); ok { +		// A non-SDK library disguised as an SDK library by the means of `provides_uses_lib` +		// property. This should be handled in the same way as a shared SDK library. +		sdkLib = ulib.ProvidesUsesLib()  	}  	depTag := ctx.OtherModuleDependencyTag(depModule) @@ -1793,7 +1805,7 @@ func addCLCFromDep(ctx android.ModuleContext, depModule android.Module,  		// Propagate <uses-library> through static library dependencies, unless it is a component  		// library (such as stubs). Component libraries have a dependency on their SDK library,  		// which should not be pulled just because of a static component library. -		if implicitSdkLib != nil { +		if sdkLib != nil {  			return  		}  	} else { @@ -1801,11 +1813,14 @@ func addCLCFromDep(ctx android.ModuleContext, depModule android.Module,  		return  	} -	if implicitSdkLib != nil { -		clcMap.AddContext(ctx, dexpreopt.AnySdkVersion, *implicitSdkLib, +	// If this is an SDK (or SDK-like) library, then it should be added as a node in the CLC tree, +	// and its CLC should be added as subtree of that node. Otherwise the library is not a +	// <uses_library> and should not be added to CLC, but the transitive <uses-library> dependencies +	// from its CLC should be added to the current CLC. +	if sdkLib != nil { +		clcMap.AddContext(ctx, dexpreopt.AnySdkVersion, *sdkLib,  			dep.DexJarBuildPath(), dep.DexJarInstallPath(), dep.ClassLoaderContexts())  	} else { -		depName := ctx.OtherModuleName(depModule)  		clcMap.AddContextMap(dep.ClassLoaderContexts(), depName)  	}  } |