564 lines
25 KiB
Makefile
564 lines
25 KiB
Makefile
# Common to host and target Java modules.
|
|
|
|
my_soong_problems :=
|
|
|
|
ifneq ($(filter ../%,$(LOCAL_SRC_FILES)),)
|
|
my_soong_problems += dotdot_srcs
|
|
endif
|
|
|
|
ifneq (,$(LOCAL_JNI_SHARED_LIBRARIES))
|
|
my_soong_problems += jni_libs
|
|
endif
|
|
|
|
###########################################################
|
|
## Java version
|
|
###########################################################
|
|
# Use the LOCAL_JAVA_LANGUAGE_VERSION if it is set, otherwise
|
|
# use one based on the LOCAL_SDK_VERSION. If it is < 24
|
|
# pass "1.7" to the tools, if it is unset, >= 24 or "current"
|
|
# pass "1.8".
|
|
#
|
|
# The LOCAL_SDK_VERSION behavior is to ensure that, by default,
|
|
# code that is expected to run on older releases of Android
|
|
# does not use any 1.8 language features that are not supported
|
|
# on earlier runtimes (like default / static interface methods).
|
|
# Modules can override this logic by specifying
|
|
# LOCAL_JAVA_LANGUAGE_VERSION explicitly.
|
|
ifeq (,$(LOCAL_JAVA_LANGUAGE_VERSION))
|
|
ifneq (,$(filter $(LOCAL_SDK_VERSION), $(TARGET_SDK_VERSIONS_WITHOUT_JAVA_18_SUPPORT)))
|
|
LOCAL_JAVA_LANGUAGE_VERSION := 1.7
|
|
else ifneq (,$(filter $(LOCAL_SDK_VERSION), $(TARGET_SDK_VERSIONS_WITHOUT_JAVA_19_SUPPORT)))
|
|
LOCAL_JAVA_LANGUAGE_VERSION := 1.8
|
|
else ifneq (,$(LOCAL_SDK_VERSION)$(TARGET_BUILD_APPS_USE_PREBUILT_SDK))
|
|
# TODO(ccross): allow 1.9 for current and unbundled once we have SDK system modules
|
|
LOCAL_JAVA_LANGUAGE_VERSION := 1.8
|
|
else
|
|
# DEFAULT_JAVA_LANGUAGE_VERSION is 1.8, unless TARGET_OPENJDK9 in which case it is 1.9
|
|
LOCAL_JAVA_LANGUAGE_VERSION := $(DEFAULT_JAVA_LANGUAGE_VERSION)
|
|
endif
|
|
endif
|
|
LOCAL_JAVACFLAGS += -source $(LOCAL_JAVA_LANGUAGE_VERSION) -target $(LOCAL_JAVA_LANGUAGE_VERSION)
|
|
|
|
###########################################################
|
|
|
|
# OpenJDK versions up to 8 shipped with bootstrap and tools jars
|
|
# (rt.jar, jce.jar, tools.jar etc.). These are no longer part of
|
|
# OpenJDK 9, but we still make them available for host tools that
|
|
# are targeting older versions.
|
|
USE_HOST_BOOTSTRAP_JARS := true
|
|
ifeq (,$(filter $(LOCAL_JAVA_LANGUAGE_VERSION), 1.6 1.7 1.8))
|
|
USE_HOST_BOOTSTRAP_JARS := false
|
|
endif
|
|
|
|
###########################################################
|
|
|
|
# Drop HOST_JDK_TOOLS_JAR from classpath when targeting versions > 9 (which don't have it).
|
|
# TODO: Remove HOST_JDK_TOOLS_JAR and all references to it once host
|
|
# bootstrap jars are no longer supported (ie. when USE_HOST_BOOTSTRAP_JARS
|
|
# is always false). http://b/38418220
|
|
ifneq ($(USE_HOST_BOOTSTRAP_JARS),true)
|
|
LOCAL_CLASSPATH := $(filter-out $(HOST_JDK_TOOLS_JAR),$(LOCAL_CLASSPATH))
|
|
endif
|
|
|
|
###########################################################
|
|
## .proto files: Compile proto files to .java
|
|
###########################################################
|
|
ifeq ($(strip $(LOCAL_PROTOC_OPTIMIZE_TYPE)),)
|
|
LOCAL_PROTOC_OPTIMIZE_TYPE := lite
|
|
endif
|
|
proto_sources := $(filter %.proto,$(LOCAL_SRC_FILES))
|
|
# Because names of the .java files compiled from .proto files are unknown until the
|
|
# .proto files are compiled, we use a timestamp file as depedency.
|
|
proto_java_sources_file_stamp :=
|
|
ifneq ($(proto_sources),)
|
|
proto_sources_fullpath := $(addprefix $(LOCAL_PATH)/, $(proto_sources))
|
|
|
|
proto_java_intemediate_dir := $(intermediates.COMMON)/proto
|
|
proto_java_sources_file_stamp := $(proto_java_intemediate_dir)/Proto.stamp
|
|
proto_java_sources_dir := $(proto_java_intemediate_dir)/src
|
|
|
|
$(proto_java_sources_file_stamp): PRIVATE_PROTO_INCLUDES := $(TOP)
|
|
$(proto_java_sources_file_stamp): PRIVATE_PROTO_SRC_FILES := $(proto_sources_fullpath)
|
|
$(proto_java_sources_file_stamp): PRIVATE_PROTO_JAVA_OUTPUT_DIR := $(proto_java_sources_dir)
|
|
$(proto_java_sources_file_stamp): PRIVATE_PROTOC_FLAGS := $(LOCAL_PROTOC_FLAGS)
|
|
ifeq ($(LOCAL_PROTOC_OPTIMIZE_TYPE),micro)
|
|
$(proto_java_sources_file_stamp): PRIVATE_PROTO_JAVA_OUTPUT_OPTION := --javamicro_out
|
|
else
|
|
ifeq ($(LOCAL_PROTOC_OPTIMIZE_TYPE),nano)
|
|
$(proto_java_sources_file_stamp): PRIVATE_PROTO_JAVA_OUTPUT_OPTION := --javanano_out
|
|
else
|
|
ifeq ($(LOCAL_PROTOC_OPTIMIZE_TYPE),stream)
|
|
$(proto_java_sources_file_stamp): PRIVATE_PROTO_JAVA_OUTPUT_OPTION := --javastream_out
|
|
$(proto_java_sources_file_stamp): PRIVATE_PROTOC_FLAGS += --plugin=$(HOST_OUT_EXECUTABLES)/protoc-gen-javastream
|
|
$(proto_java_sources_file_stamp): $(HOST_OUT_EXECUTABLES)/protoc-gen-javastream
|
|
else
|
|
$(proto_java_sources_file_stamp): PRIVATE_PROTO_JAVA_OUTPUT_OPTION := --java_out
|
|
endif
|
|
endif
|
|
endif
|
|
$(proto_java_sources_file_stamp): PRIVATE_PROTO_JAVA_OUTPUT_PARAMS := $(if $(filter lite,$(LOCAL_PROTOC_OPTIMIZE_TYPE)),lite$(if $(LOCAL_PROTO_JAVA_OUTPUT_PARAMS),:,),)$(LOCAL_PROTO_JAVA_OUTPUT_PARAMS)
|
|
$(proto_java_sources_file_stamp) : $(proto_sources_fullpath) $(PROTOC)
|
|
$(call transform-proto-to-java)
|
|
|
|
#TODO: protoc should output the dependencies introduced by imports.
|
|
|
|
ALL_MODULES.$(my_register_name).PROTO_FILES := $(proto_sources_fullpath)
|
|
endif # proto_sources
|
|
|
|
#########################################
|
|
## Java resources
|
|
|
|
# Look for resource files in any specified directories.
|
|
# Non-java and non-doc files will be picked up as resources
|
|
# and included in the output jar file.
|
|
java_resource_file_groups :=
|
|
|
|
LOCAL_JAVA_RESOURCE_DIRS := $(strip $(LOCAL_JAVA_RESOURCE_DIRS))
|
|
ifneq ($(LOCAL_JAVA_RESOURCE_DIRS),)
|
|
# This makes a list of words like
|
|
# <dir1>::<file1>:<file2> <dir2>::<file1> <dir3>:
|
|
# where each of the files is relative to the directory it's grouped with.
|
|
# Directories that don't contain any resource files will result in groups
|
|
# that end with a colon, and they are stripped out in the next step.
|
|
java_resource_file_groups += \
|
|
$(foreach dir,$(LOCAL_JAVA_RESOURCE_DIRS), \
|
|
$(subst $(space),:,$(strip \
|
|
$(LOCAL_PATH)/$(dir): \
|
|
$(patsubst ./%,%,$(sort $(shell cd $(LOCAL_PATH)/$(dir) && \
|
|
find . \
|
|
-type d -a -name ".svn" -prune -o \
|
|
-type f \
|
|
-a \! -name "*.java" \
|
|
-a \! -name "package.html" \
|
|
-a \! -name "overview.html" \
|
|
-a \! -name ".*.swp" \
|
|
-a \! -name ".DS_Store" \
|
|
-a \! -name "*~" \
|
|
-print \
|
|
))) \
|
|
)) \
|
|
)
|
|
java_resource_file_groups := $(filter-out %:,$(java_resource_file_groups))
|
|
endif # LOCAL_JAVA_RESOURCE_DIRS
|
|
|
|
ifneq ($(LOCAL_JAVA_RESOURCE_FILES),)
|
|
# Converts LOCAL_JAVA_RESOURCE_FILES := <file> to $(dir $(file))::$(notdir $(file))
|
|
# and LOCAL_JAVA_RESOURCE_FILES := <dir>:<file> to <dir>::<file>
|
|
java_resource_file_groups += $(strip $(foreach res,$(LOCAL_JAVA_RESOURCE_FILES), \
|
|
$(eval _file := $(call word-colon,2,$(res))) \
|
|
$(if $(_file), \
|
|
$(eval _base := $(call word-colon,1,$(res))), \
|
|
$(eval _base := $(dir $(res))) \
|
|
$(eval _file := $(notdir $(res)))) \
|
|
$(if $(filter /%, \
|
|
$(filter-out $(OUT_DIR)/%,$(_base) $(_file))), \
|
|
$(call pretty-error,LOCAL_JAVA_RESOURCE_FILES may not include absolute paths: $(_base) $(_file))) \
|
|
$(patsubst %/,%,$(_base))::$(_file)))
|
|
|
|
endif # LOCAL_JAVA_RESOURCE_FILES
|
|
|
|
ifdef java_resource_file_groups
|
|
# The full paths to all resources, used for dependencies.
|
|
java_resource_sources := \
|
|
$(foreach group,$(java_resource_file_groups), \
|
|
$(addprefix $(word 1,$(subst :,$(space),$(group)))/, \
|
|
$(wordlist 2,9999,$(subst :,$(space),$(group))) \
|
|
) \
|
|
)
|
|
# The arguments to jar that will include these files in a jar file.
|
|
# Quote the file name to handle special characters (such as #) correctly.
|
|
extra_jar_args := \
|
|
$(foreach group,$(java_resource_file_groups), \
|
|
$(addprefix -C "$(word 1,$(subst :,$(space),$(group)))" , \
|
|
$(foreach w, $(wordlist 2,9999,$(subst :,$(space),$(group))), "$(w)" ) \
|
|
) \
|
|
)
|
|
java_resource_file_groups :=
|
|
else
|
|
java_resource_sources :=
|
|
extra_jar_args :=
|
|
endif # java_resource_file_groups
|
|
|
|
#####################################
|
|
## Warn if there is unrecognized file in LOCAL_SRC_FILES.
|
|
my_unknown_src_files := $(filter-out \
|
|
%.java %.aidl %.proto %.logtags, \
|
|
$(LOCAL_SRC_FILES) $(LOCAL_INTERMEDIATE_SOURCES) $(LOCAL_GENERATED_SOURCES))
|
|
ifneq ($(my_unknown_src_files),)
|
|
$(warning $(LOCAL_MODULE_MAKEFILE): $(LOCAL_MODULE): Unused source files: $(my_unknown_src_files))
|
|
endif
|
|
|
|
######################################
|
|
## PRIVATE java vars
|
|
# LOCAL_SOURCE_FILES_ALL_GENERATED is set only if the module does not have static source files,
|
|
# but generated source files in its LOCAL_INTERMEDIATE_SOURCE_DIR.
|
|
# You have to set up the dependency in some other way.
|
|
need_compile_java := $(strip $(all_java_sources)$(LOCAL_SRCJARS)$(all_res_assets)$(java_resource_sources))$(LOCAL_STATIC_JAVA_LIBRARIES)$(filter true,$(LOCAL_SOURCE_FILES_ALL_GENERATED))
|
|
ifdef need_compile_java
|
|
|
|
annotation_processor_flags :=
|
|
annotation_processor_deps :=
|
|
annotation_processor_jars :=
|
|
|
|
# If error prone is enabled then add LOCAL_ERROR_PRONE_FLAGS to LOCAL_JAVACFLAGS
|
|
ifeq ($(RUN_ERROR_PRONE),true)
|
|
annotation_processor_jars += $(ERROR_PRONE_JARS)
|
|
LOCAL_JAVACFLAGS += $(ERROR_PRONE_FLAGS)
|
|
LOCAL_JAVACFLAGS += '-Xplugin:ErrorProne $(ERROR_PRONE_CHECKS) $(LOCAL_ERROR_PRONE_FLAGS)'
|
|
endif
|
|
|
|
ifdef LOCAL_ANNOTATION_PROCESSORS
|
|
annotation_processor_jars += $(call java-lib-files,$(LOCAL_ANNOTATION_PROCESSORS),true)
|
|
|
|
# b/25860419: annotation processors must be explicitly specified for grok
|
|
annotation_processor_flags += $(foreach class,$(LOCAL_ANNOTATION_PROCESSOR_CLASSES),-processor $(class))
|
|
endif
|
|
|
|
ifneq (,$(strip $(annotation_processor_jars)))
|
|
annotation_processor_flags += -processorpath $(call normalize-path-list,$(annotation_processor_jars))
|
|
annotation_processor_deps += $(annotation_processor_jars)
|
|
endif
|
|
|
|
full_static_java_libs := $(call java-lib-files,$(LOCAL_STATIC_JAVA_LIBRARIES),$(LOCAL_IS_HOST_MODULE))
|
|
full_static_java_header_libs := $(call java-lib-header-files,$(LOCAL_STATIC_JAVA_LIBRARIES),$(LOCAL_IS_HOST_MODULE))
|
|
|
|
$(LOCAL_INTERMEDIATE_TARGETS): PRIVATE_STATIC_JAVA_LIBRARIES := $(full_static_java_libs)
|
|
$(LOCAL_INTERMEDIATE_TARGETS): PRIVATE_STATIC_JAVA_HEADER_LIBRARIES := $(full_static_java_header_libs)
|
|
|
|
$(LOCAL_INTERMEDIATE_TARGETS): PRIVATE_RESOURCE_DIR := $(LOCAL_RESOURCE_DIR)
|
|
$(LOCAL_INTERMEDIATE_TARGETS): PRIVATE_ASSET_DIR := $(LOCAL_ASSET_DIR)
|
|
|
|
$(LOCAL_INTERMEDIATE_TARGETS): PRIVATE_CLASS_INTERMEDIATES_DIR := $(intermediates.COMMON)/classes
|
|
$(LOCAL_INTERMEDIATE_TARGETS): PRIVATE_ANNO_INTERMEDIATES_DIR := $(intermediates.COMMON)/anno
|
|
$(LOCAL_INTERMEDIATE_TARGETS): PRIVATE_SOURCE_INTERMEDIATES_DIR := $(intermediates.COMMON)/src
|
|
$(LOCAL_INTERMEDIATE_TARGETS): PRIVATE_HAS_PROTO_SOURCES := $(if $(proto_sources),true)
|
|
$(LOCAL_INTERMEDIATE_TARGETS): PRIVATE_PROTO_SOURCE_INTERMEDIATES_DIR := $(intermediates.COMMON)/proto
|
|
$(LOCAL_INTERMEDIATE_TARGETS): PRIVATE_HAS_RS_SOURCES :=
|
|
$(LOCAL_INTERMEDIATE_TARGETS): PRIVATE_JAVA_SOURCES := $(all_java_sources)
|
|
$(LOCAL_INTERMEDIATE_TARGETS): PRIVATE_JAVA_SOURCE_LIST := $(java_source_list_file)
|
|
|
|
$(LOCAL_INTERMEDIATE_TARGETS): PRIVATE_RMTYPEDEFS := $(LOCAL_RMTYPEDEFS)
|
|
|
|
# Sanity check class path vars.
|
|
disallowed_deps := $(foreach sdk,$(TARGET_AVAILABLE_SDK_VERSIONS),$(call resolve-prebuilt-sdk-module,$(sdk)))
|
|
disallowed_deps += $(foreach sdk,$(TARGET_AVAILABLE_SDK_VERSIONS),\
|
|
$(foreach sdk_lib,$(JAVA_SDK_LIBRARIES),$(call resolve-prebuilt-sdk-module,$(sdk),$(sdk_lib))))
|
|
bad_deps := $(filter $(disallowed_deps),$(LOCAL_JAVA_LIBRARIES) $(LOCAL_STATIC_JAVA_LIBRARIES))
|
|
ifneq (,$(bad_deps))
|
|
$(call pretty-error,SDK modules should not be depended on directly. Please use LOCAL_SDK_VERSION for $(bad_deps))
|
|
endif
|
|
|
|
full_java_bootclasspath_libs :=
|
|
empty_bootclasspath :=
|
|
my_system_modules :=
|
|
exported_sdk_libs_files :=
|
|
my_exported_sdk_libs_file :=
|
|
|
|
ifndef LOCAL_IS_HOST_MODULE
|
|
sdk_libs :=
|
|
|
|
# When an sdk lib name is listed in LOCAL_JAVA_LIBRARIES, move it to LOCAL_SDK_LIBRARIES, so that
|
|
# it is correctly redirected to the stubs library.
|
|
LOCAL_SDK_LIBRARIES += $(filter $(JAVA_SDK_LIBRARIES),$(LOCAL_JAVA_LIBRARIES))
|
|
LOCAL_JAVA_LIBRARIES := $(filter-out $(JAVA_SDK_LIBRARIES),$(LOCAL_JAVA_LIBRARIES))
|
|
|
|
ifeq ($(LOCAL_SDK_VERSION),)
|
|
ifeq ($(LOCAL_NO_STANDARD_LIBRARIES),true)
|
|
# No bootclasspath. But we still need "" to prevent javac from using default host bootclasspath.
|
|
empty_bootclasspath := ""
|
|
# Most users of LOCAL_NO_STANDARD_LIBRARIES really mean no framework libs,
|
|
# and manually add back the core libs. The ones that don't are in soong
|
|
# now, so just always assume that they want the default system modules
|
|
my_system_modules := $(DEFAULT_SYSTEM_MODULES)
|
|
else # LOCAL_NO_STANDARD_LIBRARIES
|
|
full_java_bootclasspath_libs := $(call java-lib-header-files,$(TARGET_DEFAULT_BOOTCLASSPATH_LIBRARIES) $(TARGET_DEFAULT_JAVA_LIBRARIES))
|
|
LOCAL_JAVA_LIBRARIES := $(filter-out $(TARGET_DEFAULT_BOOTCLASSPATH_LIBRARIES) $(TARGET_DEFAULT_JAVA_LIBRARIES),$(LOCAL_JAVA_LIBRARIES))
|
|
my_system_modules := $(DEFAULT_SYSTEM_MODULES)
|
|
endif # LOCAL_NO_STANDARD_LIBRARIES
|
|
|
|
ifneq (,$(TARGET_BUILD_APPS_USE_PREBUILT_SDK))
|
|
sdk_libs := $(foreach lib_name,$(LOCAL_SDK_LIBRARIES),$(call resolve-prebuilt-sdk-module,system_current,$(lib_name)))
|
|
else
|
|
# When SDK libraries are referenced from modules built without SDK, provide the all APIs to them
|
|
sdk_libs := $(foreach lib_name,$(LOCAL_SDK_LIBRARIES),$(lib_name).impl)
|
|
endif
|
|
else
|
|
ifeq ($(LOCAL_NO_STANDARD_LIBRARIES),true)
|
|
$(call pretty-error,Must not define both LOCAL_NO_STANDARD_LIBRARIES and LOCAL_SDK_VERSION)
|
|
endif
|
|
ifeq ($(strip $(filter $(LOCAL_SDK_VERSION),$(TARGET_AVAILABLE_SDK_VERSIONS))),)
|
|
$(call pretty-error,Invalid LOCAL_SDK_VERSION '$(LOCAL_SDK_VERSION)' \
|
|
Choices are: $(TARGET_AVAILABLE_SDK_VERSIONS))
|
|
endif
|
|
|
|
ifneq (,$(TARGET_BUILD_APPS_USE_PREBUILT_SDK)$(filter-out %current,$(LOCAL_SDK_VERSION)))
|
|
# TARGET_BUILD_APPS mode or numbered SDK. Use prebuilt modules.
|
|
sdk_module := $(call resolve-prebuilt-sdk-module,$(LOCAL_SDK_VERSION))
|
|
sdk_libs := $(foreach lib_name,$(LOCAL_SDK_LIBRARIES),$(call resolve-prebuilt-sdk-module,$(LOCAL_SDK_VERSION),$(lib_name)))
|
|
else
|
|
# Note: the lib naming scheme must be kept in sync with build/soong/java/sdk_library.go.
|
|
sdk_lib_suffix = $(call pretty-error,sdk_lib_suffix was not set correctly)
|
|
ifeq (current,$(LOCAL_SDK_VERSION))
|
|
sdk_module := android_stubs_current
|
|
sdk_lib_suffix := .stubs
|
|
else ifeq (system_current,$(LOCAL_SDK_VERSION))
|
|
sdk_module := android_system_stubs_current
|
|
sdk_lib_suffix := .stubs.system
|
|
else ifeq (test_current,$(LOCAL_SDK_VERSION))
|
|
sdk_module := android_test_stubs_current
|
|
sdk_lib_suffix := .stubs.test
|
|
else ifeq (core_current,$(LOCAL_SDK_VERSION))
|
|
sdk_module := core.current.stubs
|
|
sdk_lib_suffix = $(call pretty-error,LOCAL_SDK_LIBRARIES not supported for LOCAL_SDK_VERSION = core_current)
|
|
endif
|
|
sdk_libs := $(foreach lib_name,$(LOCAL_SDK_LIBRARIES),$(lib_name)$(sdk_lib_suffix))
|
|
endif
|
|
full_java_bootclasspath_libs := $(call java-lib-header-files,$(sdk_module))
|
|
endif # LOCAL_SDK_VERSION
|
|
|
|
ifneq ($(LOCAL_NO_STANDARD_LIBRARIES),true)
|
|
ifneq ($(LOCAL_MODULE),jacocoagent)
|
|
ifeq ($(EMMA_INSTRUMENT),true)
|
|
ifneq ($(EMMA_INSTRUMENT_STATIC),true)
|
|
# For instrumented build, if Jacoco is not being included statically
|
|
# in instrumented packages then include Jacoco classes into the
|
|
# bootclasspath.
|
|
full_java_bootclasspath_libs += $(call java-lib-header-files,jacocoagent)
|
|
endif # EMMA_INSTRUMENT_STATIC
|
|
endif # EMMA_INSTRUMENT
|
|
endif # LOCAL_MODULE == jacocoagent
|
|
endif # LOCAL_NO_STANDARD_LIBRARIES
|
|
|
|
# In order to compile lambda code javac requires various invokedynamic-
|
|
# related classes to be present. This change adds stubs needed for
|
|
# javac to compile lambdas.
|
|
ifneq ($(LOCAL_NO_STANDARD_LIBRARIES),true)
|
|
ifdef TARGET_BUILD_APPS_USE_PREBUILT_SDK
|
|
full_java_bootclasspath_libs += $(call java-lib-header-files,sdk-core-lambda-stubs)
|
|
else
|
|
full_java_bootclasspath_libs += $(call java-lib-header-files,core-lambda-stubs)
|
|
endif
|
|
endif
|
|
full_shared_java_libs := $(call java-lib-files,$(LOCAL_JAVA_LIBRARIES) $(sdk_libs),$(LOCAL_IS_HOST_MODULE))
|
|
full_shared_java_header_libs := $(call java-lib-header-files,$(LOCAL_JAVA_LIBRARIES) $(sdk_libs),$(LOCAL_IS_HOST_MODULE))
|
|
sdk_libs :=
|
|
|
|
# Files that contains the names of SDK libraries exported from dependencies. These will be re-exported.
|
|
# Note: No need to consider LOCAL_*_ANDROID_LIBRARIES and LOCAL_STATIC_JAVA_AAR_LIBRARIES. They are all appended to
|
|
# LOCAL_*_JAVA_LIBRARIES in java.mk
|
|
exported_sdk_libs_files := $(call exported-sdk-libs-files,$(LOCAL_JAVA_LIBRARIES) $(LOCAL_STATIC_JAVA_LIBRARIES))
|
|
# The file that contains the names of all SDK libraries that this module exports and re-exports
|
|
my_exported_sdk_libs_file := $(call local-intermediates-dir,COMMON)/exported-sdk-libs
|
|
|
|
else # LOCAL_IS_HOST_MODULE
|
|
|
|
ifeq ($(USE_CORE_LIB_BOOTCLASSPATH),true)
|
|
ifeq ($(LOCAL_NO_STANDARD_LIBRARIES),true)
|
|
empty_bootclasspath := ""
|
|
else
|
|
full_java_bootclasspath_libs := $(call java-lib-header-files,$(addsuffix -hostdex,$(TARGET_DEFAULT_BOOTCLASSPATH_LIBRARIES)),true)
|
|
endif
|
|
|
|
my_system_modules := $(DEFAULT_SYSTEM_MODULES)
|
|
full_shared_java_libs := $(call java-lib-files,$(LOCAL_JAVA_LIBRARIES),true)
|
|
full_shared_java_header_libs := $(call java-lib-header-files,$(LOCAL_JAVA_LIBRARIES),true)
|
|
else # !USE_CORE_LIB_BOOTCLASSPATH
|
|
# Give host-side tools a version of OpenJDK's standard libraries
|
|
# close to what they're targeting. As of Dec 2017, AOSP is only
|
|
# bundling OpenJDK 8 and 9, so nothing < 8 is available.
|
|
#
|
|
# When building with OpenJDK 8, the following should have no
|
|
# effect since those jars would be available by default.
|
|
#
|
|
# When building with OpenJDK 9 but targeting a version < 1.8,
|
|
# putting them on the bootclasspath means that:
|
|
# a) code can't (accidentally) refer to OpenJDK 9 specific APIs
|
|
# b) references to existing APIs are not reinterpreted in an
|
|
# OpenJDK 9-specific way, eg. calls to subclasses of
|
|
# java.nio.Buffer as in http://b/70862583
|
|
ifeq ($(USE_HOST_BOOTSTRAP_JARS),true)
|
|
full_java_bootclasspath_libs += $(ANDROID_JAVA8_HOME)/jre/lib/jce.jar
|
|
full_java_bootclasspath_libs += $(ANDROID_JAVA8_HOME)/jre/lib/rt.jar
|
|
endif
|
|
full_shared_java_libs := $(addprefix $(HOST_OUT_JAVA_LIBRARIES)/,\
|
|
$(addsuffix $(COMMON_JAVA_PACKAGE_SUFFIX),$(LOCAL_JAVA_LIBRARIES)))
|
|
full_shared_java_header_libs := $(full_shared_java_libs)
|
|
endif # USE_CORE_LIB_BOOTCLASSPATH
|
|
endif # !LOCAL_IS_HOST_MODULE
|
|
|
|
|
|
# Export the SDK libs. The sdk library names listed in LOCAL_SDK_LIBRARIES are first exported.
|
|
# Then sdk library names exported from dependencies are all re-exported.
|
|
$(my_exported_sdk_libs_file): PRIVATE_EXPORTED_SDK_LIBS_FILES := $(exported_sdk_libs_files)
|
|
$(my_exported_sdk_libs_file): PRIVATE_SDK_LIBS := $(sort $(LOCAL_SDK_LIBRARIES))
|
|
$(my_exported_sdk_libs_file): $(exported_sdk_libs_files)
|
|
@echo "Export SDK libs $@"
|
|
$(hide) mkdir -p $(dir $@) && rm -f $@ $@.temp
|
|
$(if $(PRIVATE_SDK_LIBS),\
|
|
echo $(PRIVATE_SDK_LIBS) | tr ' ' '\n' > $@.temp,\
|
|
touch $@.temp)
|
|
$(if $(PRIVATE_EXPORTED_SDK_LIBS_FILES),\
|
|
cat $(PRIVATE_EXPORTED_SDK_LIBS_FILES) >> $@.temp)
|
|
$(hide) cat $@.temp | sort -u > $@
|
|
$(hide) rm -f $@.temp
|
|
|
|
ifdef empty_bootclasspath
|
|
ifdef full_java_bootclasspath_libs
|
|
$(call pretty-error,internal error: empty_bootclasspath and full_java_bootclasspath_libs should not both be set)
|
|
endif
|
|
endif
|
|
|
|
full_java_system_modules_deps :=
|
|
my_system_modules_dir :=
|
|
$(LOCAL_INTERMEDIATE_TARGETS): PRIVATE_USE_SYSTEM_MODULES :=
|
|
ifeq ($(LOCAL_JAVA_LANGUAGE_VERSION),1.9)
|
|
$(LOCAL_INTERMEDIATE_TARGETS): PRIVATE_USE_SYSTEM_MODULES := true
|
|
ifdef my_system_modules
|
|
ifneq ($(my_system_modules),none)
|
|
ifndef SOONG_SYSTEM_MODULES_$(my_system_modules)
|
|
$(call pretty-error, Invalid system modules $(my_system_modules))
|
|
endif
|
|
full_java_system_modules_deps := $(SOONG_SYSTEM_MODULES_$(my_system_modules))
|
|
my_system_modules_dir := $(patsubst %/lib/modules,%,$(SOONG_SYSTEM_MODULES_$(my_system_modules)))
|
|
endif
|
|
endif
|
|
endif
|
|
|
|
$(LOCAL_INTERMEDIATE_TARGETS): PRIVATE_BOOTCLASSPATH := $(full_java_bootclasspath_libs)
|
|
$(LOCAL_INTERMEDIATE_TARGETS): PRIVATE_EMPTY_BOOTCLASSPATH := $(empty_bootclasspath)
|
|
$(LOCAL_INTERMEDIATE_TARGETS): PRIVATE_SYSTEM_MODULES := $(my_system_modules)
|
|
$(LOCAL_INTERMEDIATE_TARGETS): PRIVATE_SYSTEM_MODULES_DIR := $(my_system_modules_dir)
|
|
$(LOCAL_INTERMEDIATE_TARGETS): PRIVATE_SYSTEM_MODULES_LIBS := $(call java-lib-files,$(SOONG_SYSTEM_MODULES_LIBS_$(my_system_modules)))
|
|
$(LOCAL_INTERMEDIATE_TARGETS): PRIVATE_PATCH_MODULE := $(LOCAL_PATCH_MODULE)
|
|
|
|
ifndef LOCAL_IS_HOST_MODULE
|
|
# This is set by packages that are linking to other packages that export
|
|
# shared libraries, allowing them to make use of the code in the linked apk.
|
|
apk_libraries := $(sort $(LOCAL_APK_LIBRARIES) $(LOCAL_RES_LIBRARIES))
|
|
ifneq ($(apk_libraries),)
|
|
link_apk_libraries := $(call app-lib-files,$(apk_libraries))
|
|
link_apk_header_libs := $(call app-lib-header-files,$(apk_libraries))
|
|
|
|
# link against the jar with full original names (before proguard processing).
|
|
full_shared_java_libs += $(link_apk_libraries)
|
|
full_shared_java_header_libs += $(link_apk_header_libs)
|
|
endif
|
|
|
|
# This is set by packages that contain instrumentation, allowing them to
|
|
# link against the package they are instrumenting. Currently only one such
|
|
# package is allowed.
|
|
LOCAL_INSTRUMENTATION_FOR := $(strip $(LOCAL_INSTRUMENTATION_FOR))
|
|
ifdef LOCAL_INSTRUMENTATION_FOR
|
|
ifneq ($(words $(LOCAL_INSTRUMENTATION_FOR)),1)
|
|
$(error \
|
|
$(LOCAL_PATH): Multiple LOCAL_INSTRUMENTATION_FOR members defined)
|
|
endif
|
|
|
|
link_instr_intermediates_dir.COMMON := $(call intermediates-dir-for, \
|
|
APPS,$(LOCAL_INSTRUMENTATION_FOR),,COMMON)
|
|
# link against the jar with full original names (before proguard processing).
|
|
link_instr_classes_jar := $(link_instr_intermediates_dir.COMMON)/classes-pre-proguard.jar
|
|
ifneq ($(TURBINE_ENABLED),false)
|
|
link_instr_classes_header_jar := $(link_instr_intermediates_dir.COMMON)/classes-header.jar
|
|
else
|
|
link_instr_classes_header_jar := $(link_instr_intermediates_dir.COMMON)/classes.jar
|
|
endif
|
|
full_shared_java_libs += $(link_instr_classes_jar)
|
|
full_shared_java_header_libs += $(link_instr_classes_header_jar)
|
|
endif # LOCAL_INSTRUMENTATION_FOR
|
|
endif # LOCAL_IS_HOST_MODULE
|
|
|
|
endif # need_compile_java
|
|
|
|
# We may want to add jar manifest or jar resource files even if there is no java code at all.
|
|
$(LOCAL_INTERMEDIATE_TARGETS): PRIVATE_EXTRA_JAR_ARGS := $(extra_jar_args)
|
|
jar_manifest_file :=
|
|
ifneq ($(strip $(LOCAL_JAR_MANIFEST)),)
|
|
jar_manifest_file := $(LOCAL_PATH)/$(LOCAL_JAR_MANIFEST)
|
|
$(LOCAL_INTERMEDIATE_TARGETS): PRIVATE_JAR_MANIFEST := $(jar_manifest_file)
|
|
else
|
|
$(LOCAL_INTERMEDIATE_TARGETS): PRIVATE_JAR_MANIFEST :=
|
|
endif
|
|
|
|
##########################################################
|
|
|
|
full_java_libs := $(full_shared_java_libs) $(full_static_java_libs) $(LOCAL_CLASSPATH)
|
|
full_java_header_libs := $(full_shared_java_header_libs) $(full_static_java_header_libs)
|
|
|
|
$(LOCAL_INTERMEDIATE_TARGETS): PRIVATE_ALL_JAVA_LIBRARIES := $(full_java_libs)
|
|
$(LOCAL_INTERMEDIATE_TARGETS): PRIVATE_ALL_JAVA_HEADER_LIBRARIES := $(full_java_header_libs)
|
|
$(LOCAL_INTERMEDIATE_TARGETS): PRIVATE_SHARED_JAVA_HEADER_LIBRARIES := $(full_shared_java_header_libs)
|
|
|
|
ALL_MODULES.$(my_register_name).INTERMEDIATE_SOURCE_DIR := \
|
|
$(ALL_MODULES.$(my_register_name).INTERMEDIATE_SOURCE_DIR) $(LOCAL_INTERMEDIATE_SOURCE_DIR)
|
|
|
|
|
|
##########################################################
|
|
# Copy NOTICE files of transitive static dependencies
|
|
# Don't do this in mm, since many of the targets won't exist.
|
|
ifeq ($(ONE_SHOT_MAKEFILE),)
|
|
installed_static_library_notice_file_targets := \
|
|
$(foreach lib,$(LOCAL_STATIC_JAVA_LIBRARIES), \
|
|
NOTICE-$(if $(LOCAL_IS_HOST_MODULE),HOST$(if $(my_host_cross),_CROSS,),TARGET)-JAVA_LIBRARIES-$(lib))
|
|
else
|
|
installed_static_library_notice_file_targets :=
|
|
endif
|
|
|
|
$(notice_target): | $(installed_static_library_notice_file_targets)
|
|
$(LOCAL_INSTALLED_MODULE): | $(notice_target)
|
|
|
|
###########################################################
|
|
# Verify that all libraries are safe to use
|
|
###########################################################
|
|
ifndef LOCAL_IS_HOST_MODULE
|
|
ifeq ($(LOCAL_SDK_VERSION),system_current)
|
|
my_link_type := java:system
|
|
my_warn_types :=
|
|
my_allowed_types := java:sdk java:system java:core
|
|
else ifneq (,$(call has-system-sdk-version,$(LOCAL_SDK_VERSION)))
|
|
my_link_type := java:system
|
|
my_warn_types :=
|
|
my_allowed_types := java:sdk java:system java:core
|
|
else ifeq ($(LOCAL_SDK_VERSION),core_current)
|
|
my_link_type := java:core
|
|
my_warn_types :=
|
|
my_allowed_types := java:core
|
|
else ifneq ($(LOCAL_SDK_VERSION),)
|
|
my_link_type := java:sdk
|
|
my_warn_types :=
|
|
my_allowed_types := java:sdk java:core
|
|
else
|
|
my_link_type := java:platform
|
|
my_warn_types :=
|
|
my_allowed_types := java:sdk java:system java:platform java:core
|
|
endif
|
|
|
|
ifdef LOCAL_AAPT2_ONLY
|
|
my_link_type += aapt2_only
|
|
endif
|
|
ifeq ($(LOCAL_USE_AAPT2),true)
|
|
my_allowed_types += aapt2_only
|
|
endif
|
|
|
|
my_link_deps := $(addprefix JAVA_LIBRARIES:,$(LOCAL_STATIC_JAVA_LIBRARIES) $(LOCAL_JAVA_LIBRARIES))
|
|
my_link_deps += $(addprefix APPS:,$(apk_libraries))
|
|
|
|
my_2nd_arch_prefix := $(LOCAL_2ND_ARCH_VAR_PREFIX)
|
|
my_common := COMMON
|
|
include $(BUILD_SYSTEM)/link_type.mk
|
|
endif # !LOCAL_IS_HOST_MODULE
|
|
|
|
ifneq ($(LOCAL_MODULE_MAKEFILE),$(SOONG_ANDROID_MK))
|
|
|
|
SOONG_CONV.$(LOCAL_MODULE).PROBLEMS := \
|
|
$(SOONG_CONV.$(LOCAL_MODULE).PROBLEMS) $(my_soong_problems)
|
|
SOONG_CONV.$(LOCAL_MODULE).DEPS := \
|
|
$(SOONG_CONV.$(LOCAL_MODULE).DEPS) \
|
|
$(LOCAL_STATIC_JAVA_LIBRARIES) \
|
|
$(LOCAL_JAVA_LIBRARIES) \
|
|
$(LOCAL_JNI_SHARED_LIBRARIES)
|
|
SOONG_CONV.$(LOCAL_MODULE).TYPE := java
|
|
SOONG_CONV := $(SOONG_CONV) $(LOCAL_MODULE)
|
|
|
|
endif
|