| # |
| # Copyright (C) 2008 The Android Open Source Project |
| # |
| # 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. |
| # |
| |
| ########################################################### |
| ## Standard rules for building an application package. |
| ## |
| ## Additional inputs from base_rules.make: |
| ## LOCAL_PACKAGE_NAME: The name of the package; the directory |
| ## will be called this. |
| ## |
| ## MODULE, MODULE_PATH, and MODULE_SUFFIX will |
| ## be set for you. |
| ########################################################### |
| |
| LOCAL_PACKAGE_NAME := $(strip $(LOCAL_PACKAGE_NAME)) |
| ifeq ($(LOCAL_PACKAGE_NAME),) |
| $(error $(LOCAL_PATH): Package modules must define LOCAL_PACKAGE_NAME) |
| endif |
| |
| ifneq ($(strip $(LOCAL_MODULE_SUFFIX)),) |
| $(error $(LOCAL_PATH): Package modules may not define LOCAL_MODULE_SUFFIX) |
| endif |
| LOCAL_MODULE_SUFFIX := $(COMMON_ANDROID_PACKAGE_SUFFIX) |
| |
| ifneq ($(strip $(LOCAL_MODULE)),) |
| $(error $(LOCAL_PATH): Package modules may not define LOCAL_MODULE) |
| endif |
| LOCAL_MODULE := $(LOCAL_PACKAGE_NAME) |
| |
| ifneq ($(strip $(LOCAL_MODULE_CLASS)),) |
| $(error $(LOCAL_PATH): Package modules may not set LOCAL_MODULE_CLASS) |
| endif |
| LOCAL_MODULE_CLASS := APPS |
| |
| intermediates := $(call local-intermediates-dir) |
| intermediates.COMMON := $(call local-intermediates-dir,COMMON) |
| |
| # Package LOCAL_MODULE_TAGS default to optional |
| LOCAL_MODULE_TAGS := $(strip $(LOCAL_MODULE_TAGS)) |
| ifeq ($(LOCAL_MODULE_TAGS),) |
| LOCAL_MODULE_TAGS := optional |
| endif |
| |
| ifeq ($(filter tests, $(LOCAL_MODULE_TAGS)),) |
| # Force localization check if it's not tagged as tests. |
| LOCAL_AAPT_FLAGS := $(LOCAL_AAPT_FLAGS) -z |
| endif |
| |
| need_compile_asset := |
| ifeq (,$(LOCAL_ASSET_DIR)) |
| LOCAL_ASSET_DIR := $(LOCAL_PATH)/assets |
| else |
| need_compile_asset := true |
| endif |
| |
| # LOCAL_RESOURCE_DIR may point to resource generated during the build |
| need_compile_res := |
| ifeq (,$(LOCAL_RESOURCE_DIR)) |
| LOCAL_RESOURCE_DIR := $(LOCAL_PATH)/res |
| else |
| need_compile_res := true |
| LOCAL_RESOURCE_DIR := $(foreach d,$(LOCAL_RESOURCE_DIR),$(call clean-path,$(d))) |
| endif |
| |
| # If LOCAL_MODULE matches a rule in PRODUCT_MANIFEST_PACKAGE_NAME_OVERRIDES, |
| # override the manifest package name by the (first) rule matched |
| override_manifest_name := $(strip $(word 1,\ |
| $(foreach rule,$(PRODUCT_MANIFEST_PACKAGE_NAME_OVERRIDES),\ |
| $(eval _pkg_name_pat := $(call word-colon,1,$(rule)))\ |
| $(eval _manifest_name_pat := $(call word-colon,2,$(rule)))\ |
| $(if $(filter $(_pkg_name_pat),$(LOCAL_MODULE)),\ |
| $(patsubst $(_pkg_name_pat),$(_manifest_name_pat),$(LOCAL_MODULE))\ |
| )\ |
| )\ |
| )) |
| |
| ifneq (,$(override_manifest_name)) |
| # Note: this can override LOCAL_MANIFEST_PACKAGE_NAME value set in Android.mk |
| LOCAL_MANIFEST_PACKAGE_NAME := $(override_manifest_name) |
| endif |
| |
| include $(BUILD_SYSTEM)/force_aapt2.mk |
| |
| # Process Support Library dependencies. |
| include $(BUILD_SYSTEM)/support_libraries.mk |
| |
| # Determine whether auto-RRO is enabled for this package. |
| enforce_rro_enabled := |
| ifneq (,$(filter *, $(PRODUCT_ENFORCE_RRO_TARGETS))) |
| # * means all system APKs, so enable conditionally based on module path. |
| |
| # Note that base_rules.mk has not yet been included, so it's likely that only |
| # one of LOCAL_MODULE_PATH and the LOCAL_X_MODULE flags has been set. |
| ifeq (,$(LOCAL_MODULE_PATH)) |
| non_system_module := $(filter true,\ |
| $(LOCAL_ODM_MODULE) \ |
| $(LOCAL_OEM_MODULE) \ |
| $(LOCAL_PRODUCT_MODULE) \ |
| $(LOCAL_SYSTEM_EXT_MODULE) \ |
| $(LOCAL_PROPRIETARY_MODULE) \ |
| $(LOCAL_VENDOR_MODULE)) |
| enforce_rro_enabled := $(if $(non_system_module),,true) |
| else ifneq ($(filter $(TARGET_OUT)/%,$(LOCAL_MODULE_PATH)),) |
| enforce_rro_enabled := true |
| endif |
| else ifneq (,$(filter $(LOCAL_PACKAGE_NAME), $(PRODUCT_ENFORCE_RRO_TARGETS))) |
| enforce_rro_enabled := true |
| endif |
| |
| product_package_overlays := $(strip \ |
| $(wildcard $(foreach dir, $(PRODUCT_PACKAGE_OVERLAYS), \ |
| $(addprefix $(dir)/, $(LOCAL_RESOURCE_DIR))))) |
| device_package_overlays := $(strip \ |
| $(wildcard $(foreach dir, $(DEVICE_PACKAGE_OVERLAYS), \ |
| $(addprefix $(dir)/, $(LOCAL_RESOURCE_DIR))))) |
| |
| static_resource_overlays := |
| runtime_resource_overlays_product := |
| runtime_resource_overlays_vendor := |
| ifdef enforce_rro_enabled |
| ifneq ($(PRODUCT_ENFORCE_RRO_EXCLUDED_OVERLAYS),) |
| # The PRODUCT_ exclusion variable applies to both inclusion variables.. |
| static_resource_overlays += $(filter $(addsuffix %,$(PRODUCT_ENFORCE_RRO_EXCLUDED_OVERLAYS)),$(product_package_overlays)) |
| static_resource_overlays += $(filter $(addsuffix %,$(PRODUCT_ENFORCE_RRO_EXCLUDED_OVERLAYS)),$(device_package_overlays)) |
| endif |
| runtime_resource_overlays_product := $(filter-out $(static_resource_overlays),$(product_package_overlays)) |
| runtime_resource_overlays_vendor := $(filter-out $(static_resource_overlays),$(device_package_overlays)) |
| else |
| static_resource_overlays := $(product_package_overlays) $(device_package_overlays) |
| endif |
| |
| # Add the static overlays. Auto-RRO is created later, as it depends on |
| # other logic in this file. |
| LOCAL_RESOURCE_DIR := $(static_resource_overlays) $(LOCAL_RESOURCE_DIR) |
| |
| all_assets := $(strip \ |
| $(foreach dir, $(LOCAL_ASSET_DIR), \ |
| $(addprefix $(dir)/, \ |
| $(patsubst assets/%,%, \ |
| $(call find-subdir-assets, $(dir)) \ |
| ) \ |
| ) \ |
| )) |
| |
| ifneq ($(all_assets),) |
| need_compile_asset := true |
| endif |
| |
| my_res_package := |
| # In aapt2 the last takes precedence. |
| my_resource_dirs := $(call reverse-list,$(LOCAL_RESOURCE_DIR)) |
| my_res_dir := |
| my_overlay_res_dirs := |
| |
| ifneq ($(strip $(LOCAL_STATIC_ANDROID_LIBRARIES) $(LOCAL_STATIC_JAVA_AAR_LIBRARIES)),) |
| # If we are using static android libraries, every source file becomes an overlay. |
| # This is to emulate old AAPT behavior which simulated library support. |
| my_res_dir := |
| my_overlay_res_dirs := $(my_resource_dirs) |
| else |
| # Without static libraries, the first directory is our directory, which can then be |
| # overlaid by the rest. (First directory in my_resource_dirs is last directory in |
| # $(LOCAL_RESOURCE_DIR) due to it being reversed. |
| my_res_dir := $(firstword $(my_resource_dirs)) |
| my_overlay_res_dirs := $(wordlist 2,999,$(my_resource_dirs)) |
| endif |
| |
| my_overlay_resources := $(strip \ |
| $(foreach d,$(my_overlay_res_dirs),\ |
| $(addprefix $(d)/, \ |
| $(call find-subdir-assets,$(d))))) |
| |
| my_res_resources := $(if $(my_res_dir),$(strip \ |
| $(addprefix $(my_res_dir)/, \ |
| $(call find-subdir-assets,$(my_res_dir))))) |
| |
| all_resources := $(strip $(my_res_resources) $(my_overlay_resources)) |
| |
| # The linked resource package. |
| my_res_package := $(intermediates)/package-res.apk |
| LOCAL_INTERMEDIATE_TARGETS += $(my_res_package) |
| |
| my_bundle_module := $(intermediates)/base.zip |
| LOCAL_INTERMEDIATE_TARGETS += $(my_bundle_module) |
| |
| # Always run aapt2, because we need to at least compile the AndroidManifest.xml. |
| need_compile_res := true |
| |
| ifneq ($(all_resources),) |
| need_compile_res := true |
| endif |
| |
| all_res_assets := $(strip $(all_assets) $(all_resources)) |
| |
| # If no assets or resources were found, clear the directory variables so |
| # we don't try to build them. |
| ifneq (true,$(need_compile_asset)) |
| LOCAL_ASSET_DIR:= |
| endif |
| ifneq (true,$(need_compile_res)) |
| LOCAL_RESOURCE_DIR:= |
| R_file_stamp := |
| else |
| # Make sure that R_file_stamp inherits the proper PRIVATE vars. |
| # If R.stamp moves, be sure to update the framework makefile, |
| # which has intimate knowledge of its location. |
| R_file_stamp := $(intermediates.COMMON)/src/R.stamp |
| LOCAL_INTERMEDIATE_TARGETS += $(R_file_stamp) |
| endif |
| |
| ifdef LOCAL_COMPRESSED_MODULE |
| ifneq (true,$(LOCAL_COMPRESSED_MODULE)) |
| $(call pretty-error, Unknown value for LOCAL_COMPRESSED_MODULE $(LOCAL_COMPRESSED_MODULE)) |
| endif |
| endif |
| |
| ifdef LOCAL_COMPRESSED_MODULE |
| PACKAGES.$(LOCAL_PACKAGE_NAME).COMPRESSED := gz |
| LOCAL_BUILT_MODULE_STEM := package.apk.gz |
| LOCAL_INSTALLED_MODULE_STEM := $(LOCAL_MODULE).apk.gz |
| else # !LOCAL_COMPRESSED_MODULE |
| LOCAL_BUILT_MODULE_STEM := package.apk |
| LOCAL_INSTALLED_MODULE_STEM := $(LOCAL_MODULE).apk |
| endif |
| |
| LOCAL_PROGUARD_ENABLED:=$(strip $(LOCAL_PROGUARD_ENABLED)) |
| ifndef LOCAL_PROGUARD_ENABLED |
| ifneq ($(DISABLE_PROGUARD),true) |
| LOCAL_PROGUARD_ENABLED :=full |
| endif |
| endif |
| ifeq ($(LOCAL_PROGUARD_ENABLED),disabled) |
| # the package explicitly request to disable proguard. |
| LOCAL_PROGUARD_ENABLED := |
| endif |
| proguard_options_file := |
| ifneq ($(LOCAL_PROGUARD_ENABLED),custom) |
| ifeq ($(need_compile_res),true) |
| proguard_options_file := $(intermediates.COMMON)/proguard_options |
| endif # need_compile_res |
| endif # !custom |
| LOCAL_PROGUARD_FLAGS := $(addprefix -include ,$(proguard_options_file)) $(LOCAL_PROGUARD_FLAGS) |
| LOCAL_PROGUARD_FLAGS_DEPS += $(proguard_options_file) |
| |
| ifeq (true,$(EMMA_INSTRUMENT)) |
| ifndef LOCAL_EMMA_INSTRUMENT |
| # No jacoco for test apks. |
| ifeq (,$(LOCAL_INSTRUMENTATION_FOR)) |
| LOCAL_EMMA_INSTRUMENT := true |
| endif # No test apk |
| endif # LOCAL_EMMA_INSTRUMENT is not set |
| else |
| LOCAL_EMMA_INSTRUMENT := false |
| endif # EMMA_INSTRUMENT is true |
| |
| ifeq (true,$(LOCAL_EMMA_INSTRUMENT)) |
| ifeq (true,$(EMMA_INSTRUMENT_STATIC)) |
| ifneq ($(LOCAL_SRC_FILES)$(LOCAL_SRCJARS)$(LOCAL_STATIC_JAVA_LIBRARIES)$(LOCAL_SOURCE_FILES_ALL_GENERATED),) |
| # Only add jacocoagent if the package contains some java code |
| LOCAL_STATIC_JAVA_LIBRARIES += jacocoagent |
| # Exclude jacoco classes from proguard |
| LOCAL_PROGUARD_FLAGS += -include $(BUILD_SYSTEM)/proguard.jacoco.flags |
| LOCAL_PROGUARD_FLAGS_DEPS += $(BUILD_SYSTEM)/proguard.jacoco.flags |
| endif # Contains java code |
| else |
| ifdef LOCAL_SDK_VERSION |
| ifdef TARGET_BUILD_APPS |
| # In unbundled build, merge the coverage library into the apk. |
| ifneq ($(LOCAL_SRC_FILES)$(LOCAL_STATIC_JAVA_LIBRARIES)$(LOCAL_SOURCE_FILES_ALL_GENERATED),) |
| # Only add jacocoagent if the package contains some java code |
| LOCAL_STATIC_JAVA_LIBRARIES += jacocoagent |
| # Exclude jacoco classes from proguard |
| LOCAL_PROGUARD_FLAGS += -include $(BUILD_SYSTEM)/proguard.jacoco.flags |
| LOCAL_PROGUARD_FLAGS_DEPS += $(BUILD_SYSTEM)/proguard.jacoco.flags |
| endif # Contains java code |
| endif # TARGET_BUILD_APPS |
| endif # LOCAL_SDK_VERSION |
| endif # EMMA_INSTRUMENT_STATIC |
| endif # LOCAL_EMMA_INSTRUMENT |
| |
| rs_compatibility_jni_libs := |
| |
| # If the module is a compressed module, we don't pre-opt it because its final |
| # installation location will be the data partition. |
| ifdef LOCAL_COMPRESSED_MODULE |
| LOCAL_DEX_PREOPT := false |
| endif |
| |
| # Default to use uncompressed native libraries in APKs if minSdkVersion >= marshmallow |
| ifndef LOCAL_USE_EMBEDDED_NATIVE_LIBS |
| LOCAL_USE_EMBEDDED_NATIVE_LIBS := $(call math_gt_or_eq, \ |
| $(patsubst $(PLATFORM_VERSION_CODENAME),100,$(call module-min-sdk-version)),23) |
| endif |
| |
| include $(BUILD_SYSTEM)/android_manifest.mk |
| |
| resource_export_package := |
| |
| include $(BUILD_SYSTEM)/java_renderscript.mk |
| |
| include $(BUILD_SYSTEM)/aapt_flags.mk |
| |
| ifeq ($(need_compile_res),true) |
| |
| ############################### |
| ## APK splits |
| built_apk_splits := |
| installed_apk_splits := |
| my_apk_split_configs := |
| |
| ifdef LOCAL_PACKAGE_SPLITS |
| ifdef LOCAL_COMPRESSED_MODULE |
| $(error $(LOCAL_MODULE): LOCAL_COMPRESSED_MODULE is not currently supported for split installs) |
| endif # LOCAL_COMPRESSED_MODULE |
| |
| my_apk_split_configs := $(LOCAL_PACKAGE_SPLITS) |
| my_split_suffixes := $(subst $(comma),_,$(my_apk_split_configs)) |
| built_apk_splits := $(foreach s,$(my_split_suffixes),$(intermediates)/package_$(s).apk) |
| endif |
| |
| $(R_file_stamp) $(my_res_package): PRIVATE_AAPT_FLAGS := $(filter-out --legacy,$(LOCAL_AAPT_FLAGS)) |
| $(R_file_stamp) $(my_res_package): PRIVATE_TARGET_AAPT_CHARACTERISTICS := $(TARGET_AAPT_CHARACTERISTICS) |
| $(R_file_stamp) $(my_res_package): PRIVATE_MANIFEST_PACKAGE_NAME := $(LOCAL_MANIFEST_PACKAGE_NAME) |
| $(R_file_stamp) $(my_res_package): PRIVATE_MANIFEST_INSTRUMENTATION_FOR := $(LOCAL_MANIFEST_INSTRUMENTATION_FOR) |
| |
| ############################### |
| ## AAPT2 |
| |
| my_compiled_res_base_dir := $(intermediates.COMMON)/flat-res |
| ifneq (,$(filter-out current,$(renderscript_target_api))) |
| ifneq ($(call math_gt_or_eq,$(renderscript_target_api),21),true) |
| my_generated_res_zips := $(rs_generated_res_zip) |
| endif # renderscript_target_api < 21 |
| endif # renderscript_target_api is set |
| my_asset_dirs := $(LOCAL_ASSET_DIR) |
| my_full_asset_paths := $(all_assets) |
| |
| # Add AAPT2 link specific flags. |
| ifndef LOCAL_AAPT_NAMESPACES |
| $(my_res_package): PRIVATE_AAPT_FLAGS += --no-static-lib-packages |
| endif |
| |
| include $(BUILD_SYSTEM)/aapt2.mk |
| |
| endif # need_compile_res |
| |
| my_dex_jar := $(intermediates.COMMON)/dex.jar |
| |
| called_from_package_internal := true |
| ################################# |
| include $(BUILD_SYSTEM)/java.mk |
| ################################# |
| called_from_package_internal := |
| |
| ifeq ($(need_compile_res),true) |
| |
| # Other modules should depend on the BUILT module if |
| # they want to use this module's R.java file. |
| $(LOCAL_BUILT_MODULE): $(R_file_stamp) |
| |
| # The R.java file must exist by the time the java source |
| # list is generated |
| $(java_source_list_file): $(R_file_stamp) |
| |
| endif # need_compile_res |
| |
| LOCAL_SDK_RES_VERSION:=$(strip $(LOCAL_SDK_RES_VERSION)) |
| ifeq ($(LOCAL_SDK_RES_VERSION),) |
| LOCAL_SDK_RES_VERSION:=$(LOCAL_SDK_VERSION) |
| endif |
| |
| $(LOCAL_INTERMEDIATE_TARGETS): \ |
| PRIVATE_ANDROID_MANIFEST := $(full_android_manifest) |
| |
| framework_res_package_export := |
| |
| ifneq ($(LOCAL_NO_STANDARD_LIBRARIES),true) |
| # Most packages should link against the resources defined by framework-res. |
| # Even if they don't have their own resources, they may use framework |
| # resources. |
| ifeq ($(LOCAL_SDK_RES_VERSION),core_current) |
| # core_current doesn't contain any framework resources. |
| else ifneq ($(filter-out current system_current test_current,$(LOCAL_SDK_RES_VERSION))$(if $(TARGET_BUILD_APPS_USE_PREBUILT_SDK),$(filter current system_current test_current,$(LOCAL_SDK_RES_VERSION))),) |
| # for released sdk versions, the platform resources were built into android.jar. |
| framework_res_package_export := \ |
| $(call resolve-prebuilt-sdk-jar-path,$(LOCAL_SDK_RES_VERSION)) |
| else # LOCAL_SDK_RES_VERSION |
| framework_res_package_export := \ |
| $(call intermediates-dir-for,APPS,framework-res,,COMMON)/package-export.apk |
| endif # LOCAL_SDK_RES_VERSION |
| endif # LOCAL_NO_STANDARD_LIBRARIES |
| |
| all_library_res_package_exports := \ |
| $(framework_res_package_export) \ |
| $(foreach lib,$(LOCAL_RES_LIBRARIES),\ |
| $(call intermediates-dir-for,APPS,$(lib),,COMMON)/package-export.apk) |
| |
| all_library_res_package_export_deps := \ |
| $(framework_res_package_export) \ |
| $(foreach lib,$(LOCAL_RES_LIBRARIES),\ |
| $(call intermediates-dir-for,APPS,$(lib),,COMMON)/src/R.stamp) |
| $(resource_export_package) $(R_file_stamp) $(LOCAL_BUILT_MODULE): $(all_library_res_package_export_deps) |
| $(LOCAL_INTERMEDIATE_TARGETS): \ |
| PRIVATE_AAPT_INCLUDES := $(all_library_res_package_exports) |
| |
| $(my_res_package) : $(all_library_res_package_export_deps) |
| |
| ifneq ($(full_classes_jar),) |
| $(LOCAL_BUILT_MODULE): PRIVATE_DEX_FILE := $(built_dex) |
| # Use the jarjar processed arhive as the initial package file. |
| $(LOCAL_BUILT_MODULE): PRIVATE_SOURCE_ARCHIVE := $(full_classes_pre_proguard_jar) |
| $(LOCAL_BUILT_MODULE): $(built_dex) $(full_classes_pre_proguard_jar) |
| else |
| $(LOCAL_BUILT_MODULE): PRIVATE_DEX_FILE := |
| $(LOCAL_BUILT_MODULE): PRIVATE_SOURCE_ARCHIVE := |
| endif # full_classes_jar |
| |
| include $(BUILD_SYSTEM)/install_jni_libs.mk |
| |
| # Pick a key to sign the package with. If this package hasn't specified |
| # an explicit certificate, use the default. |
| # Secure release builds will have their packages signed after the fact, |
| # so it's ok for these private keys to be in the clear. |
| ifeq ($(LOCAL_CERTIFICATE),) |
| LOCAL_CERTIFICATE := $(DEFAULT_SYSTEM_DEV_CERTIFICATE) |
| endif |
| |
| ifeq ($(LOCAL_CERTIFICATE),EXTERNAL) |
| # The special value "EXTERNAL" means that we will sign it with the |
| # default devkey, apply predexopt, but then expect the final .apk |
| # (after dexopting) to be signed by an outside tool. |
| LOCAL_CERTIFICATE := $(DEFAULT_SYSTEM_DEV_CERTIFICATE) |
| PACKAGES.$(LOCAL_PACKAGE_NAME).EXTERNAL_KEY := 1 |
| endif |
| |
| # If this is not an absolute certificate, assign it to a generic one. |
| ifeq ($(dir $(strip $(LOCAL_CERTIFICATE))),./) |
| LOCAL_CERTIFICATE := $(dir $(DEFAULT_SYSTEM_DEV_CERTIFICATE))$(LOCAL_CERTIFICATE) |
| endif |
| include $(BUILD_SYSTEM)/app_certificate_validate.mk |
| private_key := $(LOCAL_CERTIFICATE).pk8 |
| certificate := $(LOCAL_CERTIFICATE).x509.pem |
| additional_certificates := $(foreach c,$(LOCAL_ADDITIONAL_CERTIFICATES), $(c).x509.pem $(c).pk8) |
| |
| $(LOCAL_BUILT_MODULE): $(private_key) $(certificate) $(SIGNAPK_JAR) $(SIGNAPK_JNI_LIBRARY_PATH) |
| $(LOCAL_BUILT_MODULE): PRIVATE_PRIVATE_KEY := $(private_key) |
| $(LOCAL_BUILT_MODULE): PRIVATE_CERTIFICATE := $(certificate) |
| |
| PACKAGES.$(LOCAL_PACKAGE_NAME).PRIVATE_KEY := $(private_key) |
| PACKAGES.$(LOCAL_PACKAGE_NAME).CERTIFICATE := $(certificate) |
| |
| $(LOCAL_BUILT_MODULE): $(additional_certificates) |
| $(LOCAL_BUILT_MODULE): PRIVATE_ADDITIONAL_CERTIFICATES := $(additional_certificates) |
| |
| # Verify LOCAL_USES_LIBRARIES/LOCAL_OPTIONAL_USES_LIBRARIES |
| # If LOCAL_ENFORCE_USES_LIBRARIES is not set, default to true if either of LOCAL_USES_LIBRARIES or |
| # LOCAL_OPTIONAL_USES_LIBRARIES are specified. |
| # Will change the default to true unconditionally in the future. |
| ifndef LOCAL_ENFORCE_USES_LIBRARIES |
| ifneq (,$(strip $(LOCAL_USES_LIBRARIES)$(LOCAL_OPTIONAL_USES_LIBRARIES))) |
| LOCAL_ENFORCE_USES_LIBRARIES := true |
| endif |
| endif |
| |
| my_enforced_uses_libraries := |
| ifdef LOCAL_ENFORCE_USES_LIBRARIES |
| my_manifest_check := $(intermediates.COMMON)/manifest/AndroidManifest.xml.check |
| $(my_manifest_check): $(MANIFEST_CHECK) |
| $(my_manifest_check): PRIVATE_USES_LIBRARIES := $(LOCAL_USES_LIBRARIES) |
| $(my_manifest_check): PRIVATE_OPTIONAL_USES_LIBRARIES := $(LOCAL_OPTIONAL_USES_LIBRARIES) |
| $(my_manifest_check): $(full_android_manifest) |
| @echo Checking manifest: $< |
| $(MANIFEST_CHECK) --enforce-uses-libraries \ |
| $(addprefix --uses-library ,$(PRIVATE_USES_LIBRARIES)) \ |
| $(addprefix --optional-uses-library ,$(PRIVATE_OPTIONAL_USES_LIBRARIES)) \ |
| $< -o $@ |
| $(LOCAL_BUILT_MODULE): $(my_manifest_check) |
| endif |
| |
| # Define the rule to build the actual package. |
| # PRIVATE_JNI_SHARED_LIBRARIES is a list of <abi>:<path_of_built_lib>. |
| $(LOCAL_BUILT_MODULE): PRIVATE_JNI_SHARED_LIBRARIES := $(jni_shared_libraries_with_abis) |
| # PRIVATE_JNI_SHARED_LIBRARIES_ABI is a list of ABI names. |
| $(LOCAL_BUILT_MODULE): PRIVATE_JNI_SHARED_LIBRARIES_ABI := $(jni_shared_libraries_abis) |
| ifneq ($(TARGET_BUILD_APPS),) |
| # Include all resources for unbundled apps. |
| LOCAL_AAPT_INCLUDE_ALL_RESOURCES := true |
| endif |
| ifeq ($(LOCAL_AAPT_INCLUDE_ALL_RESOURCES),true) |
| $(my_res_package) $(LOCAL_BUILT_MODULE): PRIVATE_PRODUCT_AAPT_CONFIG := |
| $(my_res_package) $(LOCAL_BUILT_MODULE): PRIVATE_PRODUCT_AAPT_PREF_CONFIG := |
| else |
| $(my_res_package) $(LOCAL_BUILT_MODULE): PRIVATE_PRODUCT_AAPT_CONFIG := $(PRODUCT_AAPT_CONFIG) |
| ifdef LOCAL_PACKAGE_SPLITS |
| $(my_res_package) $(LOCAL_BUILT_MODULE): PRIVATE_PRODUCT_AAPT_PREF_CONFIG := |
| else |
| $(my_res_package) $(LOCAL_BUILT_MODULE): PRIVATE_PRODUCT_AAPT_PREF_CONFIG := $(PRODUCT_AAPT_PREF_CONFIG) |
| endif |
| endif |
| |
| # Run veridex on product, system_ext and vendor modules. |
| # We skip it for unbundled app builds where we cannot build veridex. |
| module_run_appcompat := |
| ifeq (true,$(non_system_module)) |
| ifeq (,$(TARGET_BUILD_APPS)$(filter true,$(TARGET_BUILD_PDK))) # ! unbundled app build |
| ifneq ($(UNSAFE_DISABLE_HIDDENAPI_FLAGS),true) |
| module_run_appcompat := true |
| endif |
| endif |
| endif |
| |
| ifeq ($(module_run_appcompat),true) |
| $(LOCAL_BUILT_MODULE) : $(appcompat-files) |
| $(LOCAL_BUILT_MODULE): PRIVATE_INSTALLED_MODULE := $(LOCAL_INSTALLED_MODULE) |
| endif |
| |
| $(LOCAL_BUILT_MODULE): PRIVATE_RESOURCE_INTERMEDIATES_DIR := $(intermediates.COMMON)/resources |
| $(LOCAL_BUILT_MODULE) : $(jni_shared_libraries) |
| $(LOCAL_BUILT_MODULE) : $(JAR_ARGS) $(SOONG_ZIP) $(MERGE_ZIPS) $(ZIP2ZIP) |
| $(LOCAL_BUILT_MODULE): PRIVATE_RES_PACKAGE := $(my_res_package) |
| $(LOCAL_BUILT_MODULE) : $(my_res_package) $(AAPT2) |
| ifdef LOCAL_COMPRESSED_MODULE |
| $(LOCAL_BUILT_MODULE) : $(MINIGZIP) |
| endif |
| ifeq (true, $(LOCAL_UNCOMPRESS_DEX)) |
| $(LOCAL_BUILT_MODULE) : $(ZIP2ZIP) |
| endif |
| ifneq ($(BUILD_PLATFORM_ZIP),) |
| $(LOCAL_BUILT_MODULE) : .KATI_IMPLICIT_OUTPUTS := $(dir $(LOCAL_BUILT_MODULE))package.dex.apk |
| endif |
| ifdef LOCAL_DEX_PREOPT |
| $(LOCAL_BUILT_MODULE) : PRIVATE_STRIP_SCRIPT := $(intermediates)/strip.sh |
| $(LOCAL_BUILT_MODULE) : $(intermediates)/strip.sh |
| $(LOCAL_BUILT_MODULE) : | $(DEXPREOPT_STRIP_DEPS) |
| $(LOCAL_BUILT_MODULE): .KATI_DEPFILE := $(LOCAL_BUILT_MODULE).d |
| endif |
| $(LOCAL_BUILT_MODULE): PRIVATE_USE_EMBEDDED_NATIVE_LIBS := $(LOCAL_USE_EMBEDDED_NATIVE_LIBS) |
| $(LOCAL_BUILT_MODULE): |
| @echo "target Package: $(PRIVATE_MODULE) ($@)" |
| rm -rf $@.parts |
| mkdir -p $@.parts |
| cp -f $(PRIVATE_RES_PACKAGE) $@.parts/apk.zip |
| ifneq ($(jni_shared_libraries),) |
| $(call create-jni-shared-libs-package,$@.parts/jni.zip,$(PRIVATE_USE_EMBEDDED_NATIVE_LIBS)) |
| endif |
| ifeq ($(full_classes_jar),) |
| # We don't build jar, need to add the Java resources here. |
| $(if $(PRIVATE_EXTRA_JAR_ARGS),$(call create-java-resources-jar,$@.parts/res.zip)) |
| else # full_classes_jar |
| $(call create-dex-jar,$@.parts/dex.zip,$(PRIVATE_DEX_FILE)) |
| $(call extract-resources-jar,$@.parts/res.zip,$(PRIVATE_SOURCE_ARCHIVE)) |
| endif # full_classes_jar |
| $(MERGE_ZIPS) $@ $@.parts/*.zip |
| rm -rf $@.parts |
| ifeq (true, $(LOCAL_UNCOMPRESS_DEX)) |
| @# No need to align, sign-package below will do it. |
| $(uncompress-dexs) |
| endif |
| # Run appcompat before stripping the classes.dex file. |
| ifeq ($(module_run_appcompat),true) |
| $(appcompat-header) |
| $(run-appcompat) |
| endif # module_run_appcompat |
| ifdef LOCAL_DEX_PREOPT |
| ifneq ($(BUILD_PLATFORM_ZIP),) |
| @# Keep a copy of apk with classes.dex unstripped |
| $(hide) cp -f $@ $(dir $@)package.dex.apk |
| endif # BUILD_PLATFORM_ZIP |
| mv -f $@ $@.tmp |
| $(PRIVATE_STRIP_SCRIPT) $@.tmp $@ |
| endif # LOCAL_DEX_PREOPT |
| $(sign-package) |
| ifdef LOCAL_COMPRESSED_MODULE |
| $(compress-package) |
| endif # LOCAL_COMPRESSED_MODULE |
| |
| my_package_res_pb := $(intermediates)/package-res.pb.apk |
| $(my_package_res_pb): $(my_res_package) $(AAPT2) |
| $(AAPT2) convert --output-format proto $< -o $@ |
| |
| $(my_bundle_module): $(my_package_res_pb) |
| $(my_bundle_module): PRIVATE_RES_PACKAGE := $(my_package_res_pb) |
| |
| $(my_bundle_module): $(jni_shared_libraries) |
| $(my_bundle_module): PRIVATE_JNI_SHARED_LIBRARIES := $(jni_shared_libraries_with_abis) |
| $(my_bundle_module): PRIVATE_JNI_SHARED_LIBRARIES_ABI := $(jni_shared_libraries_abis) |
| |
| ifneq ($(full_classes_jar),) |
| $(my_bundle_module): PRIVATE_DEX_FILE := $(built_dex) |
| # Use the jarjar processed archive as the initial package file. |
| $(my_bundle_module): PRIVATE_SOURCE_ARCHIVE := $(full_classes_pre_proguard_jar) |
| $(my_bundle_module): $(built_dex) |
| else |
| $(my_bundle_module): PRIVATE_DEX_FILE := |
| $(my_bundle_module): PRIVATE_SOURCE_ARCHIVE := |
| endif # full_classes_jar |
| |
| $(my_bundle_module): $(MERGE_ZIPS) $(SOONG_ZIP) $(ZIP2ZIP) |
| @echo "target Bundle: $(PRIVATE_MODULE) ($@)" |
| rm -rf $@.parts |
| mkdir -p $@.parts |
| $(ZIP2ZIP) -i $(PRIVATE_RES_PACKAGE) -o $@.parts/apk.zip AndroidManifest.xml:manifest/AndroidManifest.xml resources.pb "res/**/*" "assets/**/*" |
| ifneq ($(jni_shared_libraries),) |
| $(call create-jni-shared-libs-package,$@.parts/jni.zip) |
| endif |
| ifeq ($(full_classes_jar),) |
| # We don't build jar, need to add the Java resources here. |
| $(if $(PRIVATE_EXTRA_JAR_ARGS),\ |
| $(call create-java-resources-jar,$@.parts/res.zip) && \ |
| $(ZIP2ZIP) -i $@.parts/res.zip -o $@.parts/res.zip.tmp "**/*:root/" && \ |
| mv -f $@.parts/res.zip.tmp $@.parts/res.zip) |
| else # full_classes_jar |
| $(call create-dex-jar,$@.parts/dex.zip,$(PRIVATE_DEX_FILE)) |
| $(ZIP2ZIP) -i $@.parts/dex.zip -o $@.parts/dex.zip.tmp "classes*.dex:dex/" |
| mv -f $@.parts/dex.zip.tmp $@.parts/dex.zip |
| $(call extract-resources-jar,$@.parts/res.zip,$(PRIVATE_SOURCE_ARCHIVE)) |
| $(ZIP2ZIP) -i $@.parts/res.zip -o $@.parts/res.zip.tmp "**/*:root/" |
| mv -f $@.parts/res.zip.tmp $@.parts/res.zip |
| endif # full_classes_jar |
| $(MERGE_ZIPS) $@ $@.parts/*.zip |
| rm -rf $@.parts |
| ALL_MODULES.$(LOCAL_MODULE).BUNDLE := $(my_bundle_module) |
| |
| ifdef TARGET_BUILD_APPS |
| ifdef LOCAL_DPI_VARIANTS |
| $(call pretty-error,Building DPI-specific APKs is no longer supported) |
| endif |
| endif |
| |
| ############################### |
| ## Rule to build a jar containing dex files to dexpreopt without waiting for |
| ## the APK |
| ifdef LOCAL_DEX_PREOPT |
| $(my_dex_jar): PRIVATE_DEX_FILE := $(built_dex) |
| $(my_dex_jar): $(built_dex) $(SOONG_ZIP) |
| $(hide) mkdir -p $(dir $@) && rm -f $@ |
| $(call create-dex-jar,$@,$(PRIVATE_DEX_FILE)) |
| endif |
| |
| ############################### |
| ## APK splits |
| ifdef LOCAL_PACKAGE_SPLITS |
| # The splits should have been built in the same command building the base apk. |
| # This rule just runs signing. |
| # Note that we explicily check the existence of the split apk and remove the |
| # built base apk if the split apk isn't there. |
| # That way the build system will rerun the aapt after the user changes the splitting parameters. |
| $(built_apk_splits): PRIVATE_PRIVATE_KEY := $(private_key) |
| $(built_apk_splits): PRIVATE_CERTIFICATE := $(certificate) |
| $(built_apk_splits) : $(intermediates)/%.apk : $(LOCAL_BUILT_MODULE) |
| $(hide) if [ ! -f $@ ]; then \ |
| echo 'No $@ generated, check your apk splitting parameters.' 1>&2; \ |
| rm $<; exit 1; \ |
| fi |
| $(sign-package) |
| |
| # Rules to install the splits |
| installed_apk_splits := $(foreach s,$(my_split_suffixes),$(my_module_path)/$(LOCAL_MODULE)_$(s).apk) |
| $(installed_apk_splits) : $(my_module_path)/$(LOCAL_MODULE)_%.apk : $(intermediates)/package_%.apk |
| @echo "Install: $@" |
| $(copy-file-to-new-target) |
| |
| # Register the additional built and installed files. |
| ALL_MODULES.$(my_register_name).INSTALLED += $(installed_apk_splits) |
| ALL_MODULES.$(my_register_name).BUILT_INSTALLED += \ |
| $(foreach s,$(my_split_suffixes),$(intermediates)/package_$(s).apk:$(my_module_path)/$(LOCAL_MODULE)_$(s).apk) |
| |
| # Make sure to install the splits when you run "make <module_name>". |
| $(my_all_targets): $(installed_apk_splits) |
| |
| ifdef LOCAL_COMPATIBILITY_SUITE |
| |
| $(foreach suite, $(LOCAL_COMPATIBILITY_SUITE), \ |
| $(eval my_compat_dist_$(suite) := $(foreach dir, $(call compatibility_suite_dirs,$(suite)), \ |
| $(foreach s,$(my_split_suffixes),\ |
| $(call compat-copy-pair,$(intermediates)/package_$(s).apk,$(dir)/$(LOCAL_MODULE)_$(s).apk))))) |
| |
| $(call create-suite-dependencies) |
| |
| endif # LOCAL_COMPATIBILITY_SUITE |
| endif # LOCAL_PACKAGE_SPLITS |
| |
| # Save information about this package |
| PACKAGES.$(LOCAL_PACKAGE_NAME).OVERRIDES := $(strip $(LOCAL_OVERRIDES_PACKAGES)) |
| PACKAGES.$(LOCAL_PACKAGE_NAME).RESOURCE_FILES := $(all_resources) |
| |
| PACKAGES := $(PACKAGES) $(LOCAL_PACKAGE_NAME) |
| |
| # Reset internal variables. |
| all_res_assets := |
| |
| ifneq (,$(runtime_resource_overlays_product)$(runtime_resource_overlays_vendor)) |
| ifdef LOCAL_EXPORT_PACKAGE_RESOURCES |
| enforce_rro_use_res_lib := true |
| else |
| enforce_rro_use_res_lib := false |
| endif |
| |
| ifdef LOCAL_MANIFEST_PACKAGE_NAME |
| enforce_rro_is_manifest_package_name := true |
| enforce_rro_manifest_package_info := $(LOCAL_MANIFEST_PACKAGE_NAME) |
| else |
| enforce_rro_is_manifest_package_name := false |
| enforce_rro_manifest_package_info := $(full_android_manifest) |
| endif |
| |
| ifdef runtime_resource_overlays_product |
| $(call append_enforce_rro_sources, \ |
| $(my_register_name), \ |
| $(enforce_rro_is_manifest_package_name), \ |
| $(enforce_rro_manifest_package_info), \ |
| $(enforce_rro_use_res_lib), \ |
| $(runtime_resource_overlays_product), \ |
| product \ |
| ) |
| endif |
| ifdef runtime_resource_overlays_vendor |
| $(call append_enforce_rro_sources, \ |
| $(my_register_name), \ |
| $(enforce_rro_is_manifest_package_name), \ |
| $(enforce_rro_manifest_package_info), \ |
| $(enforce_rro_use_res_lib), \ |
| $(runtime_resource_overlays_vendor), \ |
| vendor \ |
| ) |
| endif |
| endif |