2015-03-31 02:20:39 +02:00
|
|
|
// Copyright 2015 Google Inc. All rights reserved.
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
|
|
|
package java
|
|
|
|
|
|
|
|
// This file contains the module types for compiling Java for Android, and converts the properties
|
2017-06-23 01:51:17 +02:00
|
|
|
// into the flags and filenames necessary to pass to the Module. The final creation of the rules
|
2015-03-31 02:20:39 +02:00
|
|
|
// is handled in builder.go
|
|
|
|
|
|
|
|
import (
|
2018-03-26 23:42:44 +02:00
|
|
|
"fmt"
|
2017-09-19 02:41:52 +02:00
|
|
|
"path/filepath"
|
2021-12-10 12:14:59 +01:00
|
|
|
"strings"
|
2015-03-31 02:20:39 +02:00
|
|
|
|
2021-12-10 12:14:59 +01:00
|
|
|
"android/soong/bazel"
|
2022-01-06 21:03:51 +01:00
|
|
|
|
2015-03-31 02:20:39 +02:00
|
|
|
"github.com/google/blueprint"
|
2017-08-30 01:02:06 +02:00
|
|
|
"github.com/google/blueprint/proptools"
|
2015-03-31 02:20:39 +02:00
|
|
|
|
2016-05-19 00:37:25 +02:00
|
|
|
"android/soong/android"
|
2021-01-26 20:01:43 +01:00
|
|
|
"android/soong/cc"
|
2020-08-14 18:32:16 +02:00
|
|
|
"android/soong/dexpreopt"
|
2017-06-23 02:20:19 +02:00
|
|
|
"android/soong/java/config"
|
2018-08-08 01:49:25 +02:00
|
|
|
"android/soong/tradefed"
|
2015-03-31 02:20:39 +02:00
|
|
|
)
|
|
|
|
|
2015-06-17 23:20:06 +02:00
|
|
|
func init() {
|
2021-03-31 00:34:32 +02:00
|
|
|
registerJavaBuildComponents(android.InitRegistrationContext)
|
2019-12-13 12:22:16 +01:00
|
|
|
|
2021-03-11 02:02:43 +01:00
|
|
|
RegisterJavaSdkMemberTypes()
|
|
|
|
}
|
|
|
|
|
2021-03-31 00:34:32 +02:00
|
|
|
func registerJavaBuildComponents(ctx android.RegistrationContext) {
|
2021-03-11 02:02:43 +01:00
|
|
|
ctx.RegisterModuleType("java_defaults", DefaultsFactory)
|
|
|
|
|
|
|
|
ctx.RegisterModuleType("java_library", LibraryFactory)
|
|
|
|
ctx.RegisterModuleType("java_library_static", LibraryStaticFactory)
|
|
|
|
ctx.RegisterModuleType("java_library_host", LibraryHostFactory)
|
|
|
|
ctx.RegisterModuleType("java_binary", BinaryFactory)
|
|
|
|
ctx.RegisterModuleType("java_binary_host", BinaryHostFactory)
|
|
|
|
ctx.RegisterModuleType("java_test", TestFactory)
|
|
|
|
ctx.RegisterModuleType("java_test_helper_library", TestHelperLibraryFactory)
|
|
|
|
ctx.RegisterModuleType("java_test_host", TestHostFactory)
|
|
|
|
ctx.RegisterModuleType("java_test_import", JavaTestImportFactory)
|
|
|
|
ctx.RegisterModuleType("java_import", ImportFactory)
|
|
|
|
ctx.RegisterModuleType("java_import_host", ImportFactoryHost)
|
|
|
|
ctx.RegisterModuleType("java_device_for_host", DeviceForHostFactory)
|
|
|
|
ctx.RegisterModuleType("java_host_for_device", HostForDeviceFactory)
|
|
|
|
ctx.RegisterModuleType("dex_import", DexImportFactory)
|
|
|
|
|
2021-05-13 03:38:35 +02:00
|
|
|
// This mutator registers dependencies on dex2oat for modules that should be
|
|
|
|
// dexpreopted. This is done late when the final variants have been
|
|
|
|
// established, to not get the dependencies split into the wrong variants and
|
|
|
|
// to support the checks in dexpreoptDisabled().
|
2021-03-11 02:02:43 +01:00
|
|
|
ctx.FinalDepsMutators(func(ctx android.RegisterMutatorsContext) {
|
|
|
|
ctx.BottomUp("dexpreopt_tool_deps", dexpreoptToolDepsMutator).Parallel()
|
|
|
|
})
|
|
|
|
|
|
|
|
ctx.RegisterSingletonType("logtags", LogtagsSingleton)
|
|
|
|
ctx.RegisterSingletonType("kythe_java_extract", kytheExtractJavaFactory)
|
|
|
|
}
|
|
|
|
|
|
|
|
func RegisterJavaSdkMemberTypes() {
|
2019-12-13 12:22:16 +01:00
|
|
|
// Register sdk member types.
|
2020-01-13 22:03:22 +01:00
|
|
|
android.RegisterSdkMemberType(javaHeaderLibsSdkMemberType)
|
2021-04-23 20:43:28 +02:00
|
|
|
android.RegisterSdkMemberType(javaLibsSdkMemberType)
|
|
|
|
android.RegisterSdkMemberType(javaBootLibsSdkMemberType)
|
2021-09-26 10:58:02 +02:00
|
|
|
android.RegisterSdkMemberType(javaSystemserverLibsSdkMemberType)
|
2021-04-23 20:43:28 +02:00
|
|
|
android.RegisterSdkMemberType(javaTestSdkMemberType)
|
|
|
|
}
|
|
|
|
|
|
|
|
var (
|
|
|
|
// Supports adding java header libraries to module_exports and sdk.
|
|
|
|
javaHeaderLibsSdkMemberType = &librarySdkMemberType{
|
|
|
|
android.SdkMemberTypeBase{
|
|
|
|
PropertyName: "java_header_libs",
|
|
|
|
SupportsSdk: true,
|
|
|
|
},
|
|
|
|
func(_ android.SdkMemberContext, j *Library) android.Path {
|
|
|
|
headerJars := j.HeaderJars()
|
|
|
|
if len(headerJars) != 1 {
|
|
|
|
panic(fmt.Errorf("there must be only one header jar from %q", j.Name()))
|
|
|
|
}
|
|
|
|
|
|
|
|
return headerJars[0]
|
|
|
|
},
|
|
|
|
sdkSnapshotFilePathForJar,
|
|
|
|
copyEverythingToSnapshot,
|
|
|
|
}
|
2019-12-13 12:22:16 +01:00
|
|
|
|
2021-02-04 12:15:34 +01:00
|
|
|
// Export implementation classes jar as part of the sdk.
|
2021-04-23 20:43:28 +02:00
|
|
|
exportImplementationClassesJar = func(_ android.SdkMemberContext, j *Library) android.Path {
|
2021-02-04 12:15:34 +01:00
|
|
|
implementationJars := j.ImplementationAndResourcesJars()
|
|
|
|
if len(implementationJars) != 1 {
|
|
|
|
panic(fmt.Errorf("there must be only one implementation jar from %q", j.Name()))
|
|
|
|
}
|
|
|
|
return implementationJars[0]
|
|
|
|
}
|
|
|
|
|
2021-04-23 20:43:28 +02:00
|
|
|
// Supports adding java implementation libraries to module_exports but not sdk.
|
|
|
|
javaLibsSdkMemberType = &librarySdkMemberType{
|
2020-02-28 15:39:53 +01:00
|
|
|
android.SdkMemberTypeBase{
|
|
|
|
PropertyName: "java_libs",
|
|
|
|
},
|
2021-02-04 12:15:34 +01:00
|
|
|
exportImplementationClassesJar,
|
2020-12-08 18:48:25 +01:00
|
|
|
sdkSnapshotFilePathForJar,
|
|
|
|
copyEverythingToSnapshot,
|
2021-04-23 20:43:28 +02:00
|
|
|
}
|
2019-12-03 19:06:47 +01:00
|
|
|
|
2022-07-15 15:12:35 +02:00
|
|
|
snapshotRequiresImplementationJar = func(ctx android.SdkMemberContext) bool {
|
|
|
|
// In the S build the build will break if updatable-media does not provide a full implementation
|
|
|
|
// jar. That issue was fixed in Tiramisu by b/229932396.
|
|
|
|
if ctx.IsTargetBuildBeforeTiramisu() && ctx.Name() == "updatable-media" {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
2021-04-23 20:43:28 +02:00
|
|
|
// Supports adding java boot libraries to module_exports and sdk.
|
2020-12-08 18:48:25 +01:00
|
|
|
//
|
|
|
|
// The build has some implicit dependencies (via the boot jars configuration) on a number of
|
|
|
|
// modules, e.g. core-oj, apache-xml, that are part of the java boot class path and which are
|
|
|
|
// provided by mainline modules (e.g. art, conscrypt, runtime-i18n) but which are not otherwise
|
|
|
|
// used outside those mainline modules.
|
|
|
|
//
|
|
|
|
// As they are not needed outside the mainline modules adding them to the sdk/module-exports as
|
|
|
|
// either java_libs, or java_header_libs would end up exporting more information than was strictly
|
|
|
|
// necessary. The java_boot_libs property to allow those modules to be exported as part of the
|
|
|
|
// sdk/module_exports without exposing any unnecessary information.
|
2021-04-23 20:43:28 +02:00
|
|
|
javaBootLibsSdkMemberType = &librarySdkMemberType{
|
2020-12-08 18:48:25 +01:00
|
|
|
android.SdkMemberTypeBase{
|
|
|
|
PropertyName: "java_boot_libs",
|
|
|
|
SupportsSdk: true,
|
|
|
|
},
|
2021-07-15 13:42:44 +02:00
|
|
|
func(ctx android.SdkMemberContext, j *Library) android.Path {
|
2022-07-15 15:12:35 +02:00
|
|
|
if snapshotRequiresImplementationJar(ctx) {
|
|
|
|
return exportImplementationClassesJar(ctx, j)
|
|
|
|
}
|
|
|
|
|
2021-07-15 13:42:44 +02:00
|
|
|
// Java boot libs are only provided in the SDK to provide access to their dex implementation
|
|
|
|
// jar for use by dexpreopting and boot jars package check. They do not need to provide an
|
|
|
|
// actual implementation jar but the java_import will need a file that exists so just copy an
|
|
|
|
// empty file. Any attempt to use that file as a jar will cause a build error.
|
|
|
|
return ctx.SnapshotBuilder().EmptyFile()
|
|
|
|
},
|
2022-07-15 15:12:35 +02:00
|
|
|
func(ctx android.SdkMemberContext, osPrefix, name string) string {
|
|
|
|
if snapshotRequiresImplementationJar(ctx) {
|
|
|
|
return sdkSnapshotFilePathForJar(ctx, osPrefix, name)
|
|
|
|
}
|
|
|
|
|
2021-07-15 13:42:44 +02:00
|
|
|
// Create a special name for the implementation jar to try and provide some useful information
|
|
|
|
// to a developer that attempts to compile against this.
|
|
|
|
// TODO(b/175714559): Provide a proper error message in Soong not ninja.
|
|
|
|
return filepath.Join(osPrefix, "java_boot_libs", "snapshot", "jars", "are", "invalid", name+jarFileSuffix)
|
|
|
|
},
|
2020-12-08 18:48:25 +01:00
|
|
|
onlyCopyJarToSnapshot,
|
2021-04-23 20:43:28 +02:00
|
|
|
}
|
2020-12-08 18:48:25 +01:00
|
|
|
|
2021-09-26 10:58:02 +02:00
|
|
|
// Supports adding java systemserver libraries to module_exports and sdk.
|
|
|
|
//
|
|
|
|
// The build has some implicit dependencies (via the systemserver jars configuration) on a number
|
|
|
|
// of modules that are part of the java systemserver classpath and which are provided by mainline
|
|
|
|
// modules but which are not otherwise used outside those mainline modules.
|
|
|
|
//
|
|
|
|
// As they are not needed outside the mainline modules adding them to the sdk/module-exports as
|
|
|
|
// either java_libs, or java_header_libs would end up exporting more information than was strictly
|
|
|
|
// necessary. The java_systemserver_libs property to allow those modules to be exported as part of
|
|
|
|
// the sdk/module_exports without exposing any unnecessary information.
|
|
|
|
javaSystemserverLibsSdkMemberType = &librarySdkMemberType{
|
|
|
|
android.SdkMemberTypeBase{
|
|
|
|
PropertyName: "java_systemserver_libs",
|
|
|
|
SupportsSdk: true,
|
2022-07-01 17:56:06 +02:00
|
|
|
|
|
|
|
// This was only added in Tiramisu.
|
|
|
|
SupportedBuildReleaseSpecification: "Tiramisu+",
|
2021-09-26 10:58:02 +02:00
|
|
|
},
|
|
|
|
func(ctx android.SdkMemberContext, j *Library) android.Path {
|
|
|
|
// Java systemserver libs are only provided in the SDK to provide access to their dex
|
|
|
|
// implementation jar for use by dexpreopting. They do not need to provide an actual
|
|
|
|
// implementation jar but the java_import will need a file that exists so just copy an empty
|
|
|
|
// file. Any attempt to use that file as a jar will cause a build error.
|
|
|
|
return ctx.SnapshotBuilder().EmptyFile()
|
|
|
|
},
|
2022-07-15 15:12:35 +02:00
|
|
|
func(_ android.SdkMemberContext, osPrefix, name string) string {
|
2021-09-26 10:58:02 +02:00
|
|
|
// Create a special name for the implementation jar to try and provide some useful information
|
|
|
|
// to a developer that attempts to compile against this.
|
|
|
|
// TODO(b/175714559): Provide a proper error message in Soong not ninja.
|
|
|
|
return filepath.Join(osPrefix, "java_systemserver_libs", "snapshot", "jars", "are", "invalid", name+jarFileSuffix)
|
|
|
|
},
|
|
|
|
onlyCopyJarToSnapshot,
|
|
|
|
}
|
|
|
|
|
2021-04-23 20:43:28 +02:00
|
|
|
// Supports adding java test libraries to module_exports but not sdk.
|
|
|
|
javaTestSdkMemberType = &testSdkMemberType{
|
2019-12-03 19:06:47 +01:00
|
|
|
SdkMemberTypeBase: android.SdkMemberTypeBase{
|
|
|
|
PropertyName: "java_tests",
|
|
|
|
},
|
2021-04-23 20:43:28 +02:00
|
|
|
}
|
|
|
|
)
|
2019-07-11 08:54:27 +02:00
|
|
|
|
2021-02-01 22:59:03 +01:00
|
|
|
// JavaInfo contains information about a java module for use by modules that depend on it.
|
|
|
|
type JavaInfo struct {
|
|
|
|
// HeaderJars is a list of jars that can be passed as the javac classpath in order to link
|
|
|
|
// against this module. If empty, ImplementationJars should be used instead.
|
|
|
|
HeaderJars android.Paths
|
|
|
|
|
|
|
|
// ImplementationAndResourceJars is a list of jars that contain the implementations of classes
|
|
|
|
// in the module as well as any resources included in the module.
|
|
|
|
ImplementationAndResourcesJars android.Paths
|
|
|
|
|
|
|
|
// ImplementationJars is a list of jars that contain the implementations of classes in the
|
|
|
|
//module.
|
|
|
|
ImplementationJars android.Paths
|
|
|
|
|
|
|
|
// ResourceJars is a list of jars that contain the resources included in the module.
|
|
|
|
ResourceJars android.Paths
|
|
|
|
|
|
|
|
// AidlIncludeDirs is a list of directories that should be passed to the aidl tool when
|
|
|
|
// depending on this module.
|
|
|
|
AidlIncludeDirs android.Paths
|
|
|
|
|
|
|
|
// SrcJarArgs is a list of arguments to pass to soong_zip to package the sources of this
|
|
|
|
// module.
|
2021-03-17 23:56:23 +01:00
|
|
|
SrcJarArgs []string
|
2020-06-03 05:09:13 +02:00
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
// SrcJarDeps is a list of paths to depend on when packaging the sources of this module.
|
|
|
|
SrcJarDeps android.Paths
|
|
|
|
|
|
|
|
// ExportedPlugins is a list of paths that should be used as annotation processors for any
|
|
|
|
// module that depends on this module.
|
|
|
|
ExportedPlugins android.Paths
|
2020-06-03 05:09:13 +02:00
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
// ExportedPluginClasses is a list of classes that should be run as annotation processors for
|
|
|
|
// any module that depends on this module.
|
|
|
|
ExportedPluginClasses []string
|
2018-08-15 20:19:12 +02:00
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
// ExportedPluginDisableTurbine is true if this module's annotation processors generate APIs,
|
|
|
|
// requiring disbling turbine for any modules that depend on it.
|
|
|
|
ExportedPluginDisableTurbine bool
|
2021-02-01 22:59:03 +01:00
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
// JacocoReportClassesFile is the path to a jar containing uninstrumented classes that will be
|
|
|
|
// instrumented by jacoco.
|
|
|
|
JacocoReportClassesFile android.Path
|
2017-10-19 22:06:22 +02:00
|
|
|
}
|
2015-03-31 02:20:39 +02:00
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
var JavaInfoProvider = blueprint.NewProvider(JavaInfo{})
|
2019-09-06 01:44:18 +02:00
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
// SyspropPublicStubInfo contains info about the sysprop public stub library that corresponds to
|
|
|
|
// the sysprop implementation library.
|
|
|
|
type SyspropPublicStubInfo struct {
|
|
|
|
// JavaInfo is the JavaInfoProvider of the sysprop public stub library that corresponds to
|
|
|
|
// the sysprop implementation library.
|
|
|
|
JavaInfo JavaInfo
|
|
|
|
}
|
2019-09-06 01:44:18 +02:00
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
var SyspropPublicStubInfoProvider = blueprint.NewProvider(SyspropPublicStubInfo{})
|
2019-09-06 01:44:18 +02:00
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
// Methods that need to be implemented for a module that is added to apex java_libs property.
|
|
|
|
type ApexDependency interface {
|
|
|
|
HeaderJars() android.Paths
|
|
|
|
ImplementationAndResourcesJars() android.Paths
|
|
|
|
}
|
2019-09-06 01:44:18 +02:00
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
// Provides build path and install path to DEX jars.
|
|
|
|
type UsesLibraryDependency interface {
|
2021-09-15 04:34:04 +02:00
|
|
|
DexJarBuildPath() OptionalDexJarPath
|
2021-03-17 23:56:23 +01:00
|
|
|
DexJarInstallPath() android.Path
|
|
|
|
ClassLoaderContexts() dexpreopt.ClassLoaderContextMap
|
2019-09-06 01:44:18 +02:00
|
|
|
}
|
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
// TODO(jungjw): Move this to kythe.go once it's created.
|
|
|
|
type xref interface {
|
|
|
|
XrefJavaFiles() android.Paths
|
|
|
|
}
|
2018-08-21 17:10:29 +02:00
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
func (j *Module) XrefJavaFiles() android.Paths {
|
|
|
|
return j.kytheFiles
|
2018-08-21 17:10:29 +02:00
|
|
|
}
|
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
type dependencyTag struct {
|
|
|
|
blueprint.BaseDependencyTag
|
|
|
|
name string
|
2021-12-11 00:05:02 +01:00
|
|
|
|
|
|
|
// True if the dependency is relinked at runtime.
|
|
|
|
runtimeLinked bool
|
2022-01-12 20:13:32 +01:00
|
|
|
|
|
|
|
// True if the dependency is a toolchain, for example an annotation processor.
|
|
|
|
toolchain bool
|
2021-03-17 23:56:23 +01:00
|
|
|
}
|
2015-03-31 02:20:39 +02:00
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
// installDependencyTag is a dependency tag that is annotated to cause the installed files of the
|
|
|
|
// dependency to be installed when the parent module is installed.
|
|
|
|
type installDependencyTag struct {
|
|
|
|
blueprint.BaseDependencyTag
|
|
|
|
android.InstallAlwaysNeededDependencyTag
|
|
|
|
name string
|
|
|
|
}
|
2015-03-31 02:20:39 +02:00
|
|
|
|
2021-12-11 00:05:02 +01:00
|
|
|
func (d dependencyTag) LicenseAnnotations() []android.LicenseAnnotation {
|
|
|
|
if d.runtimeLinked {
|
|
|
|
return []android.LicenseAnnotation{android.LicenseAnnotationSharedDependency}
|
2022-01-12 20:13:32 +01:00
|
|
|
} else if d.toolchain {
|
|
|
|
return []android.LicenseAnnotation{android.LicenseAnnotationToolchain}
|
2021-12-11 00:05:02 +01:00
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
var _ android.LicenseAnnotationsDependencyTag = dependencyTag{}
|
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
type usesLibraryDependencyTag struct {
|
|
|
|
dependencyTag
|
2022-05-04 13:00:02 +02:00
|
|
|
sdkVersion int // SDK version in which the library appared as a standalone library.
|
|
|
|
optional bool // If the dependency is optional or required.
|
2021-03-17 23:56:23 +01:00
|
|
|
}
|
|
|
|
|
2022-05-04 13:00:02 +02:00
|
|
|
func makeUsesLibraryDependencyTag(sdkVersion int, optional bool) usesLibraryDependencyTag {
|
2021-03-17 23:56:23 +01:00
|
|
|
return usesLibraryDependencyTag{
|
2021-12-11 00:05:02 +01:00
|
|
|
dependencyTag: dependencyTag{
|
|
|
|
name: fmt.Sprintf("uses-library-%d", sdkVersion),
|
|
|
|
runtimeLinked: true,
|
|
|
|
},
|
|
|
|
sdkVersion: sdkVersion,
|
|
|
|
optional: optional,
|
2017-10-19 22:06:22 +02:00
|
|
|
}
|
2021-03-17 23:56:23 +01:00
|
|
|
}
|
2017-08-31 21:30:37 +02:00
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
func IsJniDepTag(depTag blueprint.DependencyTag) bool {
|
|
|
|
return depTag == jniLibTag
|
2017-10-19 22:06:22 +02:00
|
|
|
}
|
2017-08-31 21:30:37 +02:00
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
var (
|
|
|
|
dataNativeBinsTag = dependencyTag{name: "dataNativeBins"}
|
2022-01-20 22:10:28 +01:00
|
|
|
dataDeviceBinsTag = dependencyTag{name: "dataDeviceBins"}
|
2021-03-17 23:56:23 +01:00
|
|
|
staticLibTag = dependencyTag{name: "staticlib"}
|
2021-12-11 00:05:02 +01:00
|
|
|
libTag = dependencyTag{name: "javalib", runtimeLinked: true}
|
|
|
|
java9LibTag = dependencyTag{name: "java9lib", runtimeLinked: true}
|
2022-01-12 20:13:32 +01:00
|
|
|
pluginTag = dependencyTag{name: "plugin", toolchain: true}
|
|
|
|
errorpronePluginTag = dependencyTag{name: "errorprone-plugin", toolchain: true}
|
|
|
|
exportedPluginTag = dependencyTag{name: "exported-plugin", toolchain: true}
|
2021-12-11 00:05:02 +01:00
|
|
|
bootClasspathTag = dependencyTag{name: "bootclasspath", runtimeLinked: true}
|
|
|
|
systemModulesTag = dependencyTag{name: "system modules", runtimeLinked: true}
|
2021-03-17 23:56:23 +01:00
|
|
|
frameworkResTag = dependencyTag{name: "framework-res"}
|
2021-12-11 00:05:02 +01:00
|
|
|
kotlinStdlibTag = dependencyTag{name: "kotlin-stdlib", runtimeLinked: true}
|
|
|
|
kotlinAnnotationsTag = dependencyTag{name: "kotlin-annotations", runtimeLinked: true}
|
2022-01-12 20:13:32 +01:00
|
|
|
kotlinPluginTag = dependencyTag{name: "kotlin-plugin", toolchain: true}
|
2021-03-17 23:56:23 +01:00
|
|
|
proguardRaiseTag = dependencyTag{name: "proguard-raise"}
|
|
|
|
certificateTag = dependencyTag{name: "certificate"}
|
|
|
|
instrumentationForTag = dependencyTag{name: "instrumentation_for"}
|
2022-01-12 20:13:32 +01:00
|
|
|
extraLintCheckTag = dependencyTag{name: "extra-lint-check", toolchain: true}
|
2021-12-11 00:05:02 +01:00
|
|
|
jniLibTag = dependencyTag{name: "jnilib", runtimeLinked: true}
|
2021-03-17 23:56:23 +01:00
|
|
|
syspropPublicStubDepTag = dependencyTag{name: "sysprop public stub"}
|
|
|
|
jniInstallTag = installDependencyTag{name: "jni install"}
|
|
|
|
binaryInstallTag = installDependencyTag{name: "binary install"}
|
2022-05-04 13:00:02 +02:00
|
|
|
usesLibReqTag = makeUsesLibraryDependencyTag(dexpreopt.AnySdkVersion, false)
|
|
|
|
usesLibOptTag = makeUsesLibraryDependencyTag(dexpreopt.AnySdkVersion, true)
|
|
|
|
usesLibCompat28OptTag = makeUsesLibraryDependencyTag(28, true)
|
|
|
|
usesLibCompat29ReqTag = makeUsesLibraryDependencyTag(29, false)
|
|
|
|
usesLibCompat30OptTag = makeUsesLibraryDependencyTag(30, true)
|
2021-03-17 23:56:23 +01:00
|
|
|
)
|
2017-11-22 22:49:43 +01:00
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
func IsLibDepTag(depTag blueprint.DependencyTag) bool {
|
|
|
|
return depTag == libTag
|
|
|
|
}
|
2017-11-22 22:49:43 +01:00
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
func IsStaticLibDepTag(depTag blueprint.DependencyTag) bool {
|
|
|
|
return depTag == staticLibTag
|
|
|
|
}
|
2017-11-22 22:49:43 +01:00
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
type sdkDep struct {
|
|
|
|
useModule, useFiles, invalidVersion bool
|
2017-11-22 22:49:43 +01:00
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
// The modules that will be added to the bootclasspath when targeting 1.8 or lower
|
|
|
|
bootclasspath []string
|
2017-11-22 22:49:43 +01:00
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
// The default system modules to use. Will be an empty string if no system
|
|
|
|
// modules are to be used.
|
|
|
|
systemModules string
|
2017-11-22 22:49:43 +01:00
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
// The modules that will be added to the classpath regardless of the Java language level targeted
|
|
|
|
classpath []string
|
2017-10-19 22:06:22 +02:00
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
// The modules that will be added ot the classpath when targeting 1.9 or higher
|
|
|
|
// (normally these will be on the bootclasspath when targeting 1.8 or lower)
|
|
|
|
java9Classpath []string
|
2015-03-31 02:20:39 +02:00
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
frameworkResModule string
|
2019-01-31 23:12:44 +01:00
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
jars android.Paths
|
|
|
|
aidl android.OptionalPath
|
2020-06-09 15:31:19 +02:00
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
noStandardLibs, noFrameworksLibs bool
|
2018-08-16 05:40:52 +02:00
|
|
|
}
|
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
func (s sdkDep) hasStandardLibs() bool {
|
|
|
|
return !s.noStandardLibs
|
2015-04-08 22:03:43 +02:00
|
|
|
}
|
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
func (s sdkDep) hasFrameworkLibs() bool {
|
|
|
|
return !s.noStandardLibs && !s.noFrameworksLibs
|
2018-05-28 11:02:19 +02:00
|
|
|
}
|
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
type jniLib struct {
|
|
|
|
name string
|
|
|
|
path android.Path
|
|
|
|
target android.Target
|
|
|
|
coverageFile android.OptionalPath
|
|
|
|
unstrippedFile android.Path
|
2015-04-11 02:45:20 +02:00
|
|
|
}
|
|
|
|
|
2021-03-29 13:11:58 +02:00
|
|
|
func sdkDeps(ctx android.BottomUpMutatorContext, sdkContext android.SdkContext, d dexer) {
|
2021-03-17 23:56:23 +01:00
|
|
|
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)
|
2018-08-16 00:35:38 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
type deps struct {
|
2022-03-17 19:12:32 +01:00
|
|
|
// bootClasspath is the list of jars that form the boot classpath (generally the java.* and
|
|
|
|
// android.* classes) for tools that still use it. javac targeting 1.9 or higher uses
|
|
|
|
// systemModules and java9Classpath instead.
|
|
|
|
bootClasspath classpath
|
|
|
|
|
|
|
|
// classpath is the list of jars that form the classpath for javac and kotlinc rules. It
|
|
|
|
// contains header jars for all static and non-static dependencies.
|
|
|
|
classpath classpath
|
|
|
|
|
|
|
|
// dexClasspath is the list of jars that form the classpath for d8 and r8 rules. It contains
|
|
|
|
// header jars for all non-static dependencies. Static dependencies have already been
|
|
|
|
// combined into the program jar.
|
|
|
|
dexClasspath classpath
|
|
|
|
|
|
|
|
// java9Classpath is the list of jars that will be added to the classpath when targeting
|
|
|
|
// 1.9 or higher. It generally contains the android.* classes, while the java.* classes
|
|
|
|
// are provided by systemModules.
|
|
|
|
java9Classpath classpath
|
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
processorPath classpath
|
|
|
|
errorProneProcessorPath classpath
|
|
|
|
processorClasses []string
|
|
|
|
staticJars android.Paths
|
|
|
|
staticHeaderJars android.Paths
|
|
|
|
staticResourceJars android.Paths
|
|
|
|
aidlIncludeDirs android.Paths
|
|
|
|
srcs android.Paths
|
|
|
|
srcJars android.Paths
|
|
|
|
systemModules *systemModules
|
|
|
|
aidlPreprocess android.OptionalPath
|
|
|
|
kotlinStdlib android.Paths
|
|
|
|
kotlinAnnotations android.Paths
|
2021-09-17 23:11:52 +02:00
|
|
|
kotlinPlugins android.Paths
|
2018-08-16 00:35:38 +02:00
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
disableTurbine bool
|
2019-05-31 00:51:14 +02:00
|
|
|
}
|
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
func checkProducesJars(ctx android.ModuleContext, dep android.SourceFileProducer) {
|
|
|
|
for _, f := range dep.Srcs() {
|
|
|
|
if f.Ext() != ".jar" {
|
|
|
|
ctx.ModuleErrorf("genrule %q must generate files ending with .jar to be used as a libs or static_libs dependency",
|
|
|
|
ctx.OtherModuleName(dep.(blueprint.Module)))
|
|
|
|
}
|
|
|
|
}
|
2019-10-15 08:20:07 +02:00
|
|
|
}
|
|
|
|
|
2021-03-29 13:11:58 +02:00
|
|
|
func getJavaVersion(ctx android.ModuleContext, javaVersion string, sdkContext android.SdkContext) javaVersion {
|
2021-03-17 23:56:23 +01:00
|
|
|
if javaVersion != "" {
|
|
|
|
return normalizeJavaVersion(ctx, javaVersion)
|
|
|
|
} else if ctx.Device() {
|
2021-04-02 01:45:46 +02:00
|
|
|
return defaultJavaLanguageVersion(ctx, sdkContext.SdkVersion(ctx))
|
2022-05-24 13:13:50 +02:00
|
|
|
} else if ctx.Config().TargetsJava17() {
|
|
|
|
// Temporary experimental flag to be able to try and build with
|
|
|
|
// java version 17 options. The flag, if used, just sets Java
|
|
|
|
// 17 as the default version, leaving any components that
|
|
|
|
// target an older version intact.
|
|
|
|
return JAVA_VERSION_17
|
2022-01-20 16:21:51 +01:00
|
|
|
} else {
|
2022-01-23 10:01:07 +01:00
|
|
|
return JAVA_VERSION_11
|
2020-04-15 04:03:39 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
type javaVersion int
|
2019-10-29 03:23:10 +01:00
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
const (
|
|
|
|
JAVA_VERSION_UNSUPPORTED = 0
|
|
|
|
JAVA_VERSION_6 = 6
|
|
|
|
JAVA_VERSION_7 = 7
|
|
|
|
JAVA_VERSION_8 = 8
|
|
|
|
JAVA_VERSION_9 = 9
|
2021-11-26 18:26:33 +01:00
|
|
|
JAVA_VERSION_11 = 11
|
2022-05-24 13:13:50 +02:00
|
|
|
JAVA_VERSION_17 = 17
|
2021-03-17 23:56:23 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
func (v javaVersion) String() string {
|
|
|
|
switch v {
|
|
|
|
case JAVA_VERSION_6:
|
|
|
|
return "1.6"
|
|
|
|
case JAVA_VERSION_7:
|
|
|
|
return "1.7"
|
|
|
|
case JAVA_VERSION_8:
|
|
|
|
return "1.8"
|
|
|
|
case JAVA_VERSION_9:
|
|
|
|
return "1.9"
|
2021-11-26 18:26:33 +01:00
|
|
|
case JAVA_VERSION_11:
|
|
|
|
return "11"
|
2022-05-24 13:13:50 +02:00
|
|
|
case JAVA_VERSION_17:
|
|
|
|
return "17"
|
2021-03-17 23:56:23 +01:00
|
|
|
default:
|
|
|
|
return "unsupported"
|
|
|
|
}
|
2020-06-24 17:22:38 +02:00
|
|
|
}
|
|
|
|
|
Use the current java version for -jvm-target
This is a partial revert of aosp/541879.
In that cl, the kotlin jvm version was always
set to 1.8 because that's what the kotlin
complier supported at the time, but now
it supports more versions:
$ ./external/kotlinc/bin/kotlinc -jvm-target foo
error: unknown JVM target version: foo
Supported versions: 1.6, 1.8, 9, 10, 11, 12, 13, 14, 15, 16, 17
Bug: 69160377
Bug: 236431222
Test: Treehugger
Change-Id: I273e0b4d1f484013889e17c60bc1b299a3f975a1
2022-06-28 23:41:27 +02:00
|
|
|
func (v javaVersion) StringForKotlinc() string {
|
|
|
|
// $ ./external/kotlinc/bin/kotlinc -jvm-target foo
|
|
|
|
// error: unknown JVM target version: foo
|
|
|
|
// Supported versions: 1.6, 1.8, 9, 10, 11, 12, 13, 14, 15, 16, 17
|
|
|
|
switch v {
|
|
|
|
case JAVA_VERSION_7:
|
|
|
|
return "1.6"
|
|
|
|
case JAVA_VERSION_9:
|
|
|
|
return "9"
|
|
|
|
default:
|
|
|
|
return v.String()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
// Returns true if javac targeting this version uses system modules instead of a bootclasspath.
|
|
|
|
func (v javaVersion) usesJavaModules() bool {
|
|
|
|
return v >= 9
|
2020-01-08 05:35:43 +01:00
|
|
|
}
|
|
|
|
|
2021-03-17 23:56:23 +01:00
|
|
|
func normalizeJavaVersion(ctx android.BaseModuleContext, javaVersion string) javaVersion {
|
|
|
|
switch javaVersion {
|
|
|
|
case "1.6", "6":
|
|
|
|
return JAVA_VERSION_6
|
|
|
|
case "1.7", "7":
|
|
|
|
return JAVA_VERSION_7
|
|
|
|
case "1.8", "8":
|
|
|
|
return JAVA_VERSION_8
|
|
|
|
case "1.9", "9":
|
|
|
|
return JAVA_VERSION_9
|
2021-11-26 18:26:33 +01:00
|
|
|
case "11":
|
|
|
|
return JAVA_VERSION_11
|
2022-05-24 13:13:50 +02:00
|
|
|
case "17":
|
2022-06-22 13:53:51 +02:00
|
|
|
return JAVA_VERSION_17
|
2022-05-24 13:13:50 +02:00
|
|
|
case "10", "12", "13", "14", "15", "16":
|
|
|
|
ctx.PropertyErrorf("java_version", "Java language level %s is not supported", javaVersion)
|
2021-03-17 23:56:23 +01:00
|
|
|
return JAVA_VERSION_UNSUPPORTED
|
|
|
|
default:
|
|
|
|
ctx.PropertyErrorf("java_version", "Unrecognized Java language level")
|
|
|
|
return JAVA_VERSION_UNSUPPORTED
|
|
|
|
}
|
2020-01-31 18:10:36 +01:00
|
|
|
}
|
|
|
|
|
2015-03-31 02:20:39 +02:00
|
|
|
//
|
|
|
|
// Java libraries (.jar file)
|
|
|
|
//
|
|
|
|
|
2017-07-20 00:53:04 +02:00
|
|
|
type Library struct {
|
2017-06-23 01:51:17 +02:00
|
|
|
Module
|
2019-10-16 01:36:40 +02:00
|
|
|
|
|
|
|
InstallMixin func(ctx android.ModuleContext, installPath android.Path) (extraInstallDeps android.Paths)
|
2015-03-31 02:20:39 +02:00
|
|
|
}
|
|
|
|
|
2020-12-15 14:29:02 +01:00
|
|
|
var _ android.ApexModule = (*Library)(nil)
|
|
|
|
|
2021-07-21 15:23:52 +02:00
|
|
|
// Provides access to the list of permitted packages from apex boot jars.
|
2020-05-29 12:24:51 +02:00
|
|
|
type PermittedPackagesForUpdatableBootJars interface {
|
|
|
|
PermittedPackagesForUpdatableBootJars() []string
|
|
|
|
}
|
|
|
|
|
|
|
|
var _ PermittedPackagesForUpdatableBootJars = (*Library)(nil)
|
|
|
|
|
|
|
|
func (j *Library) PermittedPackagesForUpdatableBootJars() []string {
|
|
|
|
return j.properties.Permitted_packages
|
|
|
|
}
|
|
|
|
|
2019-02-22 03:12:14 +01:00
|
|
|
func shouldUncompressDex(ctx android.ModuleContext, dexpreopter *dexpreopter) bool {
|
2020-01-24 13:19:45 +01:00
|
|
|
// Store uncompressed (and aligned) any dex files from jars in APEXes.
|
2020-09-16 03:30:11 +02:00
|
|
|
if apexInfo := ctx.Provider(android.ApexInfoProvider).(android.ApexInfo); !apexInfo.IsForPlatform() {
|
2020-01-24 13:19:45 +01:00
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
2019-02-12 14:12:16 +01:00
|
|
|
// Store uncompressed (and do not strip) dex files from boot class path jars.
|
|
|
|
if inList(ctx.ModuleName(), ctx.Config().BootJars()) {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
// Store uncompressed dex files that are preopted on /system.
|
2021-09-16 08:15:39 +02:00
|
|
|
if !dexpreopter.dexpreoptDisabled(ctx) && (ctx.Host() || !dexpreopter.odexOnSystemOther(ctx, dexpreopter.installPath)) {
|
2018-12-21 16:54:16 +01:00
|
|
|
return true
|
|
|
|
}
|
2019-02-07 01:37:12 +01:00
|
|
|
if ctx.Config().UncompressPrivAppDex() &&
|
|
|
|
inList(ctx.ModuleName(), ctx.Config().ModulesLoadedByPrivilegedModules()) {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
2018-12-21 21:59:54 +01:00
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
2021-10-11 05:05:20 +02:00
|
|
|
// Sets `dexer.dexProperties.Uncompress_dex` to the proper value.
|
|
|
|
func setUncompressDex(ctx android.ModuleContext, dexpreopter *dexpreopter, dexer *dexer) {
|
|
|
|
if dexer.dexProperties.Uncompress_dex == nil {
|
|
|
|
// If the value was not force-set by the user, use reasonable default based on the module.
|
|
|
|
dexer.dexProperties.Uncompress_dex = proptools.BoolPtr(shouldUncompressDex(ctx, dexpreopter))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-07-20 00:53:04 +02:00
|
|
|
func (j *Library) GenerateAndroidBuildActions(ctx android.ModuleContext) {
|
2021-04-02 01:45:46 +02:00
|
|
|
j.sdkVersion = j.SdkVersion(ctx)
|
|
|
|
j.minSdkVersion = j.MinSdkVersion(ctx)
|
2021-11-29 18:25:52 +01:00
|
|
|
j.maxSdkVersion = j.MaxSdkVersion(ctx)
|
2021-04-02 01:45:46 +02:00
|
|
|
|
2020-09-16 03:30:11 +02:00
|
|
|
apexInfo := ctx.Provider(android.ApexInfoProvider).(android.ApexInfo)
|
|
|
|
if !apexInfo.IsForPlatform() {
|
|
|
|
j.hideApexVariantFromMake = true
|
|
|
|
}
|
|
|
|
|
2020-04-08 20:09:30 +02:00
|
|
|
j.checkSdkVersions(ctx)
|
2021-12-01 22:04:46 +01:00
|
|
|
if ctx.Device() {
|
|
|
|
j.dexpreopter.installPath = j.dexpreopter.getInstallPath(
|
|
|
|
ctx, android.PathForModuleInstall(ctx, "framework", j.Stem()+".jar"))
|
|
|
|
j.dexpreopter.isSDKLibrary = j.deviceProperties.IsSDKLibrary
|
|
|
|
setUncompressDex(ctx, &j.dexpreopter, &j.dexer)
|
|
|
|
j.dexpreopter.uncompressedDex = *j.dexProperties.Uncompress_dex
|
|
|
|
j.classLoaderContexts = j.usesLibrary.classLoaderContextForUsesLibDeps(ctx)
|
|
|
|
}
|
2019-05-13 18:23:20 +02:00
|
|
|
j.compile(ctx, nil)
|
2015-04-16 23:09:14 +02:00
|
|
|
|
2020-05-21 04:11:59 +02:00
|
|
|
// Collect the module directory for IDE info in java/jdeps.go.
|
|
|
|
j.modulePaths = append(j.modulePaths, ctx.ModuleDir())
|
|
|
|
|
2020-09-16 03:30:11 +02:00
|
|
|
exclusivelyForApex := !apexInfo.IsForPlatform()
|
2019-07-25 15:02:35 +02:00
|
|
|
if (Bool(j.properties.Installable) || ctx.Host()) && !exclusivelyForApex {
|
2019-10-16 01:36:40 +02:00
|
|
|
var extraInstallDeps android.Paths
|
|
|
|
if j.InstallMixin != nil {
|
|
|
|
extraInstallDeps = j.InstallMixin(ctx, j.outputFile)
|
|
|
|
}
|
2021-11-03 22:08:20 +01:00
|
|
|
hostDexNeeded := Bool(j.deviceProperties.Hostdex) && !ctx.Host()
|
|
|
|
if hostDexNeeded {
|
2021-11-10 23:38:50 +01:00
|
|
|
j.hostdexInstallFile = ctx.InstallFile(
|
|
|
|
android.PathForHostDexInstall(ctx, "framework"),
|
2021-11-03 22:08:20 +01:00
|
|
|
j.Stem()+"-hostdex.jar", j.outputFile)
|
|
|
|
}
|
|
|
|
var installDir android.InstallPath
|
|
|
|
if ctx.InstallInTestcases() {
|
|
|
|
var archDir string
|
|
|
|
if !ctx.Host() {
|
|
|
|
archDir = ctx.DeviceConfig().DeviceArch()
|
|
|
|
}
|
|
|
|
installDir = android.PathForModuleInstall(ctx, ctx.ModuleName(), archDir)
|
|
|
|
} else {
|
|
|
|
installDir = android.PathForModuleInstall(ctx, "framework")
|
|
|
|
}
|
|
|
|
j.installFile = ctx.InstallFile(installDir, j.Stem()+".jar", j.outputFile, extraInstallDeps...)
|
2017-09-01 01:45:16 +02:00
|
|
|
}
|
2015-04-16 23:09:14 +02:00
|
|
|
}
|
|
|
|
|
2017-07-20 00:53:04 +02:00
|
|
|
func (j *Library) DepsMutator(ctx android.BottomUpMutatorContext) {
|
2017-06-23 01:51:17 +02:00
|
|
|
j.deps(ctx)
|
2021-08-18 17:57:11 +02:00
|
|
|
j.usesLibrary.deps(ctx, false)
|
2017-06-23 01:51:17 +02:00
|
|
|
}
|
|
|
|
|
2019-11-12 20:39:25 +01:00
|
|
|
const (
|
2019-12-03 19:06:47 +01:00
|
|
|
aidlIncludeDir = "aidl"
|
|
|
|
javaDir = "java"
|
|
|
|
jarFileSuffix = ".jar"
|
|
|
|
testConfigSuffix = "-AndroidTest.xml"
|
2019-11-12 20:39:25 +01:00
|
|
|
)
|
|
|
|
|
2019-12-05 12:25:53 +01:00
|
|
|
// path to the jar file of a java library. Relative to <sdk_root>/<api_dir>
|
2022-07-15 15:12:35 +02:00
|
|
|
func sdkSnapshotFilePathForJar(_ android.SdkMemberContext, osPrefix, name string) string {
|
2020-03-02 11:16:35 +01:00
|
|
|
return sdkSnapshotFilePathForMember(osPrefix, name, jarFileSuffix)
|
2019-12-03 19:06:47 +01:00
|
|
|
}
|
|
|
|
|
2020-03-02 11:16:35 +01:00
|
|
|
func sdkSnapshotFilePathForMember(osPrefix, name string, suffix string) string {
|
|
|
|
return filepath.Join(javaDir, osPrefix, name+suffix)
|
2019-11-12 20:39:25 +01:00
|
|
|
}
|
|
|
|
|
2019-11-28 15:31:38 +01:00
|
|
|
type librarySdkMemberType struct {
|
2019-12-13 12:22:16 +01:00
|
|
|
android.SdkMemberTypeBase
|
2020-02-28 15:39:53 +01:00
|
|
|
|
|
|
|
// Function to retrieve the appropriate output jar (implementation or header) from
|
|
|
|
// the library.
|
2020-12-08 18:48:25 +01:00
|
|
|
jarToExportGetter func(ctx android.SdkMemberContext, j *Library) android.Path
|
|
|
|
|
|
|
|
// Function to compute the snapshot relative path to which the named library's
|
|
|
|
// jar should be copied.
|
2022-07-15 15:12:35 +02:00
|
|
|
snapshotPathGetter func(ctx android.SdkMemberContext, osPrefix, name string) string
|
2020-12-08 18:48:25 +01:00
|
|
|
|
|
|
|
// True if only the jar should be copied to the snapshot, false if the jar plus any additional
|
|
|
|
// files like aidl files should also be copied.
|
|
|
|
onlyCopyJarToSnapshot bool
|
2019-11-28 15:31:38 +01:00
|
|
|
}
|
|
|
|
|
2020-12-08 18:48:25 +01:00
|
|
|
const (
|
|
|
|
onlyCopyJarToSnapshot = true
|
|
|
|
copyEverythingToSnapshot = false
|
|
|
|
)
|
|
|
|
|
2021-07-14 11:29:36 +02:00
|
|
|
func (mt *librarySdkMemberType) AddDependencies(ctx android.SdkDependencyContext, dependencyTag blueprint.DependencyTag, names []string) {
|
|
|
|
ctx.AddVariationDependencies(nil, dependencyTag, names...)
|
2019-11-28 15:31:38 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (mt *librarySdkMemberType) IsInstance(module android.Module) bool {
|
|
|
|
_, ok := module.(*Library)
|
|
|
|
return ok
|
|
|
|
}
|
|
|
|
|
2020-03-19 17:11:18 +01:00
|
|
|
func (mt *librarySdkMemberType) AddPrebuiltModule(ctx android.SdkMemberContext, member android.SdkMember) android.BpModule {
|
|
|
|
return ctx.SnapshotBuilder().AddPrebuiltModule(member, "java_import")
|
2020-03-02 12:33:02 +01:00
|
|
|
}
|
2019-12-05 12:25:53 +01:00
|
|
|
|
2020-03-02 12:33:02 +01:00
|
|
|
func (mt *librarySdkMemberType) CreateVariantPropertiesStruct() android.SdkMemberProperties {
|
2020-03-17 22:04:24 +01:00
|
|
|
return &librarySdkMemberProperties{}
|
2020-03-02 12:33:02 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
type librarySdkMemberProperties struct {
|
|
|
|
android.SdkMemberPropertiesBase
|
|
|
|
|
2020-05-06 11:23:19 +02:00
|
|
|
JarToExport android.Path `android:"arch_variant"`
|
2020-03-17 22:04:24 +01:00
|
|
|
AidlIncludeDirs android.Paths
|
2021-07-15 15:14:41 +02:00
|
|
|
|
|
|
|
// 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
|
2020-03-02 12:33:02 +01:00
|
|
|
}
|
|
|
|
|
2020-03-19 17:11:18 +01:00
|
|
|
func (p *librarySdkMemberProperties) PopulateFromVariant(ctx android.SdkMemberContext, variant android.Module) {
|
2019-11-28 15:31:38 +01:00
|
|
|
j := variant.(*Library)
|
|
|
|
|
2020-12-08 18:48:25 +01:00
|
|
|
p.JarToExport = ctx.MemberType().(*librarySdkMemberType).jarToExportGetter(ctx, j)
|
|
|
|
|
2020-03-17 22:04:24 +01:00
|
|
|
p.AidlIncludeDirs = j.AidlIncludeDirs()
|
2021-07-15 15:14:41 +02:00
|
|
|
|
|
|
|
p.PermittedPackages = j.PermittedPackagesForUpdatableBootJars()
|
2020-03-02 12:33:02 +01:00
|
|
|
}
|
|
|
|
|
2020-03-19 17:11:18 +01:00
|
|
|
func (p *librarySdkMemberProperties) AddToPropertySet(ctx android.SdkMemberContext, propertySet android.BpPropertySet) {
|
2020-03-17 22:04:24 +01:00
|
|
|
builder := ctx.SnapshotBuilder()
|
2020-03-19 17:11:18 +01:00
|
|
|
|
2020-12-08 18:48:25 +01:00
|
|
|
memberType := ctx.MemberType().(*librarySdkMemberType)
|
|
|
|
|
2020-03-17 22:04:24 +01:00
|
|
|
exportedJar := p.JarToExport
|
|
|
|
if exportedJar != nil {
|
2020-12-08 18:48:25 +01:00
|
|
|
// Delegate the creation of the snapshot relative path to the member type.
|
2022-07-15 15:12:35 +02:00
|
|
|
snapshotRelativeJavaLibPath := memberType.snapshotPathGetter(ctx, p.OsPrefix(), ctx.Name())
|
2020-12-08 18:48:25 +01:00
|
|
|
|
|
|
|
// Copy the exported jar to the snapshot.
|
2020-03-02 12:33:02 +01:00
|
|
|
builder.CopyToSnapshot(exportedJar, snapshotRelativeJavaLibPath)
|
2019-11-12 20:39:25 +01:00
|
|
|
|
2020-03-17 22:04:24 +01:00
|
|
|
propertySet.AddProperty("jars", []string{snapshotRelativeJavaLibPath})
|
|
|
|
}
|
|
|
|
|
2021-07-15 15:14:41 +02:00
|
|
|
if len(p.PermittedPackages) > 0 {
|
|
|
|
propertySet.AddProperty("permitted_packages", p.PermittedPackages)
|
|
|
|
}
|
|
|
|
|
2020-12-08 18:48:25 +01:00
|
|
|
// Do not copy anything else to the snapshot.
|
|
|
|
if memberType.onlyCopyJarToSnapshot {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2020-03-17 22:04:24 +01:00
|
|
|
aidlIncludeDirs := p.AidlIncludeDirs
|
|
|
|
if len(aidlIncludeDirs) != 0 {
|
|
|
|
sdkModuleContext := ctx.SdkModuleContext()
|
|
|
|
for _, dir := range aidlIncludeDirs {
|
2020-03-02 12:33:02 +01:00
|
|
|
// TODO(jiyong): copy parcelable declarations only
|
|
|
|
aidlFiles, _ := sdkModuleContext.GlobWithDeps(dir.String()+"/**/*.aidl", nil)
|
|
|
|
for _, file := range aidlFiles {
|
|
|
|
builder.CopyToSnapshot(android.PathForSource(sdkModuleContext, file), filepath.Join(aidlIncludeDir, file))
|
|
|
|
}
|
2019-11-12 20:39:25 +01:00
|
|
|
}
|
|
|
|
|
2020-03-17 22:04:24 +01:00
|
|
|
// TODO(b/151933053) - add aidl include dirs property
|
2020-03-02 12:33:02 +01:00
|
|
|
}
|
2019-11-12 20:39:25 +01:00
|
|
|
}
|
|
|
|
|
2019-02-12 23:41:32 +01:00
|
|
|
// java_library builds and links sources into a `.jar` file for the device, and possibly for the host as well.
|
|
|
|
//
|
|
|
|
// By default, a java_library has a single variant that produces a `.jar` file containing `.class` files that were
|
|
|
|
// compiled against the device bootclasspath. This jar is not suitable for installing on a device, but can be used
|
|
|
|
// as a `static_libs` dependency of another module.
|
|
|
|
//
|
|
|
|
// Specifying `installable: true` will product a `.jar` file containing `classes.dex` files, suitable for installing on
|
|
|
|
// a device.
|
|
|
|
//
|
|
|
|
// Specifying `host_supported: true` will produce two variants, one compiled against the device bootclasspath and one
|
|
|
|
// compiled against the host bootclasspath.
|
2018-06-27 02:59:05 +02:00
|
|
|
func LibraryFactory() android.Module {
|
|
|
|
module := &Library{}
|
2015-03-31 02:20:39 +02:00
|
|
|
|
2020-06-16 01:09:53 +02:00
|
|
|
module.addHostAndDeviceProperties()
|
2017-06-24 00:06:31 +02:00
|
|
|
|
2021-06-23 12:39:47 +02:00
|
|
|
module.initModuleAndImport(module)
|
2020-05-15 11:20:31 +02:00
|
|
|
|
2019-07-25 15:02:35 +02:00
|
|
|
android.InitApexModule(module)
|
Introduce module type 'sdk'
This change introduces a new module type named 'sdk'. It is a logical
group of prebuilt modules that together provide a context (e.g. APIs)
in which Mainline modules (such as APEXes) are built.
A prebuilt module (e.g. java_import) can join an sdk by adding it to the
sdk module as shown below:
sdk {
name: "mysdk#20",
java_libs: ["myjavalib_mysdk_20"],
}
java_import {
name: "myjavalib_mysdk_20",
srcs: ["myjavalib-v20.jar"],
sdk_member_name: "myjavalib",
}
sdk {
name: "mysdk#21",
java_libs: ["myjavalib_mysdk_21"],
}
java_import {
name: "myjavalib_mysdk_21",
srcs: ["myjavalib-v21.jar"],
sdk_member_name: "myjavalib",
}
java_library {
name: "myjavalib",
srcs: ["**/*/*.java"],
}
An APEX can specify the SDK(s) that it wants to build with via the new
'uses_sdks' property.
apex {
name: "myapex",
java_libs: ["libX", "libY"],
uses_sdks: ["mysdk#20"],
}
With this, libX, libY, and their transitive dependencies are all built
with the version 20 of myjavalib (the first java_import module) instead
of the other one (which is for version 21) and java_library having the
same name (which is for ToT).
Bug: 138182343
Test: m (sdk_test.go added)
Change-Id: I7e14c524a7d6a0d9f575fb20822080f39818c01e
2019-07-17 13:08:41 +02:00
|
|
|
android.InitSdkAwareModule(module)
|
2021-12-10 12:14:59 +01:00
|
|
|
android.InitBazelModule(module)
|
2019-11-13 02:50:48 +01:00
|
|
|
InitJavaModule(module, android.HostAndDeviceSupported)
|
2018-06-27 02:59:05 +02:00
|
|
|
return module
|
2015-03-31 02:20:39 +02:00
|
|
|
}
|
|
|
|
|
2019-02-12 23:41:32 +01:00
|
|
|
// java_library_static is an obsolete alias for java_library.
|
|
|
|
func LibraryStaticFactory() android.Module {
|
|
|
|
return LibraryFactory()
|
|
|
|
}
|
|
|
|
|
|
|
|
// java_library_host builds and links sources into a `.jar` file for the host.
|
|
|
|
//
|
|
|
|
// A java_library_host has a single variant that produces a `.jar` file containing `.class` files that were
|
|
|
|
// compiled against the host bootclasspath.
|
2017-07-20 00:53:04 +02:00
|
|
|
func LibraryHostFactory() android.Module {
|
|
|
|
module := &Library{}
|
2015-03-31 02:20:39 +02:00
|
|
|
|
2020-06-16 01:09:53 +02:00
|
|
|
module.addHostProperties()
|
2017-06-24 00:06:31 +02:00
|
|
|
|
2018-06-27 02:59:05 +02:00
|
|
|
module.Module.properties.Installable = proptools.BoolPtr(true)
|
|
|
|
|
2019-07-25 15:02:35 +02:00
|
|
|
android.InitApexModule(module)
|
2021-05-06 17:33:43 +02:00
|
|
|
android.InitSdkAwareModule(module)
|
2021-12-10 12:14:59 +01:00
|
|
|
android.InitBazelModule(module)
|
2019-11-13 02:50:48 +01:00
|
|
|
InitJavaModule(module, android.HostSupported)
|
2017-06-24 00:06:31 +02:00
|
|
|
return module
|
2015-03-31 02:20:39 +02:00
|
|
|
}
|
|
|
|
|
2018-04-10 03:40:24 +02:00
|
|
|
//
|
2018-08-15 01:42:33 +02:00
|
|
|
// Java Tests
|
2018-04-10 03:40:24 +02:00
|
|
|
//
|
|
|
|
|
2020-08-15 21:24:26 +02:00
|
|
|
// Test option struct.
|
|
|
|
type TestOptions struct {
|
|
|
|
// a list of extra test configuration files that should be installed with the module.
|
|
|
|
Extra_test_configs []string `android:"path,arch_variant"`
|
2020-11-13 23:33:46 +01:00
|
|
|
|
|
|
|
// If the test is a hostside(no device required) unittest that shall be run during presubmit check.
|
|
|
|
Unit_test *bool
|
2020-08-15 21:24:26 +02:00
|
|
|
}
|
|
|
|
|
2018-04-10 03:40:24 +02:00
|
|
|
type testProperties struct {
|
|
|
|
// list of compatibility suites (for example "cts", "vts") that the module should be
|
|
|
|
// installed into.
|
|
|
|
Test_suites []string `android:"arch_variant"`
|
2018-08-03 00:00:46 +02:00
|
|
|
|
|
|
|
// the name of the test configuration (for example "AndroidTest.xml") that should be
|
|
|
|
// installed with the module.
|
2019-03-05 07:35:41 +01:00
|
|
|
Test_config *string `android:"path,arch_variant"`
|
2018-08-11 01:06:24 +02:00
|
|
|
|
2018-09-19 11:21:28 +02:00
|
|
|
// the name of the test configuration template (for example "AndroidTestTemplate.xml") that
|
|
|
|
// should be installed with the module.
|
2019-03-05 07:35:41 +01:00
|
|
|
Test_config_template *string `android:"path,arch_variant"`
|
2018-09-19 11:21:28 +02:00
|
|
|
|
2018-08-11 01:06:24 +02:00
|
|
|
// list of files or filegroup modules that provide data that should be installed alongside
|
|
|
|
// the test
|
2021-02-15 22:52:39 +01:00
|
|
|
Data []string `android:"path"`
|
2019-09-26 20:41:36 +02:00
|
|
|
|
|
|
|
// Flag to indicate whether or not to create test config automatically. If AndroidTest.xml
|
|
|
|
// doesn't exist next to the Android.bp, this attribute doesn't need to be set to true
|
|
|
|
// explicitly.
|
|
|
|
Auto_gen_config *bool
|
2020-04-30 08:57:06 +02:00
|
|
|
|
|
|
|
// Add parameterized mainline modules to auto generated test config. The options will be
|
|
|
|
// handled by TradeFed to do downloading and installing the specified modules on the device.
|
|
|
|
Test_mainline_modules []string
|
2020-08-15 21:24:26 +02:00
|
|
|
|
|
|
|
// Test options.
|
|
|
|
Test_options TestOptions
|
2021-01-26 20:01:43 +01:00
|
|
|
|
|
|
|
// Names of modules containing JNI libraries that should be installed alongside the test.
|
|
|
|
Jni_libs []string
|
2021-09-25 00:47:17 +02:00
|
|
|
|
|
|
|
// Install the test into a folder named for the module in all test suites.
|
|
|
|
Per_testcase_directory *bool
|
2018-04-10 03:40:24 +02:00
|
|
|
}
|
|
|
|
|
2020-06-13 01:38:45 +02:00
|
|
|
type hostTestProperties struct {
|
|
|
|
// list of native binary modules that should be installed alongside the test
|
|
|
|
Data_native_bins []string `android:"arch_variant"`
|
2022-01-20 22:10:28 +01:00
|
|
|
|
|
|
|
// list of device binary modules that should be installed alongside the test
|
2022-06-01 17:45:02 +02:00
|
|
|
// This property only adds the first variant of the dependency
|
|
|
|
Data_device_bins_first []string `android:"arch_variant"`
|
|
|
|
|
|
|
|
// list of device binary modules that should be installed alongside the test
|
|
|
|
// This property adds 64bit AND 32bit variants of the dependency
|
|
|
|
Data_device_bins_both []string `android:"arch_variant"`
|
|
|
|
|
|
|
|
// list of device binary modules that should be installed alongside the test
|
|
|
|
// This property only adds 64bit variants of the dependency
|
|
|
|
Data_device_bins_64 []string `android:"arch_variant"`
|
|
|
|
|
|
|
|
// list of device binary modules that should be installed alongside the test
|
|
|
|
// This property adds 32bit variants of the dependency if available, or else
|
|
|
|
// defaults to the 64bit variant
|
|
|
|
Data_device_bins_prefer32 []string `android:"arch_variant"`
|
|
|
|
|
|
|
|
// list of device binary modules that should be installed alongside the test
|
|
|
|
// This property only adds 32bit variants of the dependency
|
|
|
|
Data_device_bins_32 []string `android:"arch_variant"`
|
2020-06-13 01:38:45 +02:00
|
|
|
}
|
|
|
|
|
2019-03-20 13:45:53 +01:00
|
|
|
type testHelperLibraryProperties struct {
|
|
|
|
// list of compatibility suites (for example "cts", "vts") that the module should be
|
|
|
|
// installed into.
|
|
|
|
Test_suites []string `android:"arch_variant"`
|
2021-09-25 00:47:17 +02:00
|
|
|
|
|
|
|
// Install the test into a folder named for the module in all test suites.
|
|
|
|
Per_testcase_directory *bool
|
2019-03-20 13:45:53 +01:00
|
|
|
}
|
|
|
|
|
2019-12-03 19:06:47 +01:00
|
|
|
type prebuiltTestProperties struct {
|
|
|
|
// list of compatibility suites (for example "cts", "vts") that the module should be
|
|
|
|
// installed into.
|
|
|
|
Test_suites []string `android:"arch_variant"`
|
|
|
|
|
|
|
|
// the name of the test configuration (for example "AndroidTest.xml") that should be
|
|
|
|
// installed with the module.
|
|
|
|
Test_config *string `android:"path,arch_variant"`
|
|
|
|
}
|
|
|
|
|
2018-04-10 03:40:24 +02:00
|
|
|
type Test struct {
|
|
|
|
Library
|
|
|
|
|
|
|
|
testProperties testProperties
|
2018-08-08 01:49:25 +02:00
|
|
|
|
2020-08-15 21:24:26 +02:00
|
|
|
testConfig android.Path
|
|
|
|
extraTestConfigs android.Paths
|
|
|
|
data android.Paths
|
2018-08-08 01:49:25 +02:00
|
|
|
}
|
|
|
|
|
2020-06-13 01:38:45 +02:00
|
|
|
type TestHost struct {
|
|
|
|
Test
|
|
|
|
|
|
|
|
testHostProperties hostTestProperties
|
|
|
|
}
|
|
|
|
|
2019-03-20 13:45:53 +01:00
|
|
|
type TestHelperLibrary struct {
|
|
|
|
Library
|
|
|
|
|
|
|
|
testHelperLibraryProperties testHelperLibraryProperties
|
|
|
|
}
|
|
|
|
|
2019-12-03 19:06:47 +01:00
|
|
|
type JavaTestImport struct {
|
|
|
|
Import
|
|
|
|
|
|
|
|
prebuiltTestProperties prebuiltTestProperties
|
|
|
|
|
|
|
|
testConfig android.Path
|
2020-08-06 00:40:41 +02:00
|
|
|
dexJarFile android.Path
|
2019-12-03 19:06:47 +01:00
|
|
|
}
|
|
|
|
|
2021-11-03 22:09:41 +01:00
|
|
|
func (j *Test) InstallInTestcases() bool {
|
|
|
|
// Host java tests install into $(HOST_OUT_JAVA_LIBRARIES), and then are copied into
|
|
|
|
// testcases by base_rules.mk.
|
|
|
|
return !j.Host()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (j *TestHelperLibrary) InstallInTestcases() bool {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
func (j *JavaTestImport) InstallInTestcases() bool {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
2022-06-01 17:45:02 +02:00
|
|
|
func (j *TestHost) addDataDeviceBinsDeps(ctx android.BottomUpMutatorContext) {
|
|
|
|
if len(j.testHostProperties.Data_device_bins_first) > 0 {
|
|
|
|
deviceVariations := ctx.Config().AndroidFirstDeviceTarget.Variations()
|
|
|
|
ctx.AddFarVariationDependencies(deviceVariations, dataDeviceBinsTag, j.testHostProperties.Data_device_bins_first...)
|
|
|
|
}
|
|
|
|
|
|
|
|
var maybeAndroid32Target *android.Target
|
|
|
|
var maybeAndroid64Target *android.Target
|
|
|
|
android32TargetList := android.FirstTarget(ctx.Config().Targets[android.Android], "lib32")
|
|
|
|
android64TargetList := android.FirstTarget(ctx.Config().Targets[android.Android], "lib64")
|
|
|
|
if len(android32TargetList) > 0 {
|
|
|
|
maybeAndroid32Target = &android32TargetList[0]
|
|
|
|
}
|
|
|
|
if len(android64TargetList) > 0 {
|
|
|
|
maybeAndroid64Target = &android64TargetList[0]
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(j.testHostProperties.Data_device_bins_both) > 0 {
|
|
|
|
if maybeAndroid32Target == nil && maybeAndroid64Target == nil {
|
|
|
|
ctx.PropertyErrorf("data_device_bins_both", "no device targets available. Targets: %q", ctx.Config().Targets)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
if maybeAndroid32Target != nil {
|
|
|
|
ctx.AddFarVariationDependencies(
|
|
|
|
maybeAndroid32Target.Variations(),
|
|
|
|
dataDeviceBinsTag,
|
|
|
|
j.testHostProperties.Data_device_bins_both...,
|
|
|
|
)
|
|
|
|
}
|
|
|
|
if maybeAndroid64Target != nil {
|
|
|
|
ctx.AddFarVariationDependencies(
|
|
|
|
maybeAndroid64Target.Variations(),
|
|
|
|
dataDeviceBinsTag,
|
|
|
|
j.testHostProperties.Data_device_bins_both...,
|
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(j.testHostProperties.Data_device_bins_prefer32) > 0 {
|
|
|
|
if maybeAndroid32Target != nil {
|
|
|
|
ctx.AddFarVariationDependencies(
|
|
|
|
maybeAndroid32Target.Variations(),
|
|
|
|
dataDeviceBinsTag,
|
|
|
|
j.testHostProperties.Data_device_bins_prefer32...,
|
|
|
|
)
|
|
|
|
} else {
|
|
|
|
if maybeAndroid64Target == nil {
|
|
|
|
ctx.PropertyErrorf("data_device_bins_prefer32", "no device targets available. Targets: %q", ctx.Config().Targets)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
ctx.AddFarVariationDependencies(
|
|
|
|
maybeAndroid64Target.Variations(),
|
|
|
|
dataDeviceBinsTag,
|
|
|
|
j.testHostProperties.Data_device_bins_prefer32...,
|
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(j.testHostProperties.Data_device_bins_32) > 0 {
|
|
|
|
if maybeAndroid32Target == nil {
|
|
|
|
ctx.PropertyErrorf("data_device_bins_32", "cannot find 32bit device target. Targets: %q", ctx.Config().Targets)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
deviceVariations := maybeAndroid32Target.Variations()
|
|
|
|
ctx.AddFarVariationDependencies(deviceVariations, dataDeviceBinsTag, j.testHostProperties.Data_device_bins_32...)
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(j.testHostProperties.Data_device_bins_64) > 0 {
|
|
|
|
if maybeAndroid64Target == nil {
|
|
|
|
ctx.PropertyErrorf("data_device_bins_64", "cannot find 64bit device target. Targets: %q", ctx.Config().Targets)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
deviceVariations := maybeAndroid64Target.Variations()
|
|
|
|
ctx.AddFarVariationDependencies(deviceVariations, dataDeviceBinsTag, j.testHostProperties.Data_device_bins_64...)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-06-13 01:38:45 +02:00
|
|
|
func (j *TestHost) DepsMutator(ctx android.BottomUpMutatorContext) {
|
|
|
|
if len(j.testHostProperties.Data_native_bins) > 0 {
|
|
|
|
for _, target := range ctx.MultiTargets() {
|
|
|
|
ctx.AddVariationDependencies(target.Variations(), dataNativeBinsTag, j.testHostProperties.Data_native_bins...)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-01-26 20:01:43 +01:00
|
|
|
if len(j.testProperties.Jni_libs) > 0 {
|
|
|
|
for _, target := range ctx.MultiTargets() {
|
|
|
|
sharedLibVariations := append(target.Variations(), blueprint.Variation{Mutator: "link", Variation: "shared"})
|
|
|
|
ctx.AddFarVariationDependencies(sharedLibVariations, jniLibTag, j.testProperties.Jni_libs...)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-06-01 17:45:02 +02:00
|
|
|
j.addDataDeviceBinsDeps(ctx)
|
|
|
|
|
2020-06-13 01:38:45 +02:00
|
|
|
j.deps(ctx)
|
|
|
|
}
|
|
|
|
|
2021-03-04 22:47:56 +01:00
|
|
|
func (j *TestHost) AddExtraResource(p android.Path) {
|
|
|
|
j.extraResources = append(j.extraResources, p)
|
|
|
|
}
|
|
|
|
|
2022-06-01 17:45:02 +02:00
|
|
|
func (j *TestHost) dataDeviceBins() []string {
|
|
|
|
ret := make([]string, 0,
|
|
|
|
len(j.testHostProperties.Data_device_bins_first)+
|
|
|
|
len(j.testHostProperties.Data_device_bins_both)+
|
|
|
|
len(j.testHostProperties.Data_device_bins_prefer32)+
|
|
|
|
len(j.testHostProperties.Data_device_bins_32)+
|
|
|
|
len(j.testHostProperties.Data_device_bins_64),
|
|
|
|
)
|
|
|
|
|
|
|
|
ret = append(ret, j.testHostProperties.Data_device_bins_first...)
|
|
|
|
ret = append(ret, j.testHostProperties.Data_device_bins_both...)
|
|
|
|
ret = append(ret, j.testHostProperties.Data_device_bins_prefer32...)
|
|
|
|
ret = append(ret, j.testHostProperties.Data_device_bins_32...)
|
|
|
|
ret = append(ret, j.testHostProperties.Data_device_bins_64...)
|
|
|
|
|
|
|
|
return ret
|
|
|
|
}
|
|
|
|
|
2022-01-20 22:10:28 +01:00
|
|
|
func (j *TestHost) GenerateAndroidBuildActions(ctx android.ModuleContext) {
|
|
|
|
var configs []tradefed.Config
|
2022-06-01 17:45:02 +02:00
|
|
|
dataDeviceBins := j.dataDeviceBins()
|
|
|
|
if len(dataDeviceBins) > 0 {
|
2022-01-20 22:10:28 +01:00
|
|
|
// add Tradefed configuration to push device bins to device for testing
|
|
|
|
remoteDir := filepath.Join("/data/local/tests/unrestricted/", j.Name())
|
|
|
|
options := []tradefed.Option{{Name: "cleanup", Value: "true"}}
|
2022-06-01 17:45:02 +02:00
|
|
|
for _, bin := range dataDeviceBins {
|
2022-01-20 22:10:28 +01:00
|
|
|
fullPath := filepath.Join(remoteDir, bin)
|
|
|
|
options = append(options, tradefed.Option{Name: "push-file", Key: bin, Value: fullPath})
|
|
|
|
}
|
2022-06-01 17:45:02 +02:00
|
|
|
configs = append(configs, tradefed.Object{
|
|
|
|
Type: "target_preparer",
|
|
|
|
Class: "com.android.tradefed.targetprep.PushFilePreparer",
|
|
|
|
Options: options,
|
|
|
|
})
|
2022-01-20 22:10:28 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
j.Test.generateAndroidBuildActionsWithConfig(ctx, configs)
|
|
|
|
}
|
|
|
|
|
2018-08-08 01:49:25 +02:00
|
|
|
func (j *Test) GenerateAndroidBuildActions(ctx android.ModuleContext) {
|
2022-01-20 22:10:28 +01:00
|
|
|
j.generateAndroidBuildActionsWithConfig(ctx, nil)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (j *Test) generateAndroidBuildActionsWithConfig(ctx android.ModuleContext, configs []tradefed.Config) {
|
2021-03-05 19:08:36 +01:00
|
|
|
if j.testProperties.Test_options.Unit_test == nil && ctx.Host() {
|
|
|
|
// TODO(b/): Clean temporary heuristic to avoid unexpected onboarding.
|
2021-03-15 21:07:53 +01:00
|
|
|
defaultUnitTest := !inList("tradefed", j.properties.Libs) && !inList("cts", j.testProperties.Test_suites)
|
2021-03-05 19:08:36 +01:00
|
|
|
j.testProperties.Test_options.Unit_test = proptools.BoolPtr(defaultUnitTest)
|
|
|
|
}
|
2022-01-20 22:10:28 +01:00
|
|
|
|
2019-09-26 20:41:36 +02:00
|
|
|
j.testConfig = tradefed.AutoGenJavaTestConfig(ctx, j.testProperties.Test_config, j.testProperties.Test_config_template,
|
2022-01-20 22:10:28 +01:00
|
|
|
j.testProperties.Test_suites, configs, j.testProperties.Auto_gen_config, j.testProperties.Test_options.Unit_test)
|
2020-06-13 01:38:45 +02:00
|
|
|
|
2019-03-06 07:25:09 +01:00
|
|
|
j.data = android.PathsForModuleSrc(ctx, j.testProperties.Data)
|
2018-08-08 01:49:25 +02:00
|
|
|
|
2020-08-15 21:24:26 +02:00
|
|
|
j.extraTestConfigs = android.PathsForModuleSrc(ctx, j.testProperties.Test_options.Extra_test_configs)
|
|
|
|
|
2020-06-13 01:38:45 +02:00
|
|
|
ctx.VisitDirectDepsWithTag(dataNativeBinsTag, func(dep android.Module) {
|
|
|
|
j.data = append(j.data, android.OutputFileForModule(ctx, dep, ""))
|
|
|
|
})
|
|
|
|
|
2022-01-20 22:10:28 +01:00
|
|
|
ctx.VisitDirectDepsWithTag(dataDeviceBinsTag, func(dep android.Module) {
|
|
|
|
j.data = append(j.data, android.OutputFileForModule(ctx, dep, ""))
|
|
|
|
})
|
|
|
|
|
2021-01-26 20:01:43 +01:00
|
|
|
ctx.VisitDirectDepsWithTag(jniLibTag, func(dep android.Module) {
|
|
|
|
sharedLibInfo := ctx.OtherModuleProvider(dep, cc.SharedLibraryInfoProvider).(cc.SharedLibraryInfo)
|
|
|
|
if sharedLibInfo.SharedLibrary != nil {
|
|
|
|
// Copy to an intermediate output directory to append "lib[64]" to the path,
|
|
|
|
// so that it's compatible with the default rpath values.
|
|
|
|
var relPath string
|
|
|
|
if sharedLibInfo.Target.Arch.ArchType.Multilib == "lib64" {
|
|
|
|
relPath = filepath.Join("lib64", sharedLibInfo.SharedLibrary.Base())
|
|
|
|
} else {
|
|
|
|
relPath = filepath.Join("lib", sharedLibInfo.SharedLibrary.Base())
|
|
|
|
}
|
|
|
|
relocatedLib := android.PathForModuleOut(ctx, "relocated").Join(ctx, relPath)
|
|
|
|
ctx.Build(pctx, android.BuildParams{
|
|
|
|
Rule: android.Cp,
|
|
|
|
Input: sharedLibInfo.SharedLibrary,
|
|
|
|
Output: relocatedLib,
|
|
|
|
})
|
|
|
|
j.data = append(j.data, relocatedLib)
|
|
|
|
} else {
|
|
|
|
ctx.PropertyErrorf("jni_libs", "%q of type %q is not supported", dep.Name(), ctx.OtherModuleType(dep))
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
2018-08-08 01:49:25 +02:00
|
|
|
j.Library.GenerateAndroidBuildActions(ctx)
|
2018-04-10 03:40:24 +02:00
|
|
|
}
|
|
|
|
|
2019-03-20 13:45:53 +01:00
|
|
|
func (j *TestHelperLibrary) GenerateAndroidBuildActions(ctx android.ModuleContext) {
|
|
|
|
j.Library.GenerateAndroidBuildActions(ctx)
|
|
|
|
}
|
|
|
|
|
2019-12-03 19:06:47 +01:00
|
|
|
func (j *JavaTestImport) GenerateAndroidBuildActions(ctx android.ModuleContext) {
|
|
|
|
j.testConfig = tradefed.AutoGenJavaTestConfig(ctx, j.prebuiltTestProperties.Test_config, nil,
|
2022-01-20 22:10:28 +01:00
|
|
|
j.prebuiltTestProperties.Test_suites, nil, nil, nil)
|
2019-12-03 19:06:47 +01:00
|
|
|
|
|
|
|
j.Import.GenerateAndroidBuildActions(ctx)
|
|
|
|
}
|
|
|
|
|
|
|
|
type testSdkMemberType struct {
|
|
|
|
android.SdkMemberTypeBase
|
|
|
|
}
|
|
|
|
|
2021-07-14 11:29:36 +02:00
|
|
|
func (mt *testSdkMemberType) AddDependencies(ctx android.SdkDependencyContext, dependencyTag blueprint.DependencyTag, names []string) {
|
|
|
|
ctx.AddVariationDependencies(nil, dependencyTag, names...)
|
2019-12-03 19:06:47 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (mt *testSdkMemberType) IsInstance(module android.Module) bool {
|
|
|
|
_, ok := module.(*Test)
|
|
|
|
return ok
|
|
|
|
}
|
|
|
|
|
2020-03-19 17:11:18 +01:00
|
|
|
func (mt *testSdkMemberType) AddPrebuiltModule(ctx android.SdkMemberContext, member android.SdkMember) android.BpModule {
|
|
|
|
return ctx.SnapshotBuilder().AddPrebuiltModule(member, "java_test_import")
|
2020-03-02 12:33:02 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (mt *testSdkMemberType) CreateVariantPropertiesStruct() android.SdkMemberProperties {
|
|
|
|
return &testSdkMemberProperties{}
|
|
|
|
}
|
|
|
|
|
|
|
|
type testSdkMemberProperties struct {
|
|
|
|
android.SdkMemberPropertiesBase
|
2019-12-03 19:06:47 +01:00
|
|
|
|
2020-03-17 22:04:24 +01:00
|
|
|
JarToExport android.Path
|
|
|
|
TestConfig android.Path
|
2020-03-02 12:33:02 +01:00
|
|
|
}
|
|
|
|
|
2020-03-19 17:11:18 +01:00
|
|
|
func (p *testSdkMemberProperties) PopulateFromVariant(ctx android.SdkMemberContext, variant android.Module) {
|
2020-03-02 12:33:02 +01:00
|
|
|
test := variant.(*Test)
|
|
|
|
|
|
|
|
implementationJars := test.ImplementationJars()
|
2019-12-03 19:06:47 +01:00
|
|
|
if len(implementationJars) != 1 {
|
2020-03-02 12:33:02 +01:00
|
|
|
panic(fmt.Errorf("there must be only one implementation jar from %q", test.Name()))
|
2019-12-03 19:06:47 +01:00
|
|
|
}
|
|
|
|
|
2020-03-17 22:04:24 +01:00
|
|
|
p.JarToExport = implementationJars[0]
|
|
|
|
p.TestConfig = test.testConfig
|
2020-03-02 12:33:02 +01:00
|
|
|
}
|
|
|
|
|
2020-03-19 17:11:18 +01:00
|
|
|
func (p *testSdkMemberProperties) AddToPropertySet(ctx android.SdkMemberContext, propertySet android.BpPropertySet) {
|
2020-03-17 22:04:24 +01:00
|
|
|
builder := ctx.SnapshotBuilder()
|
2019-12-03 19:06:47 +01:00
|
|
|
|
2020-03-17 22:04:24 +01:00
|
|
|
exportedJar := p.JarToExport
|
|
|
|
if exportedJar != nil {
|
2022-07-15 15:12:35 +02:00
|
|
|
snapshotRelativeJavaLibPath := sdkSnapshotFilePathForJar(ctx, p.OsPrefix(), ctx.Name())
|
2020-03-17 22:04:24 +01:00
|
|
|
builder.CopyToSnapshot(exportedJar, snapshotRelativeJavaLibPath)
|
2019-12-03 19:06:47 +01:00
|
|
|
|
2020-03-02 12:33:02 +01:00
|
|
|
propertySet.AddProperty("jars", []string{snapshotRelativeJavaLibPath})
|
2020-03-17 22:04:24 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
testConfig := p.TestConfig
|
|
|
|
if testConfig != nil {
|
|
|
|
snapshotRelativeTestConfigPath := sdkSnapshotFilePathForMember(p.OsPrefix(), ctx.Name(), testConfigSuffix)
|
|
|
|
builder.CopyToSnapshot(testConfig, snapshotRelativeTestConfigPath)
|
2020-03-02 12:33:02 +01:00
|
|
|
propertySet.AddProperty("test_config", snapshotRelativeTestConfigPath)
|
|
|
|
}
|
2019-12-03 19:06:47 +01:00
|
|
|
}
|
|
|
|
|
2019-02-12 23:41:32 +01:00
|
|
|
// java_test builds a and links sources into a `.jar` file for the device, and possibly for the host as well, and
|
|
|
|
// creates an `AndroidTest.xml` file to allow running the test with `atest` or a `TEST_MAPPING` file.
|
|
|
|
//
|
|
|
|
// By default, a java_test has a single variant that produces a `.jar` file containing `classes.dex` files that were
|
|
|
|
// compiled against the device bootclasspath.
|
|
|
|
//
|
|
|
|
// Specifying `host_supported: true` will produce two variants, one compiled against the device bootclasspath and one
|
|
|
|
// compiled against the host bootclasspath.
|
2018-04-10 03:40:24 +02:00
|
|
|
func TestFactory() android.Module {
|
|
|
|
module := &Test{}
|
|
|
|
|
2020-06-16 01:09:53 +02:00
|
|
|
module.addHostAndDeviceProperties()
|
|
|
|
module.AddProperties(&module.testProperties)
|
2018-04-10 03:40:24 +02:00
|
|
|
|
2018-06-27 02:59:05 +02:00
|
|
|
module.Module.properties.Installable = proptools.BoolPtr(true)
|
2019-01-06 07:30:13 +01:00
|
|
|
module.Module.dexpreopter.isTest = true
|
2020-06-03 05:09:13 +02:00
|
|
|
module.Module.linter.test = true
|
2018-06-27 02:59:05 +02:00
|
|
|
|
2021-05-06 17:33:43 +02:00
|
|
|
android.InitSdkAwareModule(module)
|
2018-04-10 03:40:24 +02:00
|
|
|
InitJavaModule(module, android.HostAndDeviceSupported)
|
|
|
|
return module
|
|
|
|
}
|
|
|
|
|
2019-03-20 13:45:53 +01:00
|
|
|
// java_test_helper_library creates a java library and makes sure that it is added to the appropriate test suite.
|
|
|
|
func TestHelperLibraryFactory() android.Module {
|
|
|
|
module := &TestHelperLibrary{}
|
|
|
|
|
2020-06-16 01:09:53 +02:00
|
|
|
module.addHostAndDeviceProperties()
|
|
|
|
module.AddProperties(&module.testHelperLibraryProperties)
|
2019-03-20 13:45:53 +01:00
|
|
|
|
2019-04-24 22:19:28 +02:00
|
|
|
module.Module.properties.Installable = proptools.BoolPtr(true)
|
|
|
|
module.Module.dexpreopter.isTest = true
|
2020-06-03 05:09:13 +02:00
|
|
|
module.Module.linter.test = true
|
2019-04-24 22:19:28 +02:00
|
|
|
|
2019-03-20 13:45:53 +01:00
|
|
|
InitJavaModule(module, android.HostAndDeviceSupported)
|
|
|
|
return module
|
|
|
|
}
|
|
|
|
|
2019-12-03 19:06:47 +01:00
|
|
|
// java_test_import imports one or more `.jar` files into the build graph as if they were built by a java_test module
|
|
|
|
// and makes sure that it is added to the appropriate test suite.
|
|
|
|
//
|
|
|
|
// By default, a java_test_import has a single variant that expects a `.jar` file containing `.class` files that were
|
|
|
|
// compiled against an Android classpath.
|
|
|
|
//
|
|
|
|
// Specifying `host_supported: true` will produce two variants, one for use as a dependency of device modules and one
|
|
|
|
// for host modules.
|
|
|
|
func JavaTestImportFactory() android.Module {
|
|
|
|
module := &JavaTestImport{}
|
|
|
|
|
|
|
|
module.AddProperties(
|
|
|
|
&module.Import.properties,
|
|
|
|
&module.prebuiltTestProperties)
|
|
|
|
|
|
|
|
module.Import.properties.Installable = proptools.BoolPtr(true)
|
|
|
|
|
|
|
|
android.InitPrebuiltModule(module, &module.properties.Jars)
|
|
|
|
android.InitApexModule(module)
|
|
|
|
android.InitSdkAwareModule(module)
|
|
|
|
InitJavaModule(module, android.HostAndDeviceSupported)
|
|
|
|
return module
|
|
|
|
}
|
|
|
|
|
2019-02-12 23:41:32 +01:00
|
|
|
// java_test_host builds a and links sources into a `.jar` file for the host, and creates an `AndroidTest.xml` file to
|
|
|
|
// allow running the test with `atest` or a `TEST_MAPPING` file.
|
|
|
|
//
|
|
|
|
// A java_test_host has a single variant that produces a `.jar` file containing `.class` files that were
|
|
|
|
// compiled against the host bootclasspath.
|
2018-04-10 03:40:24 +02:00
|
|
|
func TestHostFactory() android.Module {
|
2020-06-13 01:38:45 +02:00
|
|
|
module := &TestHost{}
|
2018-04-10 03:40:24 +02:00
|
|
|
|
2020-06-16 01:09:53 +02:00
|
|
|
module.addHostProperties()
|
|
|
|
module.AddProperties(&module.testProperties)
|
2020-06-13 01:38:45 +02:00
|
|
|
module.AddProperties(&module.testHostProperties)
|
2018-04-10 03:40:24 +02:00
|
|
|
|
2021-03-04 22:47:56 +01:00
|
|
|
InitTestHost(
|
|
|
|
module,
|
|
|
|
proptools.BoolPtr(true),
|
|
|
|
nil,
|
|
|
|
nil)
|
2018-06-27 02:59:05 +02:00
|
|
|
|
2020-06-13 01:38:45 +02:00
|
|
|
InitJavaModuleMultiTargets(module, android.HostSupported)
|
2021-03-05 19:08:36 +01:00
|
|
|
|
2018-04-10 03:40:24 +02:00
|
|
|
return module
|
|
|
|
}
|
|
|
|
|
2021-03-04 22:47:56 +01:00
|
|
|
func InitTestHost(th *TestHost, installable *bool, testSuites []string, autoGenConfig *bool) {
|
|
|
|
th.properties.Installable = installable
|
|
|
|
th.testProperties.Auto_gen_config = autoGenConfig
|
|
|
|
th.testProperties.Test_suites = testSuites
|
|
|
|
}
|
|
|
|
|
2015-03-31 02:20:39 +02:00
|
|
|
//
|
|
|
|
// Java Binaries (.jar file plus wrapper script)
|
|
|
|
//
|
|
|
|
|
2017-07-20 00:53:04 +02:00
|
|
|
type binaryProperties struct {
|
2015-05-11 22:39:40 +02:00
|
|
|
// installable script to execute the resulting jar
|
2021-09-21 08:11:24 +02:00
|
|
|
Wrapper *string `android:"path,arch_variant"`
|
2018-10-18 00:10:48 +02:00
|
|
|
|
|
|
|
// Name of the class containing main to be inserted into the manifest as Main-Class.
|
|
|
|
Main_class *string
|
2020-10-10 04:00:54 +02:00
|
|
|
|
|
|
|
// Names of modules containing JNI libraries that should be installed alongside the host
|
|
|
|
// variant of the binary.
|
2021-09-21 08:11:24 +02:00
|
|
|
Jni_libs []string `android:"arch_variant"`
|
2015-05-11 22:39:40 +02:00
|
|
|
}
|
|
|
|
|
2017-07-20 00:53:04 +02:00
|
|
|
type Binary struct {
|
|
|
|
Library
|
2015-03-31 02:20:39 +02:00
|
|
|
|
2017-07-20 00:53:04 +02:00
|
|
|
binaryProperties binaryProperties
|
2017-08-11 02:09:43 +02:00
|
|
|
|
2017-12-05 22:42:45 +01:00
|
|
|
isWrapperVariant bool
|
|
|
|
|
2017-12-09 04:12:36 +01:00
|
|
|
wrapperFile android.Path
|
2019-10-02 07:05:35 +02:00
|
|
|
binaryFile android.InstallPath
|
2015-03-31 02:20:39 +02:00
|
|
|
}
|
|
|
|
|
2017-10-26 18:46:21 +02:00
|
|
|
func (j *Binary) HostToolPath() android.OptionalPath {
|
|
|
|
return android.OptionalPathForPath(j.binaryFile)
|
|
|
|
}
|
|
|
|
|
2017-07-20 00:53:04 +02:00
|
|
|
func (j *Binary) GenerateAndroidBuildActions(ctx android.ModuleContext) {
|
2017-12-05 22:42:45 +01:00
|
|
|
if ctx.Arch().ArchType == android.Common {
|
|
|
|
// Compile the jar
|
2018-10-18 00:10:48 +02:00
|
|
|
if j.binaryProperties.Main_class != nil {
|
|
|
|
if j.properties.Manifest != nil {
|
|
|
|
ctx.PropertyErrorf("main_class", "main_class cannot be used when manifest is set")
|
|
|
|
}
|
|
|
|
manifestFile := android.PathForModuleOut(ctx, "manifest.txt")
|
|
|
|
GenerateMainClassManifest(ctx, manifestFile, String(j.binaryProperties.Main_class))
|
|
|
|
j.overrideManifest = android.OptionalPathForPath(manifestFile)
|
|
|
|
}
|
|
|
|
|
2017-12-05 22:42:45 +01:00
|
|
|
j.Library.GenerateAndroidBuildActions(ctx)
|
2017-11-03 22:53:31 +01:00
|
|
|
} else {
|
2017-12-05 22:42:45 +01:00
|
|
|
// Handle the binary wrapper
|
|
|
|
j.isWrapperVariant = true
|
|
|
|
|
2017-12-12 01:29:02 +01:00
|
|
|
if j.binaryProperties.Wrapper != nil {
|
2019-03-06 07:25:09 +01:00
|
|
|
j.wrapperFile = android.PathForModuleSrc(ctx, *j.binaryProperties.Wrapper)
|
2017-12-05 22:42:45 +01:00
|
|
|
} else {
|
2021-09-21 08:11:24 +02:00
|
|
|
if ctx.Windows() {
|
|
|
|
ctx.PropertyErrorf("wrapper", "wrapper is required for Windows")
|
|
|
|
}
|
|
|
|
|
2017-12-05 22:42:45 +01:00
|
|
|
j.wrapperFile = android.PathForSource(ctx, "build/soong/scripts/jar-wrapper.sh")
|
|
|
|
}
|
|
|
|
|
2021-09-21 08:11:24 +02:00
|
|
|
ext := ""
|
|
|
|
if ctx.Windows() {
|
|
|
|
ext = ".bat"
|
|
|
|
}
|
|
|
|
|
2020-10-09 19:54:15 +02:00
|
|
|
// The host installation rules make the installed wrapper depend on all the dependencies
|
2020-10-10 04:00:54 +02:00
|
|
|
// of the wrapper variant, which will include the common variant's jar file and any JNI
|
|
|
|
// libraries. This is verified by TestBinary.
|
2017-12-05 22:42:45 +01:00
|
|
|
j.binaryFile = ctx.InstallExecutable(android.PathForModuleInstall(ctx, "bin"),
|
2021-09-21 08:11:24 +02:00
|
|
|
ctx.ModuleName()+ext, j.wrapperFile)
|
|
|
|
}
|
2015-03-31 02:20:39 +02:00
|
|
|
}
|
|
|
|
|
2017-07-20 00:53:04 +02:00
|
|
|
func (j *Binary) DepsMutator(ctx android.BottomUpMutatorContext) {
|
2022-04-26 15:38:20 +02:00
|
|
|
if ctx.Arch().ArchType == android.Common {
|
2017-12-05 22:42:45 +01:00
|
|
|
j.deps(ctx)
|
2021-01-26 15:18:53 +01:00
|
|
|
}
|
2022-04-26 15:38:20 +02:00
|
|
|
if ctx.Arch().ArchType != android.Common {
|
2020-11-11 03:12:15 +01:00
|
|
|
// These dependencies ensure the host installation rules will install the jar file and
|
|
|
|
// the jni libraries when the wrapper is installed.
|
|
|
|
ctx.AddVariationDependencies(nil, jniInstallTag, j.binaryProperties.Jni_libs...)
|
|
|
|
ctx.AddVariationDependencies(
|
|
|
|
[]blueprint.Variation{{Mutator: "arch", Variation: android.CommonArch.String()}},
|
|
|
|
binaryInstallTag, ctx.ModuleName())
|
2017-12-05 22:42:45 +01:00
|
|
|
}
|
2017-06-23 01:51:17 +02:00
|
|
|
}
|
|
|
|
|
2019-02-12 23:41:32 +01:00
|
|
|
// java_binary builds a `.jar` file and a shell script that executes it for the device, and possibly for the host
|
|
|
|
// as well.
|
|
|
|
//
|
|
|
|
// By default, a java_binary has a single variant that produces a `.jar` file containing `classes.dex` files that were
|
|
|
|
// compiled against the device bootclasspath.
|
|
|
|
//
|
|
|
|
// Specifying `host_supported: true` will produce two variants, one compiled against the device bootclasspath and one
|
|
|
|
// compiled against the host bootclasspath.
|
2017-07-20 00:53:04 +02:00
|
|
|
func BinaryFactory() android.Module {
|
|
|
|
module := &Binary{}
|
2015-03-31 02:20:39 +02:00
|
|
|
|
2020-06-16 01:09:53 +02:00
|
|
|
module.addHostAndDeviceProperties()
|
|
|
|
module.AddProperties(&module.binaryProperties)
|
2017-06-24 00:06:31 +02:00
|
|
|
|
2018-06-27 02:59:05 +02:00
|
|
|
module.Module.properties.Installable = proptools.BoolPtr(true)
|
|
|
|
|
2017-12-05 22:42:45 +01:00
|
|
|
android.InitAndroidArchModule(module, android.HostAndDeviceSupported, android.MultilibCommonFirst)
|
|
|
|
android.InitDefaultableModule(module)
|
2021-12-10 12:14:59 +01:00
|
|
|
android.InitBazelModule(module)
|
|
|
|
|
2017-06-24 00:06:31 +02:00
|
|
|
return module
|
2015-03-31 02:20:39 +02:00
|
|
|
}
|
|
|
|
|
2019-02-12 23:41:32 +01:00
|
|
|
// java_binary_host builds a `.jar` file and a shell script that executes it for the host.
|
|
|
|
//
|
|
|
|
// A java_binary_host has a single variant that produces a `.jar` file containing `.class` files that were
|
|
|
|
// compiled against the host bootclasspath.
|
2017-07-20 00:53:04 +02:00
|
|
|
func BinaryHostFactory() android.Module {
|
|
|
|
module := &Binary{}
|
2015-03-31 02:20:39 +02:00
|
|
|
|
2020-06-16 01:09:53 +02:00
|
|
|
module.addHostProperties()
|
|
|
|
module.AddProperties(&module.binaryProperties)
|
2017-06-24 00:06:31 +02:00
|
|
|
|
2018-06-27 02:59:05 +02:00
|
|
|
module.Module.properties.Installable = proptools.BoolPtr(true)
|
|
|
|
|
2017-12-05 22:42:45 +01:00
|
|
|
android.InitAndroidArchModule(module, android.HostSupported, android.MultilibCommonFirst)
|
|
|
|
android.InitDefaultableModule(module)
|
2021-12-10 12:14:59 +01:00
|
|
|
android.InitBazelModule(module)
|
2017-06-24 00:06:31 +02:00
|
|
|
return module
|
2015-03-31 02:20:39 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
// Java prebuilts
|
|
|
|
//
|
|
|
|
|
2017-08-02 20:05:49 +02:00
|
|
|
type ImportProperties struct {
|
2020-03-02 11:16:35 +01:00
|
|
|
Jars []string `android:"path,arch_variant"`
|
2017-10-20 22:59:18 +02:00
|
|
|
|
2021-04-02 02:38:25 +02:00
|
|
|
// The version of the SDK that the source prebuilt file was built against. Defaults to the
|
|
|
|
// current version if not specified.
|
2017-11-09 06:20:04 +01:00
|
|
|
Sdk_version *string
|
2017-10-21 02:57:49 +02:00
|
|
|
|
2021-04-02 02:38:25 +02:00
|
|
|
// The minimum version of the SDK that this module supports. Defaults to sdk_version if not
|
|
|
|
// specified.
|
|
|
|
Min_sdk_version *string
|
|
|
|
|
2022-05-17 22:21:50 +02:00
|
|
|
// The max sdk version placeholder used to replace maxSdkVersion attributes on permission
|
|
|
|
// and uses-permission tags in manifest_fixer.
|
|
|
|
Replace_max_sdk_version_placeholder *string
|
|
|
|
|
2017-10-21 02:57:49 +02:00
|
|
|
Installable *bool
|
2018-05-28 11:02:19 +02:00
|
|
|
|
2021-07-15 15:14:41 +02:00
|
|
|
// If not empty, classes are restricted to the specified packages and their sub-packages.
|
|
|
|
Permitted_packages []string
|
|
|
|
|
2018-05-28 11:02:19 +02:00
|
|
|
// List of shared java libs that this module has dependencies to
|
|
|
|
Libs []string
|
2018-07-12 21:28:41 +02:00
|
|
|
|
|
|
|
// List of files to remove from the jar file(s)
|
|
|
|
Exclude_files []string
|
|
|
|
|
|
|
|
// List of directories to remove from the jar file(s)
|
|
|
|
Exclude_dirs []string
|
2018-08-28 03:31:46 +02:00
|
|
|
|
|
|
|
// if set to true, run Jetifier against .jar file. Defaults to false.
|
2019-03-22 06:21:39 +01:00
|
|
|
Jetifier *bool
|
2019-10-21 07:53:15 +02:00
|
|
|
|
|
|
|
// set the name of the output
|
|
|
|
Stem *string
|
2020-03-24 08:44:11 +01:00
|
|
|
|
|
|
|
Aidl struct {
|
|
|
|
// directories that should be added as include directories for any aidl sources of modules
|
|
|
|
// that depend on this module, as well as to aidl for this module.
|
|
|
|
Export_include_dirs []string
|
|
|
|
}
|
2017-08-02 20:05:49 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
type Import struct {
|
2016-05-19 00:37:25 +02:00
|
|
|
android.ModuleBase
|
2018-10-02 22:53:33 +02:00
|
|
|
android.DefaultableModuleBase
|
2019-07-25 15:02:35 +02:00
|
|
|
android.ApexModuleBase
|
2022-01-28 17:12:52 +01:00
|
|
|
android.BazelModuleBase
|
2017-07-07 23:47:12 +02:00
|
|
|
prebuilt android.Prebuilt
|
Introduce module type 'sdk'
This change introduces a new module type named 'sdk'. It is a logical
group of prebuilt modules that together provide a context (e.g. APIs)
in which Mainline modules (such as APEXes) are built.
A prebuilt module (e.g. java_import) can join an sdk by adding it to the
sdk module as shown below:
sdk {
name: "mysdk#20",
java_libs: ["myjavalib_mysdk_20"],
}
java_import {
name: "myjavalib_mysdk_20",
srcs: ["myjavalib-v20.jar"],
sdk_member_name: "myjavalib",
}
sdk {
name: "mysdk#21",
java_libs: ["myjavalib_mysdk_21"],
}
java_import {
name: "myjavalib_mysdk_21",
srcs: ["myjavalib-v21.jar"],
sdk_member_name: "myjavalib",
}
java_library {
name: "myjavalib",
srcs: ["**/*/*.java"],
}
An APEX can specify the SDK(s) that it wants to build with via the new
'uses_sdks' property.
apex {
name: "myapex",
java_libs: ["libX", "libY"],
uses_sdks: ["mysdk#20"],
}
With this, libX, libY, and their transitive dependencies are all built
with the version 20 of myjavalib (the first java_import module) instead
of the other one (which is for version 21) and java_library having the
same name (which is for ToT).
Bug: 138182343
Test: m (sdk_test.go added)
Change-Id: I7e14c524a7d6a0d9f575fb20822080f39818c01e
2019-07-17 13:08:41 +02:00
|
|
|
android.SdkBase
|
2015-03-31 02:20:39 +02:00
|
|
|
|
2020-05-17 09:34:50 +02:00
|
|
|
// Functionality common to Module and Import.
|
|
|
|
embeddableInModuleAndImport
|
|
|
|
|
2020-08-06 00:40:41 +02:00
|
|
|
hiddenAPI
|
|
|
|
dexer
|
2020-12-24 01:13:04 +01:00
|
|
|
dexpreopter
|
2020-08-06 00:40:41 +02:00
|
|
|
|
2017-08-02 20:05:49 +02:00
|
|
|
properties ImportProperties
|
|
|
|
|
2020-08-06 00:40:41 +02:00
|
|
|
// output file containing classes.dex and resources
|
2021-09-15 04:34:04 +02:00
|
|
|
dexJarFile OptionalDexJarPath
|
2021-07-07 18:13:11 +02:00
|
|
|
dexJarInstallFile android.Path
|
2020-08-06 00:40:41 +02:00
|
|
|
|
2017-08-30 23:24:55 +02:00
|
|
|
combinedClasspathFile android.Path
|
2020-10-08 13:53:58 +02:00
|
|
|
classLoaderContexts dexpreopt.ClassLoaderContextMap
|
2020-03-24 08:44:11 +01:00
|
|
|
exportAidlIncludeDirs android.Paths
|
2020-09-16 03:30:11 +02:00
|
|
|
|
|
|
|
hideApexVariantFromMake bool
|
2015-03-31 02:20:39 +02:00
|
|
|
|
2021-04-02 01:45:46 +02:00
|
|
|
sdkVersion android.SdkSpec
|
|
|
|
minSdkVersion android.SdkSpec
|
2018-06-26 00:48:06 +02:00
|
|
|
}
|
|
|
|
|
2021-07-15 14:35:26 +02:00
|
|
|
var _ PermittedPackagesForUpdatableBootJars = (*Import)(nil)
|
|
|
|
|
|
|
|
func (j *Import) PermittedPackagesForUpdatableBootJars() []string {
|
|
|
|
return j.properties.Permitted_packages
|
|
|
|
}
|
|
|
|
|
2021-04-02 01:45:46 +02:00
|
|
|
func (j *Import) SdkVersion(ctx android.EarlyModuleContext) android.SdkSpec {
|
|
|
|
return android.SdkSpecFrom(ctx, String(j.properties.Sdk_version))
|
2020-08-12 23:42:30 +02:00
|
|
|
}
|
|
|
|
|
2021-03-29 13:11:58 +02:00
|
|
|
func (j *Import) SystemModules() string {
|
2020-08-06 00:40:41 +02:00
|
|
|
return "none"
|
|
|
|
}
|
|
|
|
|
2021-04-02 01:45:46 +02:00
|
|
|
func (j *Import) MinSdkVersion(ctx android.EarlyModuleContext) android.SdkSpec {
|
2021-04-02 02:38:25 +02:00
|
|
|
if j.properties.Min_sdk_version != nil {
|
2021-04-02 01:45:46 +02:00
|
|
|
return android.SdkSpecFrom(ctx, *j.properties.Min_sdk_version)
|
2021-04-02 02:38:25 +02:00
|
|
|
}
|
2021-04-02 01:45:46 +02:00
|
|
|
return j.SdkVersion(ctx)
|
2018-06-26 00:48:06 +02:00
|
|
|
}
|
|
|
|
|
2022-05-17 22:21:50 +02:00
|
|
|
func (j *Import) ReplaceMaxSdkVersionPlaceholder(ctx android.EarlyModuleContext) android.SdkSpec {
|
|
|
|
if j.properties.Replace_max_sdk_version_placeholder != nil {
|
|
|
|
return android.SdkSpecFrom(ctx, *j.properties.Replace_max_sdk_version_placeholder)
|
|
|
|
}
|
|
|
|
return android.SdkSpecFrom(ctx, "")
|
|
|
|
}
|
|
|
|
|
2021-04-02 01:45:46 +02:00
|
|
|
func (j *Import) TargetSdkVersion(ctx android.EarlyModuleContext) android.SdkSpec {
|
|
|
|
return j.SdkVersion(ctx)
|
2020-04-27 19:53:18 +02:00
|
|
|
}
|
|
|
|
|
2017-08-02 20:05:49 +02:00
|
|
|
func (j *Import) Prebuilt() *android.Prebuilt {
|
2017-07-07 23:47:12 +02:00
|
|
|
return &j.prebuilt
|
|
|
|
}
|
|
|
|
|
2017-08-02 20:05:49 +02:00
|
|
|
func (j *Import) PrebuiltSrcs() []string {
|
|
|
|
return j.properties.Jars
|
|
|
|
}
|
|
|
|
|
|
|
|
func (j *Import) Name() string {
|
2017-07-28 00:41:32 +02:00
|
|
|
return j.prebuilt.Name(j.ModuleBase.Name())
|
|
|
|
}
|
|
|
|
|
2019-10-29 03:23:10 +01:00
|
|
|
func (j *Import) Stem() string {
|
|
|
|
return proptools.StringDefault(j.properties.Stem, j.ModuleBase.Name())
|
|
|
|
}
|
|
|
|
|
2020-01-08 05:35:43 +01:00
|
|
|
func (a *Import) JacocoReportClassesFile() android.Path {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2021-01-11 19:58:54 +01:00
|
|
|
func (j *Import) LintDepSets() LintDepSets {
|
|
|
|
return LintDepSets{}
|
|
|
|
}
|
|
|
|
|
2021-05-11 00:30:00 +02:00
|
|
|
func (j *Import) getStrictUpdatabilityLinting() bool {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
func (j *Import) setStrictUpdatabilityLinting(bool) {
|
|
|
|
}
|
|
|
|
|
2017-08-02 20:05:49 +02:00
|
|
|
func (j *Import) DepsMutator(ctx android.BottomUpMutatorContext) {
|
2018-08-29 23:10:52 +02:00
|
|
|
ctx.AddVariationDependencies(nil, libTag, j.properties.Libs...)
|
2020-08-06 00:40:41 +02:00
|
|
|
|
|
|
|
if ctx.Device() && Bool(j.dexProperties.Compile_dex) {
|
2021-03-29 13:11:58 +02:00
|
|
|
sdkDeps(ctx, android.SdkContext(j), j.dexer)
|
2020-08-06 00:40:41 +02:00
|
|
|
}
|
2016-10-12 23:38:15 +02:00
|
|
|
}
|
|
|
|
|
2017-08-02 20:05:49 +02:00
|
|
|
func (j *Import) GenerateAndroidBuildActions(ctx android.ModuleContext) {
|
2021-04-02 01:45:46 +02:00
|
|
|
j.sdkVersion = j.SdkVersion(ctx)
|
|
|
|
j.minSdkVersion = j.MinSdkVersion(ctx)
|
|
|
|
|
2020-09-16 03:30:11 +02:00
|
|
|
if !ctx.Provider(android.ApexInfoProvider).(android.ApexInfo).IsForPlatform() {
|
|
|
|
j.hideApexVariantFromMake = true
|
|
|
|
}
|
|
|
|
|
2021-09-21 08:11:24 +02:00
|
|
|
if ctx.Windows() {
|
|
|
|
j.HideFromMake()
|
|
|
|
}
|
|
|
|
|
2019-03-06 07:25:09 +01:00
|
|
|
jars := android.PathsForModuleSrc(ctx, j.properties.Jars)
|
2017-08-02 20:05:49 +02:00
|
|
|
|
2019-10-29 03:23:10 +01:00
|
|
|
jarName := j.Stem() + ".jar"
|
2018-08-28 03:31:46 +02:00
|
|
|
outputFile := android.PathForModuleOut(ctx, "combined", jarName)
|
2018-07-12 21:28:41 +02:00
|
|
|
TransformJarsToJar(ctx, outputFile, "for prebuilts", jars, android.OptionalPath{},
|
|
|
|
false, j.properties.Exclude_files, j.properties.Exclude_dirs)
|
2019-03-22 06:21:39 +01:00
|
|
|
if Bool(j.properties.Jetifier) {
|
2018-08-28 03:31:46 +02:00
|
|
|
inputFile := outputFile
|
|
|
|
outputFile = android.PathForModuleOut(ctx, "jetifier", jarName)
|
|
|
|
TransformJetifier(ctx, outputFile, inputFile)
|
|
|
|
}
|
2017-10-17 02:09:48 +02:00
|
|
|
j.combinedClasspathFile = outputFile
|
2020-10-08 13:53:58 +02:00
|
|
|
j.classLoaderContexts = make(dexpreopt.ClassLoaderContextMap)
|
2020-05-15 11:20:31 +02:00
|
|
|
|
2020-08-06 00:40:41 +02:00
|
|
|
var flags javaBuilderFlags
|
|
|
|
|
2018-05-28 11:02:19 +02:00
|
|
|
ctx.VisitDirectDeps(func(module android.Module) {
|
|
|
|
tag := ctx.OtherModuleDependencyTag(module)
|
|
|
|
|
2021-02-01 22:59:03 +01:00
|
|
|
if ctx.OtherModuleHasProvider(module, JavaInfoProvider) {
|
|
|
|
dep := ctx.OtherModuleProvider(module, JavaInfoProvider).(JavaInfo)
|
2018-05-28 11:02:19 +02:00
|
|
|
switch tag {
|
2022-03-17 19:12:32 +01:00
|
|
|
case libTag:
|
|
|
|
flags.classpath = append(flags.classpath, dep.HeaderJars...)
|
|
|
|
flags.dexClasspath = append(flags.dexClasspath, dep.HeaderJars...)
|
|
|
|
case staticLibTag:
|
2021-02-01 22:59:03 +01:00
|
|
|
flags.classpath = append(flags.classpath, dep.HeaderJars...)
|
2020-08-06 00:40:41 +02:00
|
|
|
case bootClasspathTag:
|
2021-02-01 22:59:03 +01:00
|
|
|
flags.bootClasspath = append(flags.bootClasspath, dep.HeaderJars...)
|
2018-05-28 11:02:19 +02:00
|
|
|
}
|
2021-02-01 22:59:03 +01:00
|
|
|
} else if dep, ok := module.(SdkLibraryDependency); ok {
|
2018-05-28 11:02:19 +02:00
|
|
|
switch tag {
|
|
|
|
case libTag:
|
2021-04-02 01:45:46 +02:00
|
|
|
flags.classpath = append(flags.classpath, dep.SdkHeaderJars(ctx, j.SdkVersion(ctx))...)
|
2018-05-28 11:02:19 +02:00
|
|
|
}
|
|
|
|
}
|
2020-12-03 17:50:22 +01:00
|
|
|
|
2020-12-16 17:16:11 +01:00
|
|
|
addCLCFromDep(ctx, module, j.classLoaderContexts)
|
2018-05-28 11:02:19 +02:00
|
|
|
})
|
|
|
|
|
2018-08-10 22:42:12 +02:00
|
|
|
if Bool(j.properties.Installable) {
|
2021-11-03 22:08:20 +01:00
|
|
|
var installDir android.InstallPath
|
|
|
|
if ctx.InstallInTestcases() {
|
|
|
|
var archDir string
|
|
|
|
if !ctx.Host() {
|
|
|
|
archDir = ctx.DeviceConfig().DeviceArch()
|
|
|
|
}
|
|
|
|
installDir = android.PathForModuleInstall(ctx, ctx.ModuleName(), archDir)
|
|
|
|
} else {
|
|
|
|
installDir = android.PathForModuleInstall(ctx, "framework")
|
|
|
|
}
|
|
|
|
ctx.InstallFile(installDir, jarName, outputFile)
|
2018-08-10 22:42:12 +02:00
|
|
|
}
|
2020-03-24 08:44:11 +01:00
|
|
|
|
|
|
|
j.exportAidlIncludeDirs = android.PathsForModuleSrc(ctx, j.properties.Aidl.Export_include_dirs)
|
2020-08-06 00:40:41 +02:00
|
|
|
|
2020-11-02 18:32:38 +01:00
|
|
|
if ctx.Device() {
|
|
|
|
// If this is a variant created for a prebuilt_apex then use the dex implementation jar
|
|
|
|
// obtained from the associated deapexer module.
|
|
|
|
ai := ctx.Provider(android.ApexInfoProvider).(android.ApexInfo)
|
|
|
|
if ai.ForPrebuiltApex {
|
|
|
|
// Get the path of the dex implementation jar from the `deapexer` module.
|
2021-09-17 02:44:12 +02:00
|
|
|
di := android.FindDeapexerProviderForModule(ctx)
|
|
|
|
if di == nil {
|
|
|
|
return // An error has been reported by FindDeapexerProviderForModule.
|
|
|
|
}
|
2021-06-17 16:59:07 +02:00
|
|
|
if dexOutputPath := di.PrebuiltExportPath(apexRootRelativePathToJavaLib(j.BaseModuleName())); dexOutputPath != nil {
|
2021-09-15 04:34:04 +02:00
|
|
|
dexJarFile := makeDexJarPathFromPath(dexOutputPath)
|
|
|
|
j.dexJarFile = dexJarFile
|
2021-09-30 11:32:57 +02:00
|
|
|
installPath := android.PathForModuleInPartitionInstall(ctx, "apex", ai.ApexVariationName, apexRootRelativePathToJavaLib(j.BaseModuleName()))
|
|
|
|
j.dexJarInstallFile = installPath
|
2021-05-14 15:18:47 +02:00
|
|
|
|
2021-09-30 11:32:57 +02:00
|
|
|
j.dexpreopter.installPath = j.dexpreopter.getInstallPath(ctx, installPath)
|
2021-10-11 05:05:20 +02:00
|
|
|
setUncompressDex(ctx, &j.dexpreopter, &j.dexer)
|
2021-09-30 11:32:57 +02:00
|
|
|
j.dexpreopter.uncompressedDex = *j.dexProperties.Uncompress_dex
|
|
|
|
j.dexpreopt(ctx, dexOutputPath)
|
2021-10-11 05:05:20 +02:00
|
|
|
|
|
|
|
// Initialize the hiddenapi structure.
|
|
|
|
j.initHiddenAPI(ctx, dexJarFile, outputFile, j.dexProperties.Uncompress_dex)
|
2021-02-03 21:06:33 +01:00
|
|
|
} else {
|
2020-11-02 18:32:38 +01:00
|
|
|
// This should never happen as a variant for a prebuilt_apex is only created if the
|
|
|
|
// prebuilt_apex has been configured to export the java library dex file.
|
2021-09-17 02:44:12 +02:00
|
|
|
ctx.ModuleErrorf("internal error: no dex implementation jar available from prebuilt APEX %s", di.ApexModuleName())
|
2020-11-02 18:32:38 +01:00
|
|
|
}
|
|
|
|
} else if Bool(j.dexProperties.Compile_dex) {
|
2021-03-29 13:11:58 +02:00
|
|
|
sdkDep := decodeSdkDep(ctx, android.SdkContext(j))
|
2020-11-02 18:32:38 +01:00
|
|
|
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...)
|
|
|
|
}
|
2020-12-24 01:13:04 +01:00
|
|
|
|
2020-11-02 18:32:38 +01:00
|
|
|
// Dex compilation
|
2020-12-24 01:13:04 +01:00
|
|
|
|
2021-09-16 08:15:39 +02:00
|
|
|
j.dexpreopter.installPath = j.dexpreopter.getInstallPath(
|
|
|
|
ctx, android.PathForModuleInstall(ctx, "framework", jarName))
|
2021-10-11 05:05:20 +02:00
|
|
|
setUncompressDex(ctx, &j.dexpreopter, &j.dexer)
|
2020-11-02 18:32:38 +01:00
|
|
|
j.dexpreopter.uncompressedDex = *j.dexProperties.Uncompress_dex
|
2020-08-06 00:40:41 +02:00
|
|
|
|
2021-02-02 14:38:13 +01:00
|
|
|
var dexOutputFile android.OutputPath
|
2021-04-02 01:45:46 +02:00
|
|
|
dexOutputFile = j.dexer.compileDex(ctx, flags, j.MinSdkVersion(ctx), outputFile, jarName)
|
2020-11-02 18:32:38 +01:00
|
|
|
if ctx.Failed() {
|
|
|
|
return
|
|
|
|
}
|
2020-08-06 00:40:41 +02:00
|
|
|
|
2021-05-14 15:18:47 +02:00
|
|
|
// Initialize the hiddenapi structure.
|
2021-09-15 04:34:04 +02:00
|
|
|
j.initHiddenAPI(ctx, makeDexJarPathFromPath(dexOutputFile), outputFile, j.dexProperties.Uncompress_dex)
|
2021-05-14 14:04:04 +02:00
|
|
|
|
|
|
|
// Encode hidden API flags in dex file.
|
2021-05-14 16:52:25 +02:00
|
|
|
dexOutputFile = j.hiddenAPIEncodeDex(ctx, dexOutputFile)
|
2020-11-02 18:32:38 +01:00
|
|
|
|
2021-09-15 04:34:04 +02:00
|
|
|
j.dexJarFile = makeDexJarPathFromPath(dexOutputFile)
|
2021-07-07 18:13:11 +02:00
|
|
|
j.dexJarInstallFile = android.PathForModuleInstall(ctx, "framework", jarName)
|
2020-11-02 18:32:38 +01:00
|
|
|
}
|
2020-08-06 00:40:41 +02:00
|
|
|
}
|
2021-02-01 22:59:03 +01:00
|
|
|
|
|
|
|
ctx.SetProvider(JavaInfoProvider, JavaInfo{
|
|
|
|
HeaderJars: android.PathsIfNonNil(j.combinedClasspathFile),
|
|
|
|
ImplementationAndResourcesJars: android.PathsIfNonNil(j.combinedClasspathFile),
|
|
|
|
ImplementationJars: android.PathsIfNonNil(j.combinedClasspathFile),
|
|
|
|
AidlIncludeDirs: j.exportAidlIncludeDirs,
|
|
|
|
})
|
2015-03-31 02:20:39 +02:00
|
|
|
}
|
|
|
|
|
2020-10-06 18:20:13 +02:00
|
|
|
func (j *Import) OutputFiles(tag string) (android.Paths, error) {
|
|
|
|
switch tag {
|
2020-10-15 19:54:40 +02:00
|
|
|
case "", ".jar":
|
2020-10-06 18:20:13 +02:00
|
|
|
return android.Paths{j.combinedClasspathFile}, nil
|
|
|
|
default:
|
|
|
|
return nil, fmt.Errorf("unsupported module reference tag %q", tag)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
var _ android.OutputFileProducer = (*Import)(nil)
|
|
|
|
|
2017-10-19 22:06:22 +02:00
|
|
|
func (j *Import) HeaderJars() android.Paths {
|
2018-12-25 07:35:23 +01:00
|
|
|
if j.combinedClasspathFile == nil {
|
|
|
|
return nil
|
|
|
|
}
|
2018-07-12 21:28:41 +02:00
|
|
|
return android.Paths{j.combinedClasspathFile}
|
2017-10-19 22:06:22 +02:00
|
|
|
}
|
|
|
|
|
2018-08-16 05:40:52 +02:00
|
|
|
func (j *Import) ImplementationAndResourcesJars() android.Paths {
|
2018-12-25 07:35:23 +01:00
|
|
|
if j.combinedClasspathFile == nil {
|
|
|
|
return nil
|
|
|
|
}
|
2018-08-16 05:40:52 +02:00
|
|
|
return android.Paths{j.combinedClasspathFile}
|
|
|
|
}
|
|
|
|
|
2021-09-15 04:34:04 +02:00
|
|
|
func (j *Import) DexJarBuildPath() OptionalDexJarPath {
|
2020-08-06 00:40:41 +02:00
|
|
|
return j.dexJarFile
|
2019-01-31 23:12:44 +01:00
|
|
|
}
|
|
|
|
|
2020-06-09 15:31:19 +02:00
|
|
|
func (j *Import) DexJarInstallPath() android.Path {
|
2021-07-07 18:13:11 +02:00
|
|
|
return j.dexJarInstallFile
|
2020-06-09 15:31:19 +02:00
|
|
|
}
|
|
|
|
|
2020-10-08 13:53:58 +02:00
|
|
|
func (j *Import) ClassLoaderContexts() dexpreopt.ClassLoaderContextMap {
|
|
|
|
return j.classLoaderContexts
|
2018-05-28 11:02:19 +02:00
|
|
|
}
|
|
|
|
|
2020-12-15 14:29:02 +01:00
|
|
|
var _ android.ApexModule = (*Import)(nil)
|
|
|
|
|
|
|
|
// Implements android.ApexModule
|
apex_available tracks static dependencies
This change fixes a bug that apex_available is not enforced for static
dependencies. For example, a module with 'apex_available:
["//apex_available:platform"]' was able to be statically linked to any
APEX. This was happening because the check was done on the modules that
are actually installed to an APEX. Static dependencies of the modules
were not counted as they are not installed to the APEX as files.
Fixing this bug by doing the check by traversing the tree in the method
checkApexAvailability.
This change includes a few number of related changes:
1) DepIsInSameApex implementation for cc.Module was changed as well.
Previuosly, it returned false only when the dependency is actually a
stub variant of a lib. Now, it returns false when the dependency has one
or more stub variants. To understand why, we need to recall that when
there is a dependency to a lib having stubs, we actually create two
dependencies: to the non-stub variant and to the stub variant during the
DepsMutator phase. And later in the build action generation phase, we
choose one of them depending on the context. Also recall that an APEX
variant is created only when DepIsInSameApex returns true. Given these,
with the previous implementatin of DepIsInSameApex, we did create apex
variants of the non-stub variant of the dependency, while not creating
the apex variant for the stub variant. This is not right; we needlessly
created the apex variant. The extra apex variant has caused no harm so
far, but since the apex_available check became more correct, it actually
breaks the build. To fix the issue, we stop creating the APEX variant
both for non-stub and stub variants.
2) platform variant is created regardless of the apex_available value.
This is required for the case when a library X that provides stub is in
an APEX A and is configured to be available only for A. In that case,
libs in other APEX can't use the stub library since the stub library is
mutated only for apex A. By creating the platform variant for the stub
library, it can be used from outside as the default dependency variation
is set to the platform variant when creating the APEX variations.
3) The ApexAvailableWhitelist is added with the dependencies that were
revealed with this change.
Exempt-From-Owner-Approval: cherry-pick from internal
Bug: 147671264
Test: m
Merged-In: Iaedc05494085ff4e8af227a6392bdd0c338b8e6e
(cherry picked from commit fa89944c79f19552e906b41fd03a4981903eee7e)
Change-Id: Iaedc05494085ff4e8af227a6392bdd0c338b8e6e
2020-01-30 18:49:53 +01:00
|
|
|
func (j *Import) DepIsInSameApex(ctx android.BaseModuleContext, dep android.Module) bool {
|
2020-05-17 09:34:50 +02:00
|
|
|
return j.depIsInSameApex(ctx, dep)
|
apex_available tracks static dependencies
This change fixes a bug that apex_available is not enforced for static
dependencies. For example, a module with 'apex_available:
["//apex_available:platform"]' was able to be statically linked to any
APEX. This was happening because the check was done on the modules that
are actually installed to an APEX. Static dependencies of the modules
were not counted as they are not installed to the APEX as files.
Fixing this bug by doing the check by traversing the tree in the method
checkApexAvailability.
This change includes a few number of related changes:
1) DepIsInSameApex implementation for cc.Module was changed as well.
Previuosly, it returned false only when the dependency is actually a
stub variant of a lib. Now, it returns false when the dependency has one
or more stub variants. To understand why, we need to recall that when
there is a dependency to a lib having stubs, we actually create two
dependencies: to the non-stub variant and to the stub variant during the
DepsMutator phase. And later in the build action generation phase, we
choose one of them depending on the context. Also recall that an APEX
variant is created only when DepIsInSameApex returns true. Given these,
with the previous implementatin of DepIsInSameApex, we did create apex
variants of the non-stub variant of the dependency, while not creating
the apex variant for the stub variant. This is not right; we needlessly
created the apex variant. The extra apex variant has caused no harm so
far, but since the apex_available check became more correct, it actually
breaks the build. To fix the issue, we stop creating the APEX variant
both for non-stub and stub variants.
2) platform variant is created regardless of the apex_available value.
This is required for the case when a library X that provides stub is in
an APEX A and is configured to be available only for A. In that case,
libs in other APEX can't use the stub library since the stub library is
mutated only for apex A. By creating the platform variant for the stub
library, it can be used from outside as the default dependency variation
is set to the platform variant when creating the APEX variations.
3) The ApexAvailableWhitelist is added with the dependencies that were
revealed with this change.
Exempt-From-Owner-Approval: cherry-pick from internal
Bug: 147671264
Test: m
Merged-In: Iaedc05494085ff4e8af227a6392bdd0c338b8e6e
(cherry picked from commit fa89944c79f19552e906b41fd03a4981903eee7e)
Change-Id: Iaedc05494085ff4e8af227a6392bdd0c338b8e6e
2020-01-30 18:49:53 +01:00
|
|
|
}
|
|
|
|
|
2020-12-15 14:29:02 +01:00
|
|
|
// Implements android.ApexModule
|
2020-07-23 07:32:17 +02:00
|
|
|
func (j *Import) ShouldSupportSdkVersion(ctx android.BaseModuleContext,
|
|
|
|
sdkVersion android.ApiLevel) error {
|
2021-04-02 01:45:46 +02:00
|
|
|
sdkSpec := j.MinSdkVersion(ctx)
|
2021-03-29 13:11:58 +02:00
|
|
|
if !sdkSpec.Specified() {
|
2021-04-02 02:38:25 +02:00
|
|
|
return fmt.Errorf("min_sdk_version is not specified")
|
|
|
|
}
|
2021-03-29 13:11:58 +02:00
|
|
|
if sdkSpec.Kind == android.SdkCore {
|
2021-04-02 02:38:25 +02:00
|
|
|
return nil
|
|
|
|
}
|
2021-06-23 03:23:16 +02:00
|
|
|
if sdkSpec.ApiLevel.GreaterThan(sdkVersion) {
|
|
|
|
return fmt.Errorf("newer SDK(%v)", sdkSpec.ApiLevel)
|
2021-04-02 02:38:25 +02:00
|
|
|
}
|
2020-04-15 04:03:39 +02:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2021-06-17 15:56:05 +02:00
|
|
|
// requiredFilesFromPrebuiltApexForImport returns information about the files that a java_import or
|
|
|
|
// java_sdk_library_import with the specified base module name requires to be exported from a
|
|
|
|
// prebuilt_apex/apex_set.
|
2021-06-17 16:59:07 +02:00
|
|
|
func requiredFilesFromPrebuiltApexForImport(name string) []string {
|
|
|
|
// Add the dex implementation jar to the set of exported files.
|
|
|
|
return []string{
|
|
|
|
apexRootRelativePathToJavaLib(name),
|
2021-06-17 15:56:05 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-06-17 16:59:07 +02:00
|
|
|
// apexRootRelativePathToJavaLib returns the path, relative to the root of the apex's contents, for
|
|
|
|
// the java library with the specified name.
|
|
|
|
func apexRootRelativePathToJavaLib(name string) string {
|
|
|
|
return filepath.Join("javalib", name+".jar")
|
|
|
|
}
|
|
|
|
|
2021-06-17 15:56:05 +02:00
|
|
|
var _ android.RequiredFilesFromPrebuiltApex = (*Import)(nil)
|
|
|
|
|
2021-06-17 16:59:07 +02:00
|
|
|
func (j *Import) RequiredFilesFromPrebuiltApex(_ android.BaseModuleContext) []string {
|
2021-06-17 15:56:05 +02:00
|
|
|
name := j.BaseModuleName()
|
|
|
|
return requiredFilesFromPrebuiltApexForImport(name)
|
|
|
|
}
|
|
|
|
|
2018-12-25 07:35:23 +01:00
|
|
|
// Add compile time check for interface implementation
|
|
|
|
var _ android.IDEInfo = (*Import)(nil)
|
|
|
|
var _ android.IDECustomizedModuleName = (*Import)(nil)
|
|
|
|
|
2018-08-16 00:35:38 +02:00
|
|
|
// Collect information for opening IDE project files in java/jdeps.go.
|
|
|
|
|
|
|
|
func (j *Import) IDEInfo(dpInfo *android.IdeInfo) {
|
|
|
|
dpInfo.Jars = append(dpInfo.Jars, j.PrebuiltSrcs()...)
|
|
|
|
}
|
|
|
|
|
|
|
|
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.
|
2021-07-14 17:35:33 +02:00
|
|
|
return android.RemoveOptionalPrebuiltPrefix(j.Name())
|
2018-08-16 00:35:38 +02:00
|
|
|
}
|
|
|
|
|
2017-08-02 20:05:49 +02:00
|
|
|
var _ android.PrebuiltInterface = (*Import)(nil)
|
2015-03-31 02:20:39 +02:00
|
|
|
|
2020-12-24 01:13:04 +01:00
|
|
|
func (j *Import) IsInstallable() bool {
|
|
|
|
return Bool(j.properties.Installable)
|
|
|
|
}
|
|
|
|
|
2021-09-16 08:15:39 +02:00
|
|
|
var _ DexpreopterInterface = (*Import)(nil)
|
2020-12-24 01:13:04 +01:00
|
|
|
|
2019-02-12 23:41:32 +01:00
|
|
|
// java_import imports one or more `.jar` files into the build graph as if they were built by a java_library module.
|
|
|
|
//
|
|
|
|
// By default, a java_import has a single variant that expects a `.jar` file containing `.class` files that were
|
|
|
|
// compiled against an Android classpath.
|
|
|
|
//
|
|
|
|
// Specifying `host_supported: true` will produce two variants, one for use as a dependency of device modules and one
|
|
|
|
// for host modules.
|
2017-08-02 20:05:49 +02:00
|
|
|
func ImportFactory() android.Module {
|
|
|
|
module := &Import{}
|
2017-06-24 00:06:31 +02:00
|
|
|
|
2020-08-06 00:40:41 +02:00
|
|
|
module.AddProperties(
|
|
|
|
&module.properties,
|
|
|
|
&module.dexer.dexProperties,
|
|
|
|
)
|
2017-08-02 20:05:49 +02:00
|
|
|
|
2021-06-23 12:39:47 +02:00
|
|
|
module.initModuleAndImport(module)
|
2020-05-15 11:20:31 +02:00
|
|
|
|
2020-08-06 00:40:41 +02:00
|
|
|
module.dexProperties.Optimize.EnabledByDefault = false
|
|
|
|
|
2017-08-02 20:05:49 +02:00
|
|
|
android.InitPrebuiltModule(module, &module.properties.Jars)
|
2019-07-25 15:02:35 +02:00
|
|
|
android.InitApexModule(module)
|
Introduce module type 'sdk'
This change introduces a new module type named 'sdk'. It is a logical
group of prebuilt modules that together provide a context (e.g. APIs)
in which Mainline modules (such as APEXes) are built.
A prebuilt module (e.g. java_import) can join an sdk by adding it to the
sdk module as shown below:
sdk {
name: "mysdk#20",
java_libs: ["myjavalib_mysdk_20"],
}
java_import {
name: "myjavalib_mysdk_20",
srcs: ["myjavalib-v20.jar"],
sdk_member_name: "myjavalib",
}
sdk {
name: "mysdk#21",
java_libs: ["myjavalib_mysdk_21"],
}
java_import {
name: "myjavalib_mysdk_21",
srcs: ["myjavalib-v21.jar"],
sdk_member_name: "myjavalib",
}
java_library {
name: "myjavalib",
srcs: ["**/*/*.java"],
}
An APEX can specify the SDK(s) that it wants to build with via the new
'uses_sdks' property.
apex {
name: "myapex",
java_libs: ["libX", "libY"],
uses_sdks: ["mysdk#20"],
}
With this, libX, libY, and their transitive dependencies are all built
with the version 20 of myjavalib (the first java_import module) instead
of the other one (which is for version 21) and java_library having the
same name (which is for ToT).
Bug: 138182343
Test: m (sdk_test.go added)
Change-Id: I7e14c524a7d6a0d9f575fb20822080f39818c01e
2019-07-17 13:08:41 +02:00
|
|
|
android.InitSdkAwareModule(module)
|
2022-01-28 17:12:52 +01:00
|
|
|
android.InitBazelModule(module)
|
2019-11-13 02:50:48 +01:00
|
|
|
InitJavaModule(module, android.HostAndDeviceSupported)
|
2017-06-24 00:06:31 +02:00
|
|
|
return module
|
2015-03-31 02:20:39 +02:00
|
|
|
}
|
|
|
|
|
2019-02-12 23:41:32 +01:00
|
|
|
// java_import imports one or more `.jar` files into the build graph as if they were built by a java_library_host
|
|
|
|
// module.
|
|
|
|
//
|
|
|
|
// A java_import_host has a single variant that expects a `.jar` file containing `.class` files that were
|
|
|
|
// compiled against a host bootclasspath.
|
2017-08-02 20:05:49 +02:00
|
|
|
func ImportFactoryHost() android.Module {
|
|
|
|
module := &Import{}
|
|
|
|
|
|
|
|
module.AddProperties(&module.properties)
|
|
|
|
|
|
|
|
android.InitPrebuiltModule(module, &module.properties.Jars)
|
2019-07-25 15:02:35 +02:00
|
|
|
android.InitApexModule(module)
|
2022-02-28 19:50:56 +01:00
|
|
|
android.InitBazelModule(module)
|
2019-11-13 02:50:48 +01:00
|
|
|
InitJavaModule(module, android.HostSupported)
|
2017-08-02 20:05:49 +02:00
|
|
|
return module
|
|
|
|
}
|
|
|
|
|
2019-02-22 03:12:14 +01:00
|
|
|
// dex_import module
|
|
|
|
|
|
|
|
type DexImportProperties struct {
|
2019-07-15 22:36:55 +02:00
|
|
|
Jars []string `android:"path"`
|
2019-10-21 07:53:15 +02:00
|
|
|
|
|
|
|
// set the name of the output
|
|
|
|
Stem *string
|
2019-02-22 03:12:14 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
type DexImport struct {
|
|
|
|
android.ModuleBase
|
|
|
|
android.DefaultableModuleBase
|
2019-07-25 15:02:35 +02:00
|
|
|
android.ApexModuleBase
|
2019-02-22 03:12:14 +01:00
|
|
|
prebuilt android.Prebuilt
|
|
|
|
|
|
|
|
properties DexImportProperties
|
|
|
|
|
2021-09-15 04:34:04 +02:00
|
|
|
dexJarFile OptionalDexJarPath
|
2019-02-22 03:12:14 +01:00
|
|
|
|
|
|
|
dexpreopter
|
2020-09-16 03:30:11 +02:00
|
|
|
|
|
|
|
hideApexVariantFromMake bool
|
2019-02-22 03:12:14 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (j *DexImport) Prebuilt() *android.Prebuilt {
|
|
|
|
return &j.prebuilt
|
|
|
|
}
|
|
|
|
|
|
|
|
func (j *DexImport) PrebuiltSrcs() []string {
|
|
|
|
return j.properties.Jars
|
|
|
|
}
|
|
|
|
|
|
|
|
func (j *DexImport) Name() string {
|
|
|
|
return j.prebuilt.Name(j.ModuleBase.Name())
|
|
|
|
}
|
|
|
|
|
2019-10-29 03:23:10 +01:00
|
|
|
func (j *DexImport) Stem() string {
|
|
|
|
return proptools.StringDefault(j.properties.Stem, j.ModuleBase.Name())
|
|
|
|
}
|
|
|
|
|
2020-06-01 14:39:15 +02:00
|
|
|
func (a *DexImport) JacocoReportClassesFile() android.Path {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2020-07-22 05:31:17 +02:00
|
|
|
func (a *DexImport) LintDepSets() LintDepSets {
|
|
|
|
return LintDepSets{}
|
|
|
|
}
|
|
|
|
|
2020-01-31 18:10:36 +01:00
|
|
|
func (j *DexImport) IsInstallable() bool {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
2021-05-11 00:30:00 +02:00
|
|
|
func (j *DexImport) getStrictUpdatabilityLinting() bool {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
func (j *DexImport) setStrictUpdatabilityLinting(bool) {
|
|
|
|
}
|
|
|
|
|
2019-02-22 03:12:14 +01:00
|
|
|
func (j *DexImport) GenerateAndroidBuildActions(ctx android.ModuleContext) {
|
|
|
|
if len(j.properties.Jars) != 1 {
|
|
|
|
ctx.PropertyErrorf("jars", "exactly one jar must be provided")
|
|
|
|
}
|
|
|
|
|
2020-09-16 03:30:11 +02:00
|
|
|
apexInfo := ctx.Provider(android.ApexInfoProvider).(android.ApexInfo)
|
|
|
|
if !apexInfo.IsForPlatform() {
|
|
|
|
j.hideApexVariantFromMake = true
|
|
|
|
}
|
|
|
|
|
2021-09-16 08:15:39 +02:00
|
|
|
j.dexpreopter.installPath = j.dexpreopter.getInstallPath(
|
|
|
|
ctx, android.PathForModuleInstall(ctx, "framework", j.Stem()+".jar"))
|
2019-02-22 03:12:14 +01:00
|
|
|
j.dexpreopter.uncompressedDex = shouldUncompressDex(ctx, &j.dexpreopter)
|
|
|
|
|
|
|
|
inputJar := ctx.ExpandSource(j.properties.Jars[0], "jars")
|
|
|
|
dexOutputFile := android.PathForModuleOut(ctx, ctx.ModuleName()+".jar")
|
|
|
|
|
|
|
|
if j.dexpreopter.uncompressedDex {
|
2020-11-17 02:32:30 +01:00
|
|
|
rule := android.NewRuleBuilder(pctx, ctx)
|
2019-02-22 03:12:14 +01:00
|
|
|
|
|
|
|
temporary := android.PathForModuleOut(ctx, ctx.ModuleName()+".jar.unaligned")
|
|
|
|
rule.Temporary(temporary)
|
|
|
|
|
|
|
|
// use zip2zip to uncompress classes*.dex files
|
|
|
|
rule.Command().
|
2020-11-17 02:32:30 +01:00
|
|
|
BuiltTool("zip2zip").
|
2019-02-22 03:12:14 +01:00
|
|
|
FlagWithInput("-i ", inputJar).
|
|
|
|
FlagWithOutput("-o ", temporary).
|
|
|
|
FlagWithArg("-0 ", "'classes*.dex'")
|
|
|
|
|
|
|
|
// use zipalign to align uncompressed classes*.dex files
|
|
|
|
rule.Command().
|
2020-11-17 02:32:30 +01:00
|
|
|
BuiltTool("zipalign").
|
2019-02-22 03:12:14 +01:00
|
|
|
Flag("-f").
|
|
|
|
Text("4").
|
|
|
|
Input(temporary).
|
|
|
|
Output(dexOutputFile)
|
|
|
|
|
|
|
|
rule.DeleteTemporaryFiles()
|
|
|
|
|
2020-11-17 02:32:30 +01:00
|
|
|
rule.Build("uncompress_dex", "uncompress dex")
|
2019-02-22 03:12:14 +01:00
|
|
|
} else {
|
|
|
|
ctx.Build(pctx, android.BuildParams{
|
|
|
|
Rule: android.Cp,
|
|
|
|
Input: inputJar,
|
|
|
|
Output: dexOutputFile,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2021-09-15 04:34:04 +02:00
|
|
|
j.dexJarFile = makeDexJarPathFromPath(dexOutputFile)
|
2019-02-22 03:12:14 +01:00
|
|
|
|
2020-12-17 18:43:28 +01:00
|
|
|
j.dexpreopt(ctx, dexOutputFile)
|
2019-02-22 03:12:14 +01:00
|
|
|
|
2020-09-16 03:30:11 +02:00
|
|
|
if apexInfo.IsForPlatform() {
|
2020-06-08 12:24:09 +02:00
|
|
|
ctx.InstallFile(android.PathForModuleInstall(ctx, "framework"),
|
|
|
|
j.Stem()+".jar", dexOutputFile)
|
|
|
|
}
|
2019-02-22 03:12:14 +01:00
|
|
|
}
|
|
|
|
|
2021-09-15 04:34:04 +02:00
|
|
|
func (j *DexImport) DexJarBuildPath() OptionalDexJarPath {
|
2019-02-22 03:12:14 +01:00
|
|
|
return j.dexJarFile
|
|
|
|
}
|
|
|
|
|
2020-12-15 14:29:02 +01:00
|
|
|
var _ android.ApexModule = (*DexImport)(nil)
|
|
|
|
|
|
|
|
// Implements android.ApexModule
|
2020-07-23 07:32:17 +02:00
|
|
|
func (j *DexImport) ShouldSupportSdkVersion(ctx android.BaseModuleContext,
|
|
|
|
sdkVersion android.ApiLevel) error {
|
2020-04-15 04:03:39 +02:00
|
|
|
// we don't check prebuilt modules for sdk_version
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2019-02-22 03:12:14 +01:00
|
|
|
// dex_import imports a `.jar` file containing classes.dex files.
|
|
|
|
//
|
|
|
|
// A dex_import module cannot be used as a dependency of a java_* or android_* module, it can only be installed
|
|
|
|
// to the device.
|
|
|
|
func DexImportFactory() android.Module {
|
|
|
|
module := &DexImport{}
|
|
|
|
|
|
|
|
module.AddProperties(&module.properties)
|
|
|
|
|
|
|
|
android.InitPrebuiltModule(module, &module.properties.Jars)
|
2019-07-25 15:02:35 +02:00
|
|
|
android.InitApexModule(module)
|
2019-11-13 02:50:48 +01:00
|
|
|
InitJavaModule(module, android.DeviceSupported)
|
2019-02-22 03:12:14 +01:00
|
|
|
return module
|
|
|
|
}
|
|
|
|
|
2017-07-07 23:35:50 +02:00
|
|
|
//
|
|
|
|
// Defaults
|
|
|
|
//
|
|
|
|
type Defaults struct {
|
|
|
|
android.ModuleBase
|
|
|
|
android.DefaultsModuleBase
|
2019-07-25 15:02:35 +02:00
|
|
|
android.ApexModuleBase
|
2017-07-07 23:35:50 +02:00
|
|
|
}
|
|
|
|
|
2019-02-12 23:41:32 +01:00
|
|
|
// java_defaults provides a set of properties that can be inherited by other java or android modules.
|
|
|
|
//
|
|
|
|
// A module can use the properties from a java_defaults module using `defaults: ["defaults_module_name"]`. Each
|
|
|
|
// property in the defaults module that exists in the depending module will be prepended to the depending module's
|
|
|
|
// value for that property.
|
|
|
|
//
|
|
|
|
// Example:
|
|
|
|
//
|
|
|
|
// java_defaults {
|
|
|
|
// name: "example_defaults",
|
|
|
|
// srcs: ["common/**/*.java"],
|
|
|
|
// javacflags: ["-Xlint:all"],
|
|
|
|
// aaptflags: ["--auto-add-overlay"],
|
|
|
|
// }
|
|
|
|
//
|
|
|
|
// java_library {
|
|
|
|
// name: "example",
|
|
|
|
// defaults: ["example_defaults"],
|
|
|
|
// srcs: ["example/**/*.java"],
|
|
|
|
// }
|
|
|
|
//
|
|
|
|
// is functionally identical to:
|
|
|
|
//
|
|
|
|
// java_library {
|
|
|
|
// name: "example",
|
|
|
|
// srcs: [
|
|
|
|
// "common/**/*.java",
|
|
|
|
// "example/**/*.java",
|
|
|
|
// ],
|
|
|
|
// javacflags: ["-Xlint:all"],
|
|
|
|
// }
|
2019-12-05 15:07:14 +01:00
|
|
|
func DefaultsFactory() android.Module {
|
2017-07-07 23:35:50 +02:00
|
|
|
module := &Defaults{}
|
|
|
|
|
|
|
|
module.AddProperties(
|
2021-03-11 02:02:43 +01:00
|
|
|
&CommonProperties{},
|
|
|
|
&DeviceProperties{},
|
2022-01-08 04:16:32 +01:00
|
|
|
&OverridableDeviceProperties{},
|
2020-07-10 00:16:41 +02:00
|
|
|
&DexProperties{},
|
2018-11-12 19:13:39 +01:00
|
|
|
&DexpreoptProperties{},
|
2018-03-08 22:27:59 +01:00
|
|
|
&android.ProtoProperties{},
|
2018-10-02 22:53:33 +02:00
|
|
|
&aaptProperties{},
|
|
|
|
&androidLibraryProperties{},
|
|
|
|
&appProperties{},
|
|
|
|
&appTestProperties{},
|
2019-03-01 00:35:54 +01:00
|
|
|
&overridableAppProperties{},
|
2020-02-04 16:45:49 +01:00
|
|
|
&testProperties{},
|
2018-10-02 22:53:33 +02:00
|
|
|
&ImportProperties{},
|
|
|
|
&AARImportProperties{},
|
|
|
|
&sdkLibraryProperties{},
|
2020-05-08 14:44:43 +02:00
|
|
|
&commonToSdkLibraryAndImportProperties{},
|
2019-02-22 03:12:14 +01:00
|
|
|
&DexImportProperties{},
|
2019-11-13 02:50:48 +01:00
|
|
|
&android.ApexProperties{},
|
2020-04-27 00:10:51 +02:00
|
|
|
&RuntimeResourceOverlayProperties{},
|
2020-06-03 05:09:13 +02:00
|
|
|
&LintProperties{},
|
2021-02-09 19:38:30 +01:00
|
|
|
&appTestHelperAppProperties{},
|
2017-07-07 23:35:50 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
android.InitDefaultsModule(module)
|
|
|
|
return module
|
|
|
|
}
|
2017-11-09 06:20:04 +01:00
|
|
|
|
2018-11-06 01:49:08 +01:00
|
|
|
func kytheExtractJavaFactory() android.Singleton {
|
|
|
|
return &kytheExtractJavaSingleton{}
|
|
|
|
}
|
|
|
|
|
|
|
|
type kytheExtractJavaSingleton struct {
|
|
|
|
}
|
|
|
|
|
|
|
|
func (ks *kytheExtractJavaSingleton) GenerateBuildActions(ctx android.SingletonContext) {
|
|
|
|
var xrefTargets android.Paths
|
|
|
|
ctx.VisitAllModules(func(module android.Module) {
|
|
|
|
if javaModule, ok := module.(xref); ok {
|
|
|
|
xrefTargets = append(xrefTargets, javaModule.XrefJavaFiles()...)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
// TODO(asmundak): perhaps emit a rule to output a warning if there were no xrefTargets
|
|
|
|
if len(xrefTargets) > 0 {
|
2020-06-04 22:25:17 +02:00
|
|
|
ctx.Phony("xref_java", xrefTargets...)
|
2018-11-06 01:49:08 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-11-09 06:20:04 +01:00
|
|
|
var Bool = proptools.Bool
|
2018-04-11 01:14:46 +02:00
|
|
|
var BoolDefault = proptools.BoolDefault
|
2017-11-09 06:20:04 +01:00
|
|
|
var String = proptools.String
|
2018-02-20 22:33:42 +01:00
|
|
|
var inList = android.InList
|
2020-12-03 17:50:22 +01:00
|
|
|
|
2020-12-16 17:16:11 +01:00
|
|
|
// Add class loader context (CLC) of a given dependency to the current CLC.
|
|
|
|
func addCLCFromDep(ctx android.ModuleContext, depModule android.Module,
|
|
|
|
clcMap dexpreopt.ClassLoaderContextMap) {
|
|
|
|
|
|
|
|
dep, ok := depModule.(UsesLibraryDependency)
|
|
|
|
if !ok {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2021-07-15 15:34:40 +02:00
|
|
|
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()
|
2020-12-16 17:16:11 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
depTag := ctx.OtherModuleDependencyTag(depModule)
|
2021-08-12 17:16:11 +02:00
|
|
|
if depTag == libTag {
|
2020-12-16 17:16:11 +01:00
|
|
|
// Ok, propagate <uses-library> through non-static library dependencies.
|
2022-05-04 13:00:02 +02:00
|
|
|
} else if tag, ok := depTag.(usesLibraryDependencyTag); ok && tag.sdkVersion == dexpreopt.AnySdkVersion {
|
|
|
|
// Ok, propagate <uses-library> through non-compatibility <uses-library> dependencies.
|
2020-12-16 17:16:11 +01:00
|
|
|
} else if depTag == staticLibTag {
|
|
|
|
// 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.
|
2021-07-15 15:34:40 +02:00
|
|
|
if sdkLib != nil {
|
2020-12-16 17:16:11 +01:00
|
|
|
return
|
2020-12-03 17:50:22 +01:00
|
|
|
}
|
2020-12-16 17:16:11 +01:00
|
|
|
} else {
|
|
|
|
// Don't propagate <uses-library> for other dependency tags.
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2021-07-15 15:34:40 +02:00
|
|
|
// 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 {
|
2022-05-04 13:00:02 +02:00
|
|
|
clcMap.AddContext(ctx, dexpreopt.AnySdkVersion, *sdkLib, false,
|
2021-09-15 04:34:04 +02:00
|
|
|
dep.DexJarBuildPath().PathOrNil(), dep.DexJarInstallPath(), dep.ClassLoaderContexts())
|
2020-12-16 17:16:11 +01:00
|
|
|
} else {
|
|
|
|
clcMap.AddContextMap(dep.ClassLoaderContexts(), depName)
|
2020-12-03 17:50:22 +01:00
|
|
|
}
|
|
|
|
}
|
2021-12-10 12:14:59 +01:00
|
|
|
|
2022-03-23 21:20:42 +01:00
|
|
|
type javaResourcesAttributes struct {
|
|
|
|
Resources bazel.LabelListAttribute
|
|
|
|
Resource_strip_prefix *string
|
|
|
|
}
|
|
|
|
|
|
|
|
func (m *Library) convertJavaResourcesAttributes(ctx android.TopDownMutatorContext) *javaResourcesAttributes {
|
|
|
|
var resources bazel.LabelList
|
|
|
|
var resourceStripPrefix *string
|
|
|
|
|
|
|
|
if m.properties.Java_resources != nil {
|
|
|
|
resources.Append(android.BazelLabelForModuleSrc(ctx, m.properties.Java_resources))
|
|
|
|
}
|
|
|
|
|
|
|
|
//TODO(b/179889880) handle case where glob includes files outside package
|
|
|
|
resDeps := ResourceDirsToFiles(
|
|
|
|
ctx,
|
|
|
|
m.properties.Java_resource_dirs,
|
|
|
|
m.properties.Exclude_java_resource_dirs,
|
|
|
|
m.properties.Exclude_java_resources,
|
|
|
|
)
|
|
|
|
|
|
|
|
for i, resDep := range resDeps {
|
|
|
|
dir, files := resDep.dir, resDep.files
|
|
|
|
|
|
|
|
resources.Append(bazel.MakeLabelList(android.RootToModuleRelativePaths(ctx, files)))
|
|
|
|
|
|
|
|
// Bazel includes the relative path from the WORKSPACE root when placing the resource
|
|
|
|
// inside the JAR file, so we need to remove that prefix
|
|
|
|
resourceStripPrefix = proptools.StringPtr(dir.String())
|
|
|
|
if i > 0 {
|
|
|
|
// TODO(b/226423379) allow multiple resource prefixes
|
|
|
|
ctx.ModuleErrorf("bp2build does not support more than one directory in java_resource_dirs (b/226423379)")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return &javaResourcesAttributes{
|
|
|
|
Resources: bazel.MakeLabelListAttribute(resources),
|
|
|
|
Resource_strip_prefix: resourceStripPrefix,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-02-25 22:34:51 +01:00
|
|
|
type javaCommonAttributes struct {
|
2022-03-23 21:20:42 +01:00
|
|
|
*javaResourcesAttributes
|
2021-12-10 12:14:59 +01:00
|
|
|
Srcs bazel.LabelListAttribute
|
2022-03-18 15:11:07 +01:00
|
|
|
Plugins bazel.LabelListAttribute
|
2021-12-10 12:14:59 +01:00
|
|
|
Javacopts bazel.StringListAttribute
|
|
|
|
}
|
|
|
|
|
2022-02-25 22:34:51 +01:00
|
|
|
type javaDependencyLabels struct {
|
|
|
|
// Dependencies which DO NOT contribute to the API visible to upstream dependencies.
|
|
|
|
Deps bazel.LabelListAttribute
|
|
|
|
// Dependencies which DO contribute to the API visible to upstream dependencies.
|
|
|
|
StaticDeps bazel.LabelListAttribute
|
|
|
|
}
|
|
|
|
|
|
|
|
// convertLibraryAttrsBp2Build converts a few shared attributes from java_* modules
|
|
|
|
// and also separates dependencies into dynamic dependencies and static dependencies.
|
|
|
|
// Each corresponding Bazel target type, can have a different method for handling
|
|
|
|
// dynamic vs. static dependencies, and so these are returned to the calling function.
|
2022-03-16 21:36:54 +01:00
|
|
|
type eventLogTagsAttributes struct {
|
|
|
|
Srcs bazel.LabelListAttribute
|
|
|
|
}
|
|
|
|
|
2022-02-25 22:34:51 +01:00
|
|
|
func (m *Library) convertLibraryAttrsBp2Build(ctx android.TopDownMutatorContext) (*javaCommonAttributes, *javaDependencyLabels) {
|
2022-02-23 16:28:33 +01:00
|
|
|
var srcs bazel.LabelListAttribute
|
|
|
|
archVariantProps := m.GetArchVariantProperties(ctx, &CommonProperties{})
|
|
|
|
for axis, configToProps := range archVariantProps {
|
|
|
|
for config, _props := range configToProps {
|
|
|
|
if archProps, ok := _props.(*CommonProperties); ok {
|
|
|
|
archSrcs := android.BazelLabelForModuleSrcExcludes(ctx, archProps.Srcs, archProps.Exclude_srcs)
|
|
|
|
srcs.SetSelectValue(axis, config, archSrcs)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2022-02-04 22:01:20 +01:00
|
|
|
|
|
|
|
javaSrcPartition := "java"
|
|
|
|
protoSrcPartition := "proto"
|
2022-03-16 21:36:54 +01:00
|
|
|
logtagSrcPartition := "logtag"
|
2022-02-04 22:01:20 +01:00
|
|
|
srcPartitions := bazel.PartitionLabelListAttribute(ctx, &srcs, bazel.LabelPartitions{
|
2022-03-16 21:36:54 +01:00
|
|
|
javaSrcPartition: bazel.LabelPartition{Extensions: []string{".java"}, Keep_remainder: true},
|
|
|
|
logtagSrcPartition: bazel.LabelPartition{Extensions: []string{".logtags", ".logtag"}},
|
|
|
|
protoSrcPartition: android.ProtoSrcLabelPartition,
|
2022-02-04 22:01:20 +01:00
|
|
|
})
|
|
|
|
|
2022-03-16 21:36:54 +01:00
|
|
|
javaSrcs := srcPartitions[javaSrcPartition]
|
|
|
|
|
|
|
|
var logtagsSrcs bazel.LabelList
|
|
|
|
if !srcPartitions[logtagSrcPartition].IsEmpty() {
|
|
|
|
logtagsLibName := m.Name() + "_logtags"
|
|
|
|
logtagsSrcs = bazel.MakeLabelList([]bazel.Label{{Label: ":" + logtagsLibName}})
|
|
|
|
ctx.CreateBazelTargetModule(
|
|
|
|
bazel.BazelTargetModuleProperties{
|
|
|
|
Rule_class: "event_log_tags",
|
|
|
|
Bzl_load_location: "//build/make/tools:event_log_tags.bzl",
|
|
|
|
},
|
|
|
|
android.CommonAttributes{Name: logtagsLibName},
|
|
|
|
&eventLogTagsAttributes{
|
|
|
|
Srcs: srcPartitions[logtagSrcPartition],
|
|
|
|
},
|
|
|
|
)
|
|
|
|
}
|
|
|
|
javaSrcs.Append(bazel.MakeLabelListAttribute(logtagsSrcs))
|
|
|
|
|
2022-03-15 22:02:09 +01:00
|
|
|
var javacopts []string
|
|
|
|
if m.properties.Javacflags != nil {
|
|
|
|
javacopts = append(javacopts, m.properties.Javacflags...)
|
|
|
|
}
|
2022-04-23 01:09:58 +02:00
|
|
|
if m.properties.Java_version != nil {
|
|
|
|
javaVersion := normalizeJavaVersion(ctx, *m.properties.Java_version).String()
|
|
|
|
javacopts = append(javacopts, fmt.Sprintf("-source %s -target %s", javaVersion, javaVersion))
|
|
|
|
}
|
|
|
|
|
2022-03-15 22:02:09 +01:00
|
|
|
epEnabled := m.properties.Errorprone.Enabled
|
|
|
|
//TODO(b/227504307) add configuration that depends on RUN_ERROR_PRONE environment variable
|
|
|
|
if Bool(epEnabled) {
|
|
|
|
javacopts = append(javacopts, m.properties.Errorprone.Javacflags...)
|
|
|
|
}
|
|
|
|
|
2022-02-25 22:34:51 +01:00
|
|
|
commonAttrs := &javaCommonAttributes{
|
2022-03-23 21:20:42 +01:00
|
|
|
Srcs: javaSrcs,
|
|
|
|
javaResourcesAttributes: m.convertJavaResourcesAttributes(ctx),
|
2022-03-18 15:11:07 +01:00
|
|
|
Plugins: bazel.MakeLabelListAttribute(
|
|
|
|
android.BazelLabelForModuleDeps(ctx, m.properties.Plugins),
|
|
|
|
),
|
2022-03-15 22:02:09 +01:00
|
|
|
Javacopts: bazel.MakeStringListAttribute(javacopts),
|
2021-12-10 12:14:59 +01:00
|
|
|
}
|
|
|
|
|
2022-02-25 22:34:51 +01:00
|
|
|
depLabels := &javaDependencyLabels{}
|
|
|
|
|
2022-01-28 21:53:38 +01:00
|
|
|
var deps bazel.LabelList
|
2021-12-10 12:14:59 +01:00
|
|
|
if m.properties.Libs != nil {
|
2022-01-28 21:53:38 +01:00
|
|
|
deps.Append(android.BazelLabelForModuleDeps(ctx, m.properties.Libs))
|
|
|
|
}
|
2022-02-25 22:34:51 +01:00
|
|
|
|
|
|
|
var staticDeps bazel.LabelList
|
2022-01-28 21:53:38 +01:00
|
|
|
if m.properties.Static_libs != nil {
|
2022-02-25 22:34:51 +01:00
|
|
|
staticDeps.Append(android.BazelLabelForModuleDeps(ctx, m.properties.Static_libs))
|
2021-12-10 12:14:59 +01:00
|
|
|
}
|
2022-02-04 22:01:20 +01:00
|
|
|
|
2022-02-25 22:34:51 +01:00
|
|
|
protoDepLabel := bp2buildProto(ctx, &m.Module, srcPartitions[protoSrcPartition])
|
|
|
|
// Soong does not differentiate between a java_library and the Bazel equivalent of
|
|
|
|
// a java_proto_library + proto_library pair. Instead, in Soong proto sources are
|
|
|
|
// listed directly in the srcs of a java_library, and the classes produced
|
|
|
|
// by protoc are included directly in the resulting JAR. Thus upstream dependencies
|
|
|
|
// that depend on a java_library with proto sources can link directly to the protobuf API,
|
|
|
|
// and so this should be a static dependency.
|
|
|
|
staticDeps.Add(protoDepLabel)
|
2022-02-04 22:01:20 +01:00
|
|
|
|
2022-02-25 22:34:51 +01:00
|
|
|
depLabels.Deps = bazel.MakeLabelListAttribute(deps)
|
|
|
|
depLabels.StaticDeps = bazel.MakeLabelListAttribute(staticDeps)
|
2022-01-28 21:53:38 +01:00
|
|
|
|
2022-02-25 22:34:51 +01:00
|
|
|
return commonAttrs, depLabels
|
|
|
|
}
|
|
|
|
|
|
|
|
type javaLibraryAttributes struct {
|
|
|
|
*javaCommonAttributes
|
|
|
|
Deps bazel.LabelListAttribute
|
|
|
|
Exports bazel.LabelListAttribute
|
2022-01-28 21:53:38 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func javaLibraryBp2Build(ctx android.TopDownMutatorContext, m *Library) {
|
2022-02-25 22:34:51 +01:00
|
|
|
commonAttrs, depLabels := m.convertLibraryAttrsBp2Build(ctx)
|
|
|
|
|
|
|
|
deps := depLabels.Deps
|
|
|
|
if !commonAttrs.Srcs.IsEmpty() {
|
|
|
|
deps.Append(depLabels.StaticDeps) // we should only append these if there are sources to use them
|
|
|
|
|
|
|
|
sdkVersion := m.SdkVersion(ctx)
|
|
|
|
if sdkVersion.Kind == android.SdkPublic && sdkVersion.ApiLevel == android.FutureApiLevel {
|
|
|
|
// TODO(b/220869005) remove forced dependency on current public android.jar
|
|
|
|
deps.Add(bazel.MakeLabelAttribute("//prebuilts/sdk:public_current_android_sdk_java_import"))
|
|
|
|
}
|
|
|
|
} else if !depLabels.Deps.IsEmpty() {
|
|
|
|
ctx.ModuleErrorf("Module has direct dependencies but no sources. Bazel will not allow this.")
|
|
|
|
}
|
|
|
|
|
|
|
|
attrs := &javaLibraryAttributes{
|
|
|
|
javaCommonAttributes: commonAttrs,
|
|
|
|
Deps: deps,
|
|
|
|
Exports: depLabels.StaticDeps,
|
|
|
|
}
|
2021-12-10 12:14:59 +01:00
|
|
|
|
|
|
|
props := bazel.BazelTargetModuleProperties{
|
|
|
|
Rule_class: "java_library",
|
|
|
|
Bzl_load_location: "//build/bazel/rules/java:library.bzl",
|
|
|
|
}
|
|
|
|
|
|
|
|
ctx.CreateBazelTargetModule(props, android.CommonAttributes{Name: m.Name()}, attrs)
|
|
|
|
}
|
|
|
|
|
|
|
|
type javaBinaryHostAttributes struct {
|
2022-02-25 22:34:51 +01:00
|
|
|
*javaCommonAttributes
|
|
|
|
Deps bazel.LabelListAttribute
|
|
|
|
Runtime_deps bazel.LabelListAttribute
|
|
|
|
Main_class string
|
|
|
|
Jvm_flags bazel.StringListAttribute
|
2021-12-10 12:14:59 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// JavaBinaryHostBp2Build is for java_binary_host bp2build.
|
|
|
|
func javaBinaryHostBp2Build(ctx android.TopDownMutatorContext, m *Binary) {
|
2022-02-25 22:34:51 +01:00
|
|
|
commonAttrs, depLabels := m.convertLibraryAttrsBp2Build(ctx)
|
|
|
|
|
|
|
|
deps := depLabels.Deps
|
|
|
|
deps.Append(depLabels.StaticDeps)
|
|
|
|
if m.binaryProperties.Jni_libs != nil {
|
|
|
|
deps.Append(bazel.MakeLabelListAttribute(android.BazelLabelForModuleDeps(ctx, m.binaryProperties.Jni_libs)))
|
|
|
|
}
|
|
|
|
|
|
|
|
var runtimeDeps bazel.LabelListAttribute
|
|
|
|
if commonAttrs.Srcs.IsEmpty() {
|
|
|
|
// if there are no sources, then the dependencies can only be used at runtime
|
|
|
|
runtimeDeps = deps
|
|
|
|
deps = bazel.LabelListAttribute{}
|
|
|
|
}
|
|
|
|
|
2021-12-10 12:14:59 +01:00
|
|
|
mainClass := ""
|
|
|
|
if m.binaryProperties.Main_class != nil {
|
|
|
|
mainClass = *m.binaryProperties.Main_class
|
|
|
|
}
|
|
|
|
if m.properties.Manifest != nil {
|
|
|
|
mainClassInManifest, err := android.GetMainClassInManifest(ctx.Config(), android.PathForModuleSrc(ctx, *m.properties.Manifest).String())
|
|
|
|
if err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
mainClass = mainClassInManifest
|
|
|
|
}
|
|
|
|
|
2022-02-25 22:34:51 +01:00
|
|
|
attrs := &javaBinaryHostAttributes{
|
|
|
|
javaCommonAttributes: commonAttrs,
|
|
|
|
Deps: deps,
|
|
|
|
Runtime_deps: runtimeDeps,
|
|
|
|
Main_class: mainClass,
|
2021-12-10 12:14:59 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// Attribute jvm_flags
|
|
|
|
if m.binaryProperties.Jni_libs != nil {
|
|
|
|
jniLibPackages := map[string]bool{}
|
|
|
|
for _, jniLibLabel := range android.BazelLabelForModuleDeps(ctx, m.binaryProperties.Jni_libs).Includes {
|
|
|
|
jniLibPackage := jniLibLabel.Label
|
|
|
|
indexOfColon := strings.Index(jniLibLabel.Label, ":")
|
|
|
|
if indexOfColon > 0 {
|
|
|
|
// JNI lib from other package
|
|
|
|
jniLibPackage = jniLibLabel.Label[2:indexOfColon]
|
|
|
|
} else if indexOfColon == 0 {
|
|
|
|
// JNI lib in the same package of java_binary
|
|
|
|
packageOfCurrentModule := m.GetBazelLabel(ctx, m)
|
|
|
|
jniLibPackage = packageOfCurrentModule[2:strings.Index(packageOfCurrentModule, ":")]
|
|
|
|
}
|
|
|
|
if _, inMap := jniLibPackages[jniLibPackage]; !inMap {
|
|
|
|
jniLibPackages[jniLibPackage] = true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
jniLibPaths := []string{}
|
|
|
|
for jniLibPackage, _ := range jniLibPackages {
|
|
|
|
// See cs/f:.*/third_party/bazel/.*java_stub_template.txt for the use of RUNPATH
|
|
|
|
jniLibPaths = append(jniLibPaths, "$${RUNPATH}"+jniLibPackage)
|
|
|
|
}
|
|
|
|
attrs.Jvm_flags = bazel.MakeStringListAttribute([]string{"-Djava.library.path=" + strings.Join(jniLibPaths, ":")})
|
|
|
|
}
|
|
|
|
|
|
|
|
props := bazel.BazelTargetModuleProperties{
|
|
|
|
Rule_class: "java_binary",
|
|
|
|
}
|
|
|
|
|
|
|
|
// Create the BazelTargetModule.
|
|
|
|
ctx.CreateBazelTargetModule(props, android.CommonAttributes{Name: m.Name()}, attrs)
|
|
|
|
}
|
2022-01-28 17:12:52 +01:00
|
|
|
|
|
|
|
type bazelJavaImportAttributes struct {
|
|
|
|
Jars bazel.LabelListAttribute
|
|
|
|
}
|
|
|
|
|
|
|
|
// java_import bp2Build converter.
|
|
|
|
func (i *Import) ConvertWithBp2build(ctx android.TopDownMutatorContext) {
|
2022-02-22 22:41:33 +01:00
|
|
|
var jars bazel.LabelListAttribute
|
|
|
|
archVariantProps := i.GetArchVariantProperties(ctx, &ImportProperties{})
|
|
|
|
for axis, configToProps := range archVariantProps {
|
|
|
|
for config, _props := range configToProps {
|
|
|
|
if archProps, ok := _props.(*ImportProperties); ok {
|
|
|
|
archJars := android.BazelLabelForModuleSrcExcludes(ctx, archProps.Jars, []string(nil))
|
|
|
|
jars.SetSelectValue(axis, config, archJars)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2022-01-28 17:12:52 +01:00
|
|
|
|
|
|
|
attrs := &bazelJavaImportAttributes{
|
|
|
|
Jars: jars,
|
|
|
|
}
|
|
|
|
props := bazel.BazelTargetModuleProperties{Rule_class: "java_import"}
|
|
|
|
|
|
|
|
ctx.CreateBazelTargetModule(props, android.CommonAttributes{Name: android.RemoveOptionalPrebuiltPrefix(i.Name())}, attrs)
|
|
|
|
|
|
|
|
}
|