Merge "Support to build static Java library with Android resource"
This commit is contained in:
@@ -1408,6 +1408,9 @@ endef
|
|||||||
|
|
||||||
# For a list of jar files, unzip them to a specified directory,
|
# For a list of jar files, unzip them to a specified directory,
|
||||||
# but make sure that no META-INF files come along for the ride.
|
# but make sure that no META-INF files come along for the ride.
|
||||||
|
# We also remove any R.class/Manifest.class from the jar files;
|
||||||
|
# R/Manifest class for the static Java libraries should be
|
||||||
|
# re-generate in the app module instead.
|
||||||
#
|
#
|
||||||
# $(1): files to unzip
|
# $(1): files to unzip
|
||||||
# $(2): destination directory
|
# $(2): destination directory
|
||||||
@@ -1421,6 +1424,7 @@ define unzip-jar-files
|
|||||||
unzip -qo $$f -d $(2); \
|
unzip -qo $$f -d $(2); \
|
||||||
(cd $(2) && rm -rf META-INF); \
|
(cd $(2) && rm -rf META-INF); \
|
||||||
done
|
done
|
||||||
|
$(hide) find $(2) -name 'R.class' -o -name 'R$$*.class' -o -name 'Manifest.class' -o -name 'Manifest$$*.class' | xargs rm -rf
|
||||||
endef
|
endef
|
||||||
|
|
||||||
# Common definition to invoke javac on the host and target.
|
# Common definition to invoke javac on the host and target.
|
||||||
|
@@ -14,9 +14,11 @@ ifneq (,$(LOCAL_ASSET_DIR))
|
|||||||
$(error $(LOCAL_PATH): Target java libraries may not set LOCAL_ASSET_DIR)
|
$(error $(LOCAL_PATH): Target java libraries may not set LOCAL_ASSET_DIR)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifneq (true,$(LOCAL_IS_STATIC_JAVA_LIBRARY))
|
||||||
ifneq (,$(LOCAL_RESOURCE_DIR))
|
ifneq (,$(LOCAL_RESOURCE_DIR))
|
||||||
$(error $(LOCAL_PATH): Target java libraries may not set LOCAL_RESOURCE_DIR)
|
$(error $(LOCAL_PATH): Target java libraries may not set LOCAL_RESOURCE_DIR)
|
||||||
endif
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
#xxx base_rules.mk looks at this
|
#xxx base_rules.mk looks at this
|
||||||
all_res_assets :=
|
all_res_assets :=
|
||||||
|
@@ -21,5 +21,75 @@
|
|||||||
|
|
||||||
LOCAL_UNINSTALLABLE_MODULE := true
|
LOCAL_UNINSTALLABLE_MODULE := true
|
||||||
LOCAL_IS_STATIC_JAVA_LIBRARY := true
|
LOCAL_IS_STATIC_JAVA_LIBRARY := true
|
||||||
|
|
||||||
|
# Hack to build static Java library with Android resource
|
||||||
|
# See bug 5714516
|
||||||
|
all_resources :=
|
||||||
|
ifdef LOCAL_RESOURCE_DIR
|
||||||
|
all_resources := $(strip \
|
||||||
|
$(foreach dir, $(LOCAL_RESOURCE_DIR), \
|
||||||
|
$(addprefix $(dir)/, \
|
||||||
|
$(patsubst res/%,%, \
|
||||||
|
$(call find-subdir-assets,$(dir)) \
|
||||||
|
) \
|
||||||
|
) \
|
||||||
|
))
|
||||||
|
endif
|
||||||
|
|
||||||
include $(BUILD_SYSTEM)/java_library.mk
|
include $(BUILD_SYSTEM)/java_library.mk
|
||||||
|
|
||||||
|
ifneq (,$(all_resources))
|
||||||
|
R_file_stamp := $(LOCAL_INTERMEDIATE_SOURCE_DIR)/R.stamp
|
||||||
|
|
||||||
|
ifeq ($(strip $(LOCAL_MANIFEST_FILE)),)
|
||||||
|
LOCAL_MANIFEST_FILE := AndroidManifest.xml
|
||||||
|
endif
|
||||||
|
full_android_manifest := $(LOCAL_PATH)/$(LOCAL_MANIFEST_FILE)
|
||||||
|
|
||||||
|
framework_res_package_export :=
|
||||||
|
framework_res_package_export_deps :=
|
||||||
|
# Please refer to package.mk
|
||||||
|
ifneq ($(LOCAL_NO_STANDARD_LIBRARIES),true)
|
||||||
|
ifneq ($(filter-out current,$(LOCAL_SDK_RES_VERSION)),)
|
||||||
|
framework_res_package_export := \
|
||||||
|
$(HISTORICAL_SDK_VERSIONS_ROOT)/$(LOCAL_SDK_RES_VERSION)/android.jar
|
||||||
|
framework_res_package_export_deps := $(framework_res_package_export)
|
||||||
|
else
|
||||||
|
framework_res_package_export := \
|
||||||
|
$(call intermediates-dir-for,APPS,framework-res,,COMMON)/package-export.apk
|
||||||
|
framework_res_package_export_deps := \
|
||||||
|
$(dir $(framework_res_package_export))src/R.stamp
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
$(R_file_stamp): PRIVATE_MODULE := $(LOCAL_MODULE)
|
||||||
|
# add --non-constant-id to prevent inlining constants.
|
||||||
|
$(R_file_stamp): PRIVATE_AAPT_FLAGS := $(LOCAL_AAPT_FLAGS) --non-constant-id
|
||||||
|
$(R_file_stamp): PRIVATE_SOURCE_INTERMEDIATES_DIR := $(LOCAL_INTERMEDIATE_SOURCE_DIR)
|
||||||
|
$(R_file_stamp): PRIVATE_ANDROID_MANIFEST := $(full_android_manifest)
|
||||||
|
$(R_file_stamp): PRIVATE_RESOURCE_PUBLICS_OUTPUT := $(intermediates.COMMON)/public_resources.xml
|
||||||
|
$(R_file_stamp): PRIVATE_RESOURCE_DIR := $(LOCAL_RESOURCE_DIR)
|
||||||
|
$(R_file_stamp): PRIVATE_AAPT_INCLUDES := $(framework_res_package_export)
|
||||||
|
ifneq (,$(filter-out current, $(LOCAL_SDK_VERSION)))
|
||||||
|
$(R_file_stamp): PRIVATE_DEFAULT_APP_TARGET_SDK := $(LOCAL_SDK_VERSION)
|
||||||
|
else
|
||||||
|
$(R_file_stamp): PRIVATE_DEFAULT_APP_TARGET_SDK := $(DEFAULT_APP_TARGET_SDK)
|
||||||
|
endif
|
||||||
|
$(R_file_stamp): PRIVATE_ASSET_DIR :=
|
||||||
|
$(R_file_stamp): PRIVATE_PROGUARD_OPTIONS_FILE :=
|
||||||
|
$(R_file_stamp): PRIVATE_MANIFEST_PACKAGE_NAME :=
|
||||||
|
$(R_file_stamp): PRIVATE_MANIFEST_INSTRUMENTATION_FOR :=
|
||||||
|
|
||||||
|
$(R_file_stamp) : $(all_resources) $(full_android_manifest) $(AAPT) $(framework_res_package_export_deps)
|
||||||
|
@echo "target R.java/Manifest.java: $(PRIVATE_MODULE) ($@)"
|
||||||
|
$(create-resource-java-files)
|
||||||
|
$(hide) find $(PRIVATE_SOURCE_INTERMEDIATES_DIR) -name R.java | xargs cat > $@
|
||||||
|
|
||||||
|
$(LOCAL_BUILT_MODULE): $(R_file_stamp)
|
||||||
|
ifneq ($(full_classes_jar),)
|
||||||
|
$(full_classes_compiled_jar): $(R_file_stamp)
|
||||||
|
endif
|
||||||
|
|
||||||
|
endif # $(all_resources) not empty
|
||||||
|
|
||||||
LOCAL_IS_STATIC_JAVA_LIBRARY :=
|
LOCAL_IS_STATIC_JAVA_LIBRARY :=
|
||||||
|
Reference in New Issue
Block a user