2009-03-04 03:28:42 +00:00
|
|
|
###########################################################
|
|
|
|
## Standard rules for building a java library.
|
|
|
|
##
|
|
|
|
###########################################################
|
|
|
|
|
|
|
|
ifdef LOCAL_IS_HOST_MODULE
|
|
|
|
$(error $(LOCAL_PATH): Host java libraries must use BUILD_HOST_JAVA_LIBRARY)
|
|
|
|
endif
|
|
|
|
|
|
|
|
LOCAL_MODULE_SUFFIX := $(COMMON_JAVA_PACKAGE_SUFFIX)
|
|
|
|
LOCAL_MODULE_CLASS := JAVA_LIBRARIES
|
|
|
|
|
|
|
|
ifneq (,$(LOCAL_ASSET_DIR))
|
|
|
|
$(error $(LOCAL_PATH): Target java libraries may not set LOCAL_ASSET_DIR)
|
|
|
|
endif
|
|
|
|
|
2011-12-14 22:29:28 +00:00
|
|
|
ifneq (true,$(LOCAL_IS_STATIC_JAVA_LIBRARY))
|
2009-03-04 03:28:42 +00:00
|
|
|
ifneq (,$(LOCAL_RESOURCE_DIR))
|
|
|
|
$(error $(LOCAL_PATH): Target java libraries may not set LOCAL_RESOURCE_DIR)
|
|
|
|
endif
|
2013-08-28 18:16:06 +00:00
|
|
|
# base_rules.mk looks at this
|
2009-03-04 03:28:42 +00:00
|
|
|
all_res_assets :=
|
2013-08-28 18:16:06 +00:00
|
|
|
endif
|
2009-03-04 03:28:42 +00:00
|
|
|
|
|
|
|
LOCAL_BUILT_MODULE_STEM := javalib.jar
|
|
|
|
|
2010-09-27 21:53:39 +00:00
|
|
|
intermediates.COMMON := $(call local-intermediates-dir,COMMON)
|
|
|
|
|
2010-09-25 01:09:04 +00:00
|
|
|
# This file will be the one that other modules should depend on.
|
|
|
|
common_javalib.jar := $(intermediates.COMMON)/$(LOCAL_BUILT_MODULE_STEM)
|
|
|
|
LOCAL_INTERMEDIATE_TARGETS += $(common_javalib.jar)
|
|
|
|
|
2013-03-26 19:42:32 +00:00
|
|
|
ifeq ($(LOCAL_PROGUARD_ENABLED),disabled)
|
|
|
|
LOCAL_PROGUARD_ENABLED :=
|
|
|
|
endif
|
|
|
|
|
2012-08-21 23:59:01 +00:00
|
|
|
ifeq (true,$(EMMA_INSTRUMENT))
|
|
|
|
ifeq (true,$(LOCAL_EMMA_INSTRUMENT))
|
|
|
|
ifeq (true,$(EMMA_INSTRUMENT_STATIC))
|
|
|
|
LOCAL_STATIC_JAVA_LIBRARIES += emma
|
|
|
|
endif # LOCAL_EMMA_INSTRUMENT
|
|
|
|
endif # EMMA_INSTRUMENT_STATIC
|
|
|
|
else
|
|
|
|
LOCAL_EMMA_INSTRUMENT := false
|
|
|
|
endif # EMMA_INSTRUMENT
|
|
|
|
|
2009-03-04 03:28:42 +00:00
|
|
|
#################################
|
|
|
|
include $(BUILD_SYSTEM)/java.mk
|
|
|
|
#################################
|
|
|
|
|
|
|
|
ifeq ($(LOCAL_IS_STATIC_JAVA_LIBRARY),true)
|
2011-04-01 22:45:58 +00:00
|
|
|
# No dex; all we want are the .class files with resources.
|
2013-03-26 19:42:32 +00:00
|
|
|
$(common_javalib.jar) : $(java_resource_sources)
|
|
|
|
ifdef LOCAL_PROGUARD_ENABLED
|
|
|
|
$(common_javalib.jar) : $(full_classes_proguard_jar)
|
|
|
|
else
|
|
|
|
$(common_javalib.jar) : $(full_classes_jar)
|
|
|
|
endif
|
2009-03-04 03:28:42 +00:00
|
|
|
@echo "target Static Jar: $(PRIVATE_MODULE) ($@)"
|
|
|
|
$(copy-file-to-target)
|
|
|
|
|
2010-09-25 01:09:04 +00:00
|
|
|
$(LOCAL_BUILT_MODULE): $(common_javalib.jar)
|
|
|
|
$(copy-file-to-target)
|
|
|
|
|
2009-03-04 03:28:42 +00:00
|
|
|
else # !LOCAL_IS_STATIC_JAVA_LIBRARY
|
|
|
|
|
2010-09-25 01:09:04 +00:00
|
|
|
$(common_javalib.jar): PRIVATE_DEX_FILE := $(built_dex)
|
Running jarjar on Java resources.
Before this change, Java resources are added as a separate step
(add-java-resources-to-package) after dex is run, so jarjar isn't run on
the resource files.
With this change, we add Java resources immediately after we call javac,
so jarjar is run on the resource files (the module's own resource, as
well as resources carried by static Java libraries).
When we generate the final apk/jar, we use the jarjar'ed jar as the
inital pacakge file, with class files and empty folders removed.
When jack is enabled, in jack-java-to-dex we add the Java resources to
a temp jar using the PRIVATE_EXTRA_JAR_ARGS, and extrac the files in a
temp dir. Jack will process the resource files and output the result to
PRIVATE_JACK_INTERMEDIATES_DIR. When we package the final apk/jar, we
need to call add-carried-jack-resources to readd the resources.
(TODO: if jack can output all resources to a jar/zip file, we can use
that file as the initial package file as well.)
Bug: 18837479
Change-Id: I8d7296e30ec8d005054cf04c4f2aed6d7a0d823b
2015-01-14 22:23:56 +00:00
|
|
|
$(common_javalib.jar): PRIVATE_SOURCE_ARCHIVE := $(full_classes_jarjar_jar)
|
2015-01-28 20:29:38 +00:00
|
|
|
$(common_javalib.jar): PRIVATE_DONT_DELETE_JAR_DIRS := $(LOCAL_DONT_DELETE_JAR_DIRS)
|
2013-01-24 00:54:32 +00:00
|
|
|
$(common_javalib.jar) : $(built_dex) $(java_resource_sources)
|
2010-09-17 23:36:06 +00:00
|
|
|
@echo "target Jar: $(PRIVATE_MODULE) ($@)"
|
2015-01-09 09:36:40 +00:00
|
|
|
ifdef LOCAL_JACK_ENABLED
|
2010-09-17 23:36:06 +00:00
|
|
|
$(create-empty-package)
|
2015-01-21 11:04:22 +00:00
|
|
|
else
|
Running jarjar on Java resources.
Before this change, Java resources are added as a separate step
(add-java-resources-to-package) after dex is run, so jarjar isn't run on
the resource files.
With this change, we add Java resources immediately after we call javac,
so jarjar is run on the resource files (the module's own resource, as
well as resources carried by static Java libraries).
When we generate the final apk/jar, we use the jarjar'ed jar as the
inital pacakge file, with class files and empty folders removed.
When jack is enabled, in jack-java-to-dex we add the Java resources to
a temp jar using the PRIVATE_EXTRA_JAR_ARGS, and extrac the files in a
temp dir. Jack will process the resource files and output the result to
PRIVATE_JACK_INTERMEDIATES_DIR. When we package the final apk/jar, we
need to call add-carried-jack-resources to readd the resources.
(TODO: if jack can output all resources to a jar/zip file, we can use
that file as the initial package file as well.)
Bug: 18837479
Change-Id: I8d7296e30ec8d005054cf04c4f2aed6d7a0d823b
2015-01-14 22:23:56 +00:00
|
|
|
$(call initialize-package-file,$(PRIVATE_SOURCE_ARCHIVE),$@)
|
2010-09-17 23:36:06 +00:00
|
|
|
endif
|
Running jarjar on Java resources.
Before this change, Java resources are added as a separate step
(add-java-resources-to-package) after dex is run, so jarjar isn't run on
the resource files.
With this change, we add Java resources immediately after we call javac,
so jarjar is run on the resource files (the module's own resource, as
well as resources carried by static Java libraries).
When we generate the final apk/jar, we use the jarjar'ed jar as the
inital pacakge file, with class files and empty folders removed.
When jack is enabled, in jack-java-to-dex we add the Java resources to
a temp jar using the PRIVATE_EXTRA_JAR_ARGS, and extrac the files in a
temp dir. Jack will process the resource files and output the result to
PRIVATE_JACK_INTERMEDIATES_DIR. When we package the final apk/jar, we
need to call add-carried-jack-resources to readd the resources.
(TODO: if jack can output all resources to a jar/zip file, we can use
that file as the initial package file as well.)
Bug: 18837479
Change-Id: I8d7296e30ec8d005054cf04c4f2aed6d7a0d823b
2015-01-14 22:23:56 +00:00
|
|
|
$(add-dex-to-package)
|
2015-01-09 09:36:40 +00:00
|
|
|
ifdef LOCAL_JACK_ENABLED
|
Running jarjar on Java resources.
Before this change, Java resources are added as a separate step
(add-java-resources-to-package) after dex is run, so jarjar isn't run on
the resource files.
With this change, we add Java resources immediately after we call javac,
so jarjar is run on the resource files (the module's own resource, as
well as resources carried by static Java libraries).
When we generate the final apk/jar, we use the jarjar'ed jar as the
inital pacakge file, with class files and empty folders removed.
When jack is enabled, in jack-java-to-dex we add the Java resources to
a temp jar using the PRIVATE_EXTRA_JAR_ARGS, and extrac the files in a
temp dir. Jack will process the resource files and output the result to
PRIVATE_JACK_INTERMEDIATES_DIR. When we package the final apk/jar, we
need to call add-carried-jack-resources to readd the resources.
(TODO: if jack can output all resources to a jar/zip file, we can use
that file as the initial package file as well.)
Bug: 18837479
Change-Id: I8d7296e30ec8d005054cf04c4f2aed6d7a0d823b
2015-01-14 22:23:56 +00:00
|
|
|
$(add-carried-jack-resources)
|
2015-01-21 11:04:22 +00:00
|
|
|
endif
|
2010-09-17 23:36:06 +00:00
|
|
|
|
2011-10-24 19:17:03 +00:00
|
|
|
ifdef LOCAL_DEX_PREOPT
|
2013-11-15 07:44:56 +00:00
|
|
|
ifneq ($(dexpreopt_boot_jar_module),) # boot jar
|
2010-09-17 23:36:06 +00:00
|
|
|
# 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
|
|
|
|
$(LOCAL_BUILT_MODULE) : $(dexpreopted_boot_jar) | $(ACP)
|
|
|
|
$(call copy-file-to-target)
|
|
|
|
|
2013-11-15 07:44:56 +00:00
|
|
|
# For libart boot jars, we don't have .odex files.
|
|
|
|
else # ! boot jar
|
2010-09-17 23:36:06 +00:00
|
|
|
$(built_odex): PRIVATE_MODULE := $(LOCAL_MODULE)
|
2014-05-13 20:57:28 +00:00
|
|
|
# Use pattern rule - we may have multiple built odex files.
|
|
|
|
$(built_odex) : $(dir $(LOCAL_BUILT_MODULE))% : $(common_javalib.jar)
|
2010-09-17 23:36:06 +00:00
|
|
|
@echo "Dexpreopt Jar: $(PRIVATE_MODULE) ($@)"
|
2014-05-13 20:57:28 +00:00
|
|
|
$(call dexpreopt-one-file,$<,$@)
|
2010-09-17 23:36:06 +00:00
|
|
|
|
2013-01-24 00:54:32 +00:00
|
|
|
$(LOCAL_BUILT_MODULE) : $(common_javalib.jar) | $(ACP)
|
2010-09-17 23:36:06 +00:00
|
|
|
$(call copy-file-to-target)
|
2011-10-24 19:17:03 +00:00
|
|
|
ifneq (nostripping,$(LOCAL_DEX_PREOPT))
|
2010-09-17 23:36:06 +00:00
|
|
|
$(call dexpreopt-remove-classes.dex,$@)
|
2011-10-24 19:17:03 +00:00
|
|
|
endif
|
2010-09-17 23:36:06 +00:00
|
|
|
|
2013-11-15 07:44:56 +00:00
|
|
|
endif # ! boot jar
|
2010-09-17 23:36:06 +00:00
|
|
|
|
|
|
|
else # LOCAL_DEX_PREOPT
|
2010-09-25 01:09:04 +00:00
|
|
|
$(LOCAL_BUILT_MODULE) : $(common_javalib.jar) | $(ACP)
|
|
|
|
$(call copy-file-to-target)
|
2009-03-04 03:28:42 +00:00
|
|
|
|
2010-09-25 01:09:04 +00:00
|
|
|
endif # LOCAL_DEX_PREOPT
|
2009-03-04 03:28:42 +00:00
|
|
|
endif # !LOCAL_IS_STATIC_JAVA_LIBRARY
|