Support using java_sdk_library components in stub_libs
Previously, if a bootclasspath_fragment had both a java_sdk_library module and one of its components in stub_libs properties they would be treated as separate modules instead of simply different APIs from the same module. That would result in them both providing stub dex jars to "hiddenapi list" which would fail because it found duplicate definitions of the same class. e.g. Specifying something like this: api: { stub_libs: [ "art.module.public.api", ], }, core_platform_api: { stub_libs: [ "art.module.public.api.stubs.module_lib", ], }, would cause "hiddenapi list" to fail because it would have been passed paths to two dex jars (actually the same dex jar but that does not matter) each of which defined the same class, e.g. java.lang.Object. This change treats the "art.module.public.api.stubs.module_lib" and "art.module.public.api" modules as being the same for the purposes of hidden API processing. Bug: 192446466 Test: m nothing Change-Id: I9de96337f64f26e24cff040d4bbed9eecc67b1ed
This commit is contained in:
@@ -675,10 +675,13 @@ func (c *commonToSdkLibraryAndImport) initCommonAfterDefaultsApplied(ctx android
|
||||
return false
|
||||
}
|
||||
|
||||
namePtr := proptools.StringPtr(c.module.BaseModuleName())
|
||||
c.sdkLibraryComponentProperties.SdkLibraryName = namePtr
|
||||
|
||||
// Only track this sdk library if this can be used as a shared library.
|
||||
if c.sharedLibrary() {
|
||||
// Use the name specified in the module definition as the owner.
|
||||
c.sdkLibraryComponentProperties.SdkLibraryToImplicitlyTrack = proptools.StringPtr(c.module.BaseModuleName())
|
||||
c.sdkLibraryComponentProperties.SdkLibraryToImplicitlyTrack = namePtr
|
||||
}
|
||||
|
||||
return true
|
||||
@@ -922,15 +925,19 @@ func (c *commonToSdkLibraryAndImport) SdkRemovedTxtFile(ctx android.BaseModuleCo
|
||||
|
||||
func (c *commonToSdkLibraryAndImport) sdkComponentPropertiesForChildLibrary() interface{} {
|
||||
componentProps := &struct {
|
||||
SdkLibraryName *string
|
||||
SdkLibraryToImplicitlyTrack *string
|
||||
}{}
|
||||
|
||||
namePtr := proptools.StringPtr(c.module.BaseModuleName())
|
||||
componentProps.SdkLibraryName = namePtr
|
||||
|
||||
if c.sharedLibrary() {
|
||||
// Mark the stubs library as being components of this java_sdk_library so that
|
||||
// any app that includes code which depends (directly or indirectly) on the stubs
|
||||
// library will have the appropriate <uses-library> invocation inserted into its
|
||||
// manifest if necessary.
|
||||
componentProps.SdkLibraryToImplicitlyTrack = proptools.StringPtr(c.module.BaseModuleName())
|
||||
componentProps.SdkLibraryToImplicitlyTrack = namePtr
|
||||
}
|
||||
|
||||
return componentProps
|
||||
@@ -949,6 +956,8 @@ func (c *commonToSdkLibraryAndImport) stubLibrariesCompiledForDex() bool {
|
||||
|
||||
// Properties related to the use of a module as an component of a java_sdk_library.
|
||||
type SdkLibraryComponentProperties struct {
|
||||
// The name of the java_sdk_library/_import module.
|
||||
SdkLibraryName *string `blueprint:"mutated"`
|
||||
|
||||
// The name of the java_sdk_library/_import to add to a <uses-library> entry
|
||||
// in the AndroidManifest.xml of any Android app that includes code that references
|
||||
@@ -966,6 +975,11 @@ func (e *EmbeddableSdkLibraryComponent) initSdkLibraryComponent(module android.M
|
||||
module.AddProperties(&e.sdkLibraryComponentProperties)
|
||||
}
|
||||
|
||||
// to satisfy SdkLibraryComponentDependency
|
||||
func (e *EmbeddableSdkLibraryComponent) SdkLibraryName() *string {
|
||||
return e.sdkLibraryComponentProperties.SdkLibraryName
|
||||
}
|
||||
|
||||
// to satisfy SdkLibraryComponentDependency
|
||||
func (e *EmbeddableSdkLibraryComponent) OptionalImplicitSdkLibrary() *string {
|
||||
return e.sdkLibraryComponentProperties.SdkLibraryToImplicitlyTrack
|
||||
@@ -982,6 +996,9 @@ func (e *EmbeddableSdkLibraryComponent) OptionalSdkLibraryImplementation() *stri
|
||||
type SdkLibraryComponentDependency interface {
|
||||
UsesLibraryDependency
|
||||
|
||||
// SdkLibraryName returns the name of the java_sdk_library/_import module.
|
||||
SdkLibraryName() *string
|
||||
|
||||
// The optional name of the sdk library that should be implicitly added to the
|
||||
// AndroidManifest of an app that contains code which references the sdk library.
|
||||
//
|
||||
|
Reference in New Issue
Block a user