Make classes.jar the output of uninstallable Soong Java modules
The soong_java_prebuilt.mk file used to assume that if a Soong module defines a dex jar, it is the output of the module and the module is installable. This may now not be true if the module uses 'compile_dex' to define a secondary build rule for a dex jar. If the module is not installable (LOCAL_UNINSTALLABLE_MODULE=true), do not attempt to preopt and copy classes.jar to the modules output destination. Bug: 79409988 Test: on related CL Change-Id: Ica958ac793e09a0e52125448b44e7cd36e7f35d5
This commit is contained in:
@@ -79,49 +79,55 @@ endif
|
|||||||
endif # TURBINE_ENABLED != false
|
endif # TURBINE_ENABLED != false
|
||||||
|
|
||||||
ifdef LOCAL_SOONG_DEX_JAR
|
ifdef LOCAL_SOONG_DEX_JAR
|
||||||
ifndef LOCAL_IS_HOST_MODULE
|
ifneq ($(LOCAL_UNINSTALLABLE_MODULE),true)
|
||||||
ifneq ($(filter $(LOCAL_MODULE),$(PRODUCT_BOOT_JARS)),) # is_boot_jar
|
ifndef LOCAL_IS_HOST_MODULE
|
||||||
$(eval $(call hiddenapi-copy-soong-jar,$(LOCAL_SOONG_DEX_JAR),$(common_javalib.jar)))
|
ifneq ($(filter $(LOCAL_MODULE),$(PRODUCT_BOOT_JARS)),) # is_boot_jar
|
||||||
else # !is_boot_jar
|
$(eval $(call hiddenapi-copy-soong-jar,$(LOCAL_SOONG_DEX_JAR),$(common_javalib.jar)))
|
||||||
$(eval $(call copy-one-file,$(LOCAL_SOONG_DEX_JAR),$(common_javalib.jar)))
|
else # !is_boot_jar
|
||||||
endif # is_boot_jar
|
$(eval $(call copy-one-file,$(LOCAL_SOONG_DEX_JAR),$(common_javalib.jar)))
|
||||||
$(eval $(call add-dependency,$(common_javalib.jar),$(full_classes_jar) $(full_classes_header_jar)))
|
endif # is_boot_jar
|
||||||
|
$(eval $(call add-dependency,$(common_javalib.jar),$(full_classes_jar) $(full_classes_header_jar)))
|
||||||
|
|
||||||
dex_preopt_profile_src_file := $(common_javalib.jar)
|
dex_preopt_profile_src_file := $(common_javalib.jar)
|
||||||
|
|
||||||
# defines built_odex along with rule to install odex
|
# defines built_odex along with rule to install odex
|
||||||
include $(BUILD_SYSTEM)/dex_preopt_odex_install.mk
|
include $(BUILD_SYSTEM)/dex_preopt_odex_install.mk
|
||||||
|
|
||||||
dex_preopt_profile_src_file :=
|
dex_preopt_profile_src_file :=
|
||||||
|
|
||||||
ifdef LOCAL_DEX_PREOPT
|
ifdef LOCAL_DEX_PREOPT
|
||||||
ifneq ($(dexpreopt_boot_jar_module),) # boot jar
|
ifneq ($(dexpreopt_boot_jar_module),) # boot jar
|
||||||
# boot jar's rules are defined in dex_preopt.mk
|
# boot jar's rules are defined in dex_preopt.mk
|
||||||
dexpreopted_boot_jar := $(DEXPREOPT_BOOT_JAR_DIR_FULL_PATH)/$(dexpreopt_boot_jar_module)_nodex.jar
|
dexpreopted_boot_jar := $(DEXPREOPT_BOOT_JAR_DIR_FULL_PATH)/$(dexpreopt_boot_jar_module)_nodex.jar
|
||||||
$(eval $(call copy-one-file,$(dexpreopted_boot_jar),$(LOCAL_BUILT_MODULE)))
|
$(eval $(call copy-one-file,$(dexpreopted_boot_jar),$(LOCAL_BUILT_MODULE)))
|
||||||
|
|
||||||
# For libart boot jars, we don't have .odex files.
|
# For libart boot jars, we don't have .odex files.
|
||||||
else # ! boot jar
|
else # ! boot jar
|
||||||
$(built_odex): PRIVATE_MODULE := $(LOCAL_MODULE)
|
$(built_odex): PRIVATE_MODULE := $(LOCAL_MODULE)
|
||||||
# Use pattern rule - we may have multiple built odex files.
|
# Use pattern rule - we may have multiple built odex files.
|
||||||
$(built_odex) : $(dir $(LOCAL_BUILT_MODULE))% : $(common_javalib.jar)
|
$(built_odex) : $(dir $(LOCAL_BUILT_MODULE))% : $(common_javalib.jar)
|
||||||
@echo "Dexpreopt Jar: $(PRIVATE_MODULE) ($@)"
|
@echo "Dexpreopt Jar: $(PRIVATE_MODULE) ($@)"
|
||||||
$(call dexpreopt-one-file,$<,$@)
|
$(call dexpreopt-one-file,$<,$@)
|
||||||
|
|
||||||
$(eval $(call dexpreopt-copy-jar,$(common_javalib.jar),$(LOCAL_BUILT_MODULE),$(LOCAL_DEX_PREOPT)))
|
$(eval $(call dexpreopt-copy-jar,$(common_javalib.jar),$(LOCAL_BUILT_MODULE),$(LOCAL_DEX_PREOPT)))
|
||||||
endif # ! boot jar
|
endif # ! boot jar
|
||||||
else # LOCAL_DEX_PREOPT
|
else # LOCAL_DEX_PREOPT
|
||||||
$(eval $(call copy-one-file,$(common_javalib.jar),$(LOCAL_BUILT_MODULE)))
|
$(eval $(call copy-one-file,$(common_javalib.jar),$(LOCAL_BUILT_MODULE)))
|
||||||
endif # LOCAL_DEX_PREOPT
|
endif # LOCAL_DEX_PREOPT
|
||||||
else # LOCAL_IS_HOST_MODULE
|
else # LOCAL_IS_HOST_MODULE
|
||||||
$(eval $(call copy-one-file,$(LOCAL_SOONG_DEX_JAR),$(LOCAL_BUILT_MODULE)))
|
$(eval $(call copy-one-file,$(LOCAL_SOONG_DEX_JAR),$(LOCAL_BUILT_MODULE)))
|
||||||
$(eval $(call add-dependency,$(LOCAL_BUILT_MODULE),$(full_classes_jar) $(full_classes_header_jar)))
|
$(eval $(call add-dependency,$(LOCAL_BUILT_MODULE),$(full_classes_jar) $(full_classes_header_jar)))
|
||||||
endif
|
endif
|
||||||
|
|
||||||
java-dex : $(LOCAL_BUILT_MODULE)
|
java-dex : $(LOCAL_BUILT_MODULE)
|
||||||
else
|
else # LOCAL_UNINSTALLABLE_MODULE
|
||||||
|
$(eval $(call copy-one-file,$(full_classes_jar),$(LOCAL_BUILT_MODULE)))
|
||||||
|
$(eval $(call copy-one-file,$(LOCAL_SOONG_DEX_JAR),$(common_javalib.jar)))
|
||||||
|
java-dex : $(common_javalib.jar)
|
||||||
|
endif # LOCAL_UNINSTALLABLE_MODULE
|
||||||
|
else # LOCAL_SOONG_DEX_JAR
|
||||||
$(eval $(call copy-one-file,$(full_classes_jar),$(LOCAL_BUILT_MODULE)))
|
$(eval $(call copy-one-file,$(full_classes_jar),$(LOCAL_BUILT_MODULE)))
|
||||||
endif
|
endif # LOCAL_SOONG_DEX_JAR
|
||||||
|
|
||||||
javac-check : $(full_classes_jar)
|
javac-check : $(full_classes_jar)
|
||||||
javac-check-$(LOCAL_MODULE) : $(full_classes_jar)
|
javac-check-$(LOCAL_MODULE) : $(full_classes_jar)
|
||||||
|
Reference in New Issue
Block a user