diff options
author | Ying Wang <wangying@google.com> | 2012-12-13 18:23:01 -0800 |
---|---|---|
committer | Ying Wang <wangying@google.com> | 2012-12-14 14:48:00 -0800 |
commit | 63d94fa3056066ba7be6754356975af6a1c82981 (patch) | |
tree | ea7b1813537535b23c45476eb81440fbd5fb1eeb /core/definitions.mk | |
parent | 9c68f06a5450223eaefcd165c69fd5336cc2317e (diff) | |
download | build-63d94fa3056066ba7be6754356975af6a1c82981.zip build-63d94fa3056066ba7be6754356975af6a1c82981.tar.gz build-63d94fa3056066ba7be6754356975af6a1c82981.tar.bz2 |
Build from source or prebuilt
With this change, you can easily switch between building from source
code and prebuilt.
Set LOCAL_PREBUILT_MODULE_FILE to the path of the prebuilt file,
relative to the top of the source tree, in the usual module definition.
The prebuilt will be used unless any of the followings satisfied:
1) ANDROID_BUILD_FROM_SOURCE is "true", which disable prebuilt globally;
2) The module name is in ANDROID_NO_PREBUILT_MODULES;
3) The LOCAL_PATH is prefixed by any of ANDROID_NO_PREBUILT_PATHS.
A developer can set ANDROID_NO_PREBUILT_MODULES or
ANDROID_NO_PREBUILT_PATHS to build only his own module(s) from source,
while build other modules from prebuilts.
You can set ANDROID_BUILD_FROM_SOURCE to true to build everything from
source.
Those variables can be set with shell environmental variable or in your
buildspec.mk.
Sometimes module B is able to be built from source only if module A is
also
built from source, for example, if B is the test apk of A.
In that case, you can use the macro include-if-build-from-source to
include B's Android.mk only if A is built from source too, or
if-build-from-source to conditionally include the definition of module
B,
if their module definitions are in the same Android.mk.
Support host-executable-hook and host-shared-library-hook.
Change-Id: Icab7cf028c87eaba0dd7efc2a7749fd6f32b44e4
Diffstat (limited to 'core/definitions.mk')
-rw-r--r-- | core/definitions.mk | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/core/definitions.mk b/core/definitions.mk index 96cc0cc..4bce0a7 100644 --- a/core/definitions.mk +++ b/core/definitions.mk @@ -2110,6 +2110,30 @@ $(TARGET_OUT_COMMON_INTERMEDIATES)/PACKAGING/$(strip $(1))-timestamp: $(2) $(3) $(6): $(TARGET_OUT_COMMON_INTERMEDIATES)/PACKAGING/$(strip $(1))-timestamp endef +## Whether to build from source if prebuilt alternative exists +########################################################### +# $(1): module name +# $(2): LOCAL_PATH +# Expands to empty string if not from source. +ifeq (true,$(ANDROID_BUILD_FROM_SOURCE)) +define if-build-from-source +true +endef +else +define if-build-from-source +$(if $(filter $(ANDROID_NO_PREBUILT_MODULES),$(1))$(filter \ + $(addsuffix %,$(ANDROID_NO_PREBUILT_PATHS)),$(2)),true) +endef +endif + +# Include makefile $(1) if build from source for module $(2) +# $(1): the makefile to include +# $(2): module name +# $(3): LOCAL_PATH +define include-if-build-from-source +$(if $(call if-build-from-source,$(2),$(3)),$(eval include $(1))) +endef + ########################################################### ## Other includes ########################################################### |