| # 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 |