definitions.mk revision 0aeee045bdd26673b9be29b76d692ac93d1ea74b
1#
2# Copyright (C) 2008 The Android Open Source Project
3#
4# Licensed under the Apache License, Version 2.0 (the "License");
5# you may not use this file except in compliance with the License.
6# You may obtain a copy of the License at
7#
8#      http://www.apache.org/licenses/LICENSE-2.0
9#
10# Unless required by applicable law or agreed to in writing, software
11# distributed under the License is distributed on an "AS IS" BASIS,
12# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13# See the License for the specific language governing permissions and
14# limitations under the License.
15#
16
17##
18## Common build system definitions.  Mostly standard
19## commands for building various types of targets, which
20## are used by others to construct the final targets.
21##
22
23# These are variables we use to collect overall lists
24# of things being processed.
25
26# Full paths to all of the documentation
27ALL_DOCS:=
28
29# The short names of all of the targets in the system.
30# For each element of ALL_MODULES, two other variables
31# are defined:
32#   $(ALL_MODULES.$(target)).BUILT
33#   $(ALL_MODULES.$(target)).INSTALLED
34# The BUILT variable contains LOCAL_BUILT_MODULE for that
35# target, and the INSTALLED variable contains the LOCAL_INSTALLED_MODULE.
36# Some targets may have multiple files listed in the BUILT and INSTALLED
37# sub-variables.
38ALL_MODULES:=
39
40# Full paths to targets that should be added to the "make droid"
41# set of installed targets.
42ALL_DEFAULT_INSTALLED_MODULES:=
43
44# The list of tags that have been defined by
45# LOCAL_MODULE_TAGS.  Each word in this variable maps
46# to a corresponding ALL_MODULE_TAGS.<tagname> variable
47# that contains all of the INSTALLED_MODULEs with that tag.
48ALL_MODULE_TAGS:=
49
50# Similar to ALL_MODULE_TAGS, but contains the short names
51# of all targets for a particular tag.  The top-level variable
52# won't have the list of tags;  ust ALL_MODULE_TAGS to get
53# the list of all known tags.  (This means that this variable
54# will always be empty; it's just here as a placeholder for
55# its sub-variables.)
56ALL_MODULE_NAME_TAGS:=
57
58# Full paths to all prebuilt files that will be copied
59# (used to make the dependency on acp)
60ALL_PREBUILT:=
61
62# Full path to all files that are made by some tool
63ALL_GENERATED_SOURCES:=
64
65# Full path to all asm, C, C++, lex and yacc generated C files.
66# These all have an order-only dependency on the copied headers
67ALL_C_CPP_ETC_OBJECTS:=
68
69# The list of dynamic binaries that haven't been stripped/compressed/etc.
70ALL_ORIGINAL_DYNAMIC_BINARIES:=
71
72# These files go into the SDK
73ALL_SDK_FILES:=
74
75# Files for dalvik.  This is often build without building the rest of the OS.
76INTERNAL_DALVIK_MODULES:=
77
78# All findbugs xml files
79ALL_FINDBUGS_FILES:=
80
81# GPL module license files
82ALL_GPL_MODULE_LICENSE_FILES:=
83
84# Target and host installed module's dependencies on shared libraries.
85# They are list of "<module_name>:<installed_file>:lib1,lib2...".
86TARGET_DEPENDENCIES_ON_SHARED_LIBRARIES :=
87$(TARGET_2ND_ARCH_VAR_PREFIX)TARGET_DEPENDENCIES_ON_SHARED_LIBRARIES :=
88HOST_DEPENDENCIES_ON_SHARED_LIBRARIES :=
89$(HOST_2ND_ARCH_VAR_PREFIX)HOST_DEPENDENCIES_ON_SHARED_LIBRARIES :=
90HOST_CROSS_DEPENDENCIES_ON_SHARED_LIBRARIES :=
91$(HOST_CROSS_2ND_ARCH_VAR_PREFIX)HOST_CROSS_DEPENDENCIES_ON_SHARED_LIBRARIES :=
92
93# Generated class file names for Android resource.
94# They are escaped and quoted so can be passed safely to a bash command.
95ANDROID_RESOURCE_GENERATED_CLASSES := 'R.class' 'R$$*.class' 'Manifest.class' 'Manifest$$*.class'
96
97# Display names for various build targets
98TARGET_DISPLAY := target
99HOST_DISPLAY := host
100HOST_CROSS_DISPLAY := host cross
101
102###########################################################
103## Debugging; prints a variable list to stdout
104###########################################################
105
106# $(1): variable name list, not variable values
107define print-vars
108$(foreach var,$(1), \
109  $(info $(var):) \
110  $(foreach word,$($(var)), \
111    $(info $(space)$(space)$(word)) \
112   ) \
113 )
114endef
115
116###########################################################
117## Evaluates to true if the string contains the word true,
118## and empty otherwise
119## $(1): a var to test
120###########################################################
121
122define true-or-empty
123$(filter true, $(1))
124endef
125
126
127###########################################################
128## Retrieve the directory of the current makefile
129## Must be called before including any other makefile!!
130###########################################################
131
132# Figure out where we are.
133define my-dir
134$(strip \
135  $(eval LOCAL_MODULE_MAKEFILE := $$(lastword $$(MAKEFILE_LIST))) \
136  $(eval LOCAL_MODULE_MAKEFILE_DEP := $(if $(BUILDING_WITH_NINJA),,$$(LOCAL_MODULE_MAKEFILE))) \
137  $(if $(filter $(BUILD_SYSTEM)/% $(OUT_DIR)/%,$(LOCAL_MODULE_MAKEFILE)), \
138    $(error my-dir must be called before including any other makefile.) \
139   , \
140    $(patsubst %/,%,$(dir $(LOCAL_MODULE_MAKEFILE))) \
141   ) \
142 )
143endef
144
145###########################################################
146## Retrieve a list of all makefiles immediately below some directory
147###########################################################
148
149define all-makefiles-under
150$(sort $(wildcard $(1)/*/Android.mk))
151endef
152
153###########################################################
154## Look under a directory for makefiles that don't have parent
155## makefiles.
156###########################################################
157
158# $(1): directory to search under
159# Ignores $(1)/Android.mk
160define first-makefiles-under
161$(shell build/tools/findleaves.py $(FIND_LEAVES_EXCLUDES) \
162        --mindepth=2 $(1) Android.mk)
163endef
164
165###########################################################
166## Retrieve a list of all makefiles immediately below your directory
167## Must be called before including any other makefile!!
168###########################################################
169
170define all-subdir-makefiles
171$(call all-makefiles-under,$(call my-dir))
172endef
173
174###########################################################
175## Look in the named list of directories for makefiles,
176## relative to the current directory.
177## Must be called before including any other makefile!!
178###########################################################
179
180# $(1): List of directories to look for under this directory
181define all-named-subdir-makefiles
182$(sort $(wildcard $(addsuffix /Android.mk, $(addprefix $(call my-dir)/,$(1)))))
183endef
184
185###########################################################
186## Find all of the directories under the named directories with
187## the specified name.
188## Meant to be used like:
189##    INC_DIRS := $(call all-named-dirs-under,inc,.)
190###########################################################
191
192define all-named-dirs-under
193$(call find-subdir-files,$(2) -type d -name "$(1)")
194endef
195
196###########################################################
197## Find all the directories under the current directory that
198## haves name that match $(1)
199###########################################################
200
201define all-subdir-named-dirs
202$(call all-named-dirs-under,$(1),.)
203endef
204
205###########################################################
206## Find all of the files under the named directories with
207## the specified name.
208## Meant to be used like:
209##    SRC_FILES := $(call all-named-files-under,*.h,src tests)
210###########################################################
211
212define all-named-files-under
213$(call find-files-in-subdirs,$(LOCAL_PATH),"$(1)",$(2))
214endef
215
216###########################################################
217## Find all of the files under the current directory with
218## the specified name.
219###########################################################
220
221define all-subdir-named-files
222$(call all-named-files-under,$(1),.)
223endef
224
225###########################################################
226## Find all of the java files under the named directories.
227## Meant to be used like:
228##    SRC_FILES := $(call all-java-files-under,src tests)
229###########################################################
230
231define all-java-files-under
232$(call all-named-files-under,*.java,$(1))
233endef
234
235###########################################################
236## Find all of the java files from here.  Meant to be used like:
237##    SRC_FILES := $(call all-subdir-java-files)
238###########################################################
239
240define all-subdir-java-files
241$(call all-java-files-under,.)
242endef
243
244###########################################################
245## Find all of the c files under the named directories.
246## Meant to be used like:
247##    SRC_FILES := $(call all-c-files-under,src tests)
248###########################################################
249
250define all-c-files-under
251$(call all-named-files-under,*.c,$(1))
252endef
253
254###########################################################
255## Find all of the c files from here.  Meant to be used like:
256##    SRC_FILES := $(call all-subdir-c-files)
257###########################################################
258
259define all-subdir-c-files
260$(call all-c-files-under,.)
261endef
262
263###########################################################
264## Find all of the cpp files under the named directories.
265## LOCAL_CPP_EXTENSION is respected if set.
266## Meant to be used like:
267##    SRC_FILES := $(call all-cpp-files-under,src tests)
268###########################################################
269
270define all-cpp-files-under
271$(sort $(patsubst ./%,%, \
272  $(shell cd $(LOCAL_PATH) ; \
273          find -L $(1) -name "*$(or $(LOCAL_CPP_EXTENSION),.cpp)" -and -not -name ".*") \
274 ))
275endef
276
277###########################################################
278## Find all of the cpp files from here.  Meant to be used like:
279##    SRC_FILES := $(call all-subdir-cpp-files)
280###########################################################
281
282define all-subdir-cpp-files
283$(call all-cpp-files-under,.)
284endef
285
286###########################################################
287## Find all files named "I*.aidl" under the named directories,
288## which must be relative to $(LOCAL_PATH).  The returned list
289## is relative to $(LOCAL_PATH).
290###########################################################
291
292define all-Iaidl-files-under
293$(call all-named-files-under,I*.aidl,$(1))
294endef
295
296###########################################################
297## Find all of the "I*.aidl" files under $(LOCAL_PATH).
298###########################################################
299
300define all-subdir-Iaidl-files
301$(call all-Iaidl-files-under,.)
302endef
303
304###########################################################
305## Find all of the logtags files under the named directories.
306## Meant to be used like:
307##    SRC_FILES := $(call all-logtags-files-under,src)
308###########################################################
309
310define all-logtags-files-under
311$(call all-named-files-under,*.logtags,$(1))
312endef
313
314###########################################################
315## Find all of the .proto files under the named directories.
316## Meant to be used like:
317##    SRC_FILES := $(call all-proto-files-under,src)
318###########################################################
319
320define all-proto-files-under
321$(call all-named-files-under,*.proto,$(1))
322endef
323
324###########################################################
325## Find all of the RenderScript files under the named directories.
326##  Meant to be used like:
327##    SRC_FILES := $(call all-renderscript-files-under,src)
328###########################################################
329
330define all-renderscript-files-under
331$(call find-subdir-files,$(1) \( -name "*.rs" -or -name "*.fs" \) -and -not -name ".*")
332endef
333
334###########################################################
335## Find all of the S files under the named directories.
336## Meant to be used like:
337##    SRC_FILES := $(call all-c-files-under,src tests)
338###########################################################
339
340define all-S-files-under
341$(call all-named-files-under,*.S,$(1))
342endef
343
344###########################################################
345## Find all of the html files under the named directories.
346## Meant to be used like:
347##    SRC_FILES := $(call all-html-files-under,src tests)
348###########################################################
349
350define all-html-files-under
351$(call all-named-files-under,*.html,$(1))
352endef
353
354###########################################################
355## Find all of the html files from here.  Meant to be used like:
356##    SRC_FILES := $(call all-subdir-html-files)
357###########################################################
358
359define all-subdir-html-files
360$(call all-html-files-under,.)
361endef
362
363###########################################################
364## Find all of the files matching pattern
365##    SRC_FILES := $(call find-subdir-files, <pattern>)
366###########################################################
367
368define find-subdir-files
369$(sort $(patsubst ./%,%,$(shell cd $(LOCAL_PATH) ; find -L $(1))))
370endef
371
372###########################################################
373# find the files in the subdirectory $1 of LOCAL_DIR
374# matching pattern $2, filtering out files $3
375# e.g.
376#     SRC_FILES += $(call find-subdir-subdir-files, \
377#                         css, *.cpp, DontWantThis.cpp)
378###########################################################
379
380define find-subdir-subdir-files
381$(sort $(filter-out $(patsubst %,$(1)/%,$(3)),$(patsubst ./%,%,$(shell cd \
382            $(LOCAL_PATH) ; find -L $(1) -maxdepth 1 -name $(2)))))
383endef
384
385###########################################################
386## Find all of the files matching pattern
387##    SRC_FILES := $(call all-subdir-java-files)
388###########################################################
389
390define find-subdir-assets
391$(sort $(if $(1),$(patsubst ./%,%, \
392	$(shell if [ -d $(1) ] ; then cd $(1) ; find ./ -not -name '.*' -and -type f -and -not -type l ; fi)), \
393	$(warning Empty argument supplied to find-subdir-assets) \
394))
395endef
396
397###########################################################
398## Find various file types in a list of directories relative to $(LOCAL_PATH)
399###########################################################
400
401define find-other-java-files
402$(call all-java-files-under,$(1))
403endef
404
405define find-other-html-files
406$(call all-html-files-under,$(1))
407endef
408
409###########################################################
410# Use utility find to find given files in the given subdirs.
411# This function uses $(1), instead of LOCAL_PATH as the base.
412# $(1): the base dir, relative to the root of the source tree.
413# $(2): the file name pattern to be passed to find as "-name".
414# $(3): a list of subdirs of the base dir.
415# Returns: a list of paths relative to the base dir.
416###########################################################
417
418define find-files-in-subdirs
419$(sort $(patsubst ./%,%, \
420  $(shell cd $(1) ; \
421          find -L $(3) -name $(2) -and -not -name ".*") \
422 ))
423endef
424
425###########################################################
426## Scan through each directory of $(1) looking for files
427## that match $(2) using $(wildcard).  Useful for seeing if
428## a given directory or one of its parents contains
429## a particular file.  Returns the first match found,
430## starting furthest from the root.
431###########################################################
432
433define find-parent-file
434$(strip \
435  $(eval _fpf := $(sort $(wildcard $(foreach f, $(2), $(strip $(1))/$(f))))) \
436  $(if $(_fpf),$(_fpf), \
437       $(if $(filter-out ./ .,$(1)), \
438             $(call find-parent-file,$(patsubst %/,%,$(dir $(1))),$(2)) \
439        ) \
440   ) \
441)
442endef
443
444###########################################################
445## Function we can evaluate to introduce a dynamic dependency
446###########################################################
447
448define add-dependency
449$(1): $(2)
450endef
451
452###########################################################
453## Reverse order of a list
454###########################################################
455
456define reverse-list
457$(if $(1),$(call reverse-list,$(wordlist 2,$(words $(1)),$(1)))) $(firstword $(1))
458endef
459
460###########################################################
461## The intermediates directory.  Where object files go for
462## a given target.  We could technically get away without
463## the "_intermediates" suffix on the directory, but it's
464## nice to be able to grep for that string to find out if
465## anyone's abusing the system.
466###########################################################
467
468# $(1): target class, like "APPS"
469# $(2): target name, like "NotePad"
470# $(3): if non-empty, this is a HOST target.
471# $(4): if non-empty, force the intermediates to be COMMON
472# $(5): if non-empty, force the intermediates to be for the 2nd arch
473# $(6): if non-empty, force the intermediates to be for the host cross os
474define intermediates-dir-for
475$(strip \
476    $(eval _idfClass := $(strip $(1))) \
477    $(if $(_idfClass),, \
478        $(error $(LOCAL_PATH): Class not defined in call to intermediates-dir-for)) \
479    $(eval _idfName := $(strip $(2))) \
480    $(if $(_idfName),, \
481        $(error $(LOCAL_PATH): Name not defined in call to intermediates-dir-for)) \
482    $(eval _idfPrefix := $(if $(strip $(3)),$(if $(strip $(6)),HOST_CROSS,HOST),TARGET)) \
483    $(eval _idf2ndArchPrefix := $(if $(strip $(5)),$(TARGET_2ND_ARCH_VAR_PREFIX))) \
484    $(if $(filter $(_idfPrefix)-$(_idfClass),$(COMMON_MODULE_CLASSES))$(4), \
485        $(eval _idfIntBase := $($(_idfPrefix)_OUT_COMMON_INTERMEDIATES)) \
486      ,$(if $(filter $(_idfClass),$(PER_ARCH_MODULE_CLASSES)),\
487          $(eval _idfIntBase := $($(_idf2ndArchPrefix)$(_idfPrefix)_OUT_INTERMEDIATES)) \
488       ,$(eval _idfIntBase := $($(_idfPrefix)_OUT_INTERMEDIATES)) \
489       ) \
490     ) \
491    $(_idfIntBase)/$(_idfClass)/$(_idfName)_intermediates \
492)
493endef
494
495# Uses LOCAL_MODULE_CLASS, LOCAL_MODULE, and LOCAL_IS_HOST_MODULE
496# to determine the intermediates directory.
497#
498# $(1): if non-empty, force the intermediates to be COMMON
499# $(2): if non-empty, force the intermediates to be for the 2nd arch
500# $(3): if non-empty, force the intermediates to be for the host cross os
501define local-intermediates-dir
502$(strip \
503    $(if $(strip $(LOCAL_MODULE_CLASS)),, \
504        $(error $(LOCAL_PATH): LOCAL_MODULE_CLASS not defined before call to local-intermediates-dir)) \
505    $(if $(strip $(LOCAL_MODULE)),, \
506        $(error $(LOCAL_PATH): LOCAL_MODULE not defined before call to local-intermediates-dir)) \
507    $(call intermediates-dir-for,$(LOCAL_MODULE_CLASS),$(LOCAL_MODULE),$(LOCAL_IS_HOST_MODULE),$(1),$(2),$(3)) \
508)
509endef
510
511###########################################################
512## The generated sources directory.  Placing generated
513## source files directly in the intermediates directory
514## causes problems for multiarch builds, where there are
515## two intermediates directories for a single target. Put
516## them in a separate directory, and they will be copied to
517## each intermediates directory automatically.
518###########################################################
519
520# $(1): target class, like "APPS"
521# $(2): target name, like "NotePad"
522# $(3): if non-empty, this is a HOST target.
523# $(4): if non-empty, force the generated sources to be COMMON
524define generated-sources-dir-for
525$(strip \
526    $(eval _idfClass := $(strip $(1))) \
527    $(if $(_idfClass),, \
528        $(error $(LOCAL_PATH): Class not defined in call to generated-sources-dir-for)) \
529    $(eval _idfName := $(strip $(2))) \
530    $(if $(_idfName),, \
531        $(error $(LOCAL_PATH): Name not defined in call to generated-sources-dir-for)) \
532    $(eval _idfPrefix := $(if $(strip $(3)),HOST,TARGET)) \
533    $(if $(filter $(_idfPrefix)-$(_idfClass),$(COMMON_MODULE_CLASSES))$(4), \
534        $(eval _idfIntBase := $($(_idfPrefix)_OUT_COMMON_GEN)) \
535      , \
536        $(eval _idfIntBase := $($(_idfPrefix)_OUT_GEN)) \
537     ) \
538    $(_idfIntBase)/$(_idfClass)/$(_idfName)_intermediates \
539)
540endef
541
542# Uses LOCAL_MODULE_CLASS, LOCAL_MODULE, and LOCAL_IS_HOST_MODULE
543# to determine the generated sources directory.
544#
545# $(1): if non-empty, force the intermediates to be COMMON
546define local-generated-sources-dir
547$(strip \
548    $(if $(strip $(LOCAL_MODULE_CLASS)),, \
549        $(error $(LOCAL_PATH): LOCAL_MODULE_CLASS not defined before call to local-generated-sources-dir)) \
550    $(if $(strip $(LOCAL_MODULE)),, \
551        $(error $(LOCAL_PATH): LOCAL_MODULE not defined before call to local-generated-sources-dir)) \
552    $(call generated-sources-dir-for,$(LOCAL_MODULE_CLASS),$(LOCAL_MODULE),$(LOCAL_IS_HOST_MODULE),$(1)) \
553)
554endef
555
556###########################################################
557## Convert "path/to/libXXX.so" to "-lXXX".
558## Any "path/to/libXXX.a" elements pass through unchanged.
559###########################################################
560
561define normalize-libraries
562$(foreach so,$(filter %.so,$(1)),-l$(patsubst lib%.so,%,$(notdir $(so))))\
563$(filter-out %.so,$(1))
564endef
565
566# TODO: change users to call the common version.
567define normalize-host-libraries
568$(call normalize-libraries,$(1))
569endef
570
571define normalize-target-libraries
572$(call normalize-libraries,$(1))
573endef
574
575###########################################################
576## Convert a list of short module names (e.g., "framework", "Browser")
577## into the list of files that are built for those modules.
578## NOTE: this won't return reliable results until after all
579## sub-makefiles have been included.
580## $(1): target list
581###########################################################
582
583define module-built-files
584$(foreach module,$(1),$(ALL_MODULES.$(module).BUILT))
585endef
586
587###########################################################
588## Convert a list of short modules names (e.g., "framework", "Browser")
589## into the list of files that are installed for those modules.
590## NOTE: this won't return reliable results until after all
591## sub-makefiles have been included.
592## $(1): target list
593###########################################################
594
595define module-installed-files
596$(foreach module,$(1),$(ALL_MODULES.$(module).INSTALLED))
597endef
598
599###########################################################
600## Convert a list of short modules names (e.g., "framework", "Browser")
601## into the list of files that should be used when linking
602## against that module as a public API.
603## TODO: Allow this for more than JAVA_LIBRARIES modules
604## NOTE: this won't return reliable results until after all
605## sub-makefiles have been included.
606## $(1): target list
607###########################################################
608
609define module-stubs-files
610$(foreach module,$(1),$(ALL_MODULES.$(module).STUBS))
611endef
612
613###########################################################
614## Evaluates to the timestamp file for a doc module, which
615## is the dependency that should be used.
616## $(1): doc module
617###########################################################
618
619define doc-timestamp-for
620$(OUT_DOCS)/$(strip $(1))-timestamp
621endef
622
623
624###########################################################
625## Convert "core ext framework" to "out/.../javalib.jar ..."
626## $(1): library list
627## $(2): Non-empty if IS_HOST_MODULE
628###########################################################
629
630# $(1): library name
631# $(2): Non-empty if IS_HOST_MODULE
632define _java-lib-dir
633$(call intermediates-dir-for, \
634	JAVA_LIBRARIES,$(1),$(2),COMMON)
635endef
636
637# $(1): library name
638# $(2): Non-empty if IS_HOST_MODULE
639define _java-lib-full-classes.jar
640$(call _java-lib-dir,$(1),$(2))/$(if $(2),javalib,classes)$(COMMON_JAVA_PACKAGE_SUFFIX)
641endef
642
643# Get the jar files (you can pass to "javac -classpath") of static or shared
644# Java libraries that you want to link against.
645# $(1): library name list
646# $(2): Non-empty if IS_HOST_MODULE
647define java-lib-files
648$(foreach lib,$(1),$(call _java-lib-full-classes.jar,$(lib),$(2)))
649endef
650
651# Get the dependency files (you can put on the right side of "|" of a build rule)
652# of the Java libraries.
653# $(1): library name list
654# $(2): Non-empty if IS_HOST_MODULE
655# Historically for target Java libraries we used a different file (javalib.jar)
656# as the dependency.
657# Now we can use classes.jar as dependency, so java-lib-deps is the same
658# as java-lib-files.
659define java-lib-deps
660$(call java-lib-files,$(1),$(2))
661endef
662
663# Get the jar files (you can pass to "javac -classpath") of host dalvik Java libraries.
664# You can also use them as dependency files.
665# A host dalvik Java library is different from a host Java library in that
666# the java lib file is classes.jar, not javalib.jar.
667# $(1): library name list
668define host-dex-java-lib-files
669$(foreach lib,$(1),$(call _java-lib-dir,$(lib),true)/classes.jar)
670endef
671
672###########################################################
673## Convert "core ext framework" to "out/.../classes.jack ..."
674## $(1): library list
675## $(2): Non-empty if IS_HOST_MODULE
676###########################################################
677
678# $(1): library name
679# $(2): Non-empty if IS_HOST_MODULE
680define _jack-lib-full-classes
681$(call _java-lib-dir,$(1),$(2))/classes.jack
682endef
683
684# $(1): library name list
685# $(2): Non-empty if IS_HOST_MODULE
686define jack-lib-files
687$(foreach lib,$(1),$(call _jack-lib-full-classes,$(lib),$(2)))
688endef
689
690# $(1): library name list
691# $(2): Non-empty if IS_HOST_MODULE
692define jack-lib-deps
693$(call jack-lib-files,$(1),$(2))
694endef
695
696###########################################################
697## Run rot13 on a string
698## $(1): the string.  Must be one line.
699###########################################################
700define rot13
701$(shell echo $(1) | tr 'a-zA-Z' 'n-za-mN-ZA-M')
702endef
703
704
705###########################################################
706## Returns true if $(1) and $(2) are equal.  Returns
707## the empty string if they are not equal.
708###########################################################
709define streq
710$(strip $(if $(strip $(1)),\
711  $(if $(strip $(2)),\
712    $(if $(filter-out __,_$(subst $(strip $(1)),,$(strip $(2)))$(subst $(strip $(2)),,$(strip $(1)))_),,true), \
713    ),\
714  $(if $(strip $(2)),\
715    ,\
716    true)\
717 ))
718endef
719
720###########################################################
721## Convert "a b c" into "a:b:c"
722###########################################################
723define normalize-path-list
724$(subst $(space),:,$(strip $(1)))
725endef
726
727###########################################################
728## Read the word out of a colon-separated list of words.
729## This has the same behavior as the built-in function
730## $(word n,str).
731##
732## The individual words may not contain spaces.
733##
734## $(1): 1 based index
735## $(2): value of the form a:b:c...
736###########################################################
737
738define word-colon
739$(word $(1),$(subst :,$(space),$(2)))
740endef
741
742###########################################################
743## Convert "a=b c= d e = f" into "a=b c=d e=f"
744##
745## $(1): list to collapse
746## $(2): if set, separator word; usually "=", ":", or ":="
747##       Defaults to "=" if not set.
748###########################################################
749
750define collapse-pairs
751$(eval _cpSEP := $(strip $(if $(2),$(2),=)))\
752$(subst $(space)$(_cpSEP)$(space),$(_cpSEP),$(strip \
753    $(subst $(_cpSEP), $(_cpSEP) ,$(1))))
754endef
755
756###########################################################
757## Given a list of pairs, if multiple pairs have the same
758## first components, keep only the first pair.
759##
760## $(1): list of pairs
761## $(2): the separator word, such as ":", "=", etc.
762define uniq-pairs-by-first-component
763$(eval _upbfc_fc_set :=)\
764$(strip $(foreach w,$(1), $(eval _first := $(word 1,$(subst $(2),$(space),$(w))))\
765    $(if $(filter $(_upbfc_fc_set),$(_first)),,$(w)\
766        $(eval _upbfc_fc_set += $(_first)))))\
767$(eval _upbfc_fc_set :=)\
768$(eval _first:=)
769endef
770
771###########################################################
772## MODULE_TAG set operations
773###########################################################
774
775# Given a list of tags, return the targets that specify
776# any of those tags.
777# $(1): tag list
778define modules-for-tag-list
779$(sort $(foreach tag,$(1),$(foreach m,$(ALL_MODULE_NAME_TAGS.$(tag)),$(ALL_MODULES.$(m).INSTALLED))))
780endef
781
782# Same as modules-for-tag-list, but operates on
783# ALL_MODULE_NAME_TAGS.
784# $(1): tag list
785define module-names-for-tag-list
786$(sort $(foreach tag,$(1),$(ALL_MODULE_NAME_TAGS.$(tag))))
787endef
788
789# Given an accept and reject list, find the matching
790# set of targets.  If a target has multiple tags and
791# any of them are rejected, the target is rejected.
792# Reject overrides accept.
793# $(1): list of tags to accept
794# $(2): list of tags to reject
795#TODO(dbort): do $(if $(strip $(1)),$(1),$(ALL_MODULE_TAGS))
796#TODO(jbq): as of 20100106 nobody uses the second parameter
797define get-tagged-modules
798$(filter-out \
799	$(call modules-for-tag-list,$(2)), \
800	    $(call modules-for-tag-list,$(1)))
801endef
802
803###########################################################
804## Append a leaf to a base path.  Properly deals with
805## base paths ending in /.
806##
807## $(1): base path
808## $(2): leaf path
809###########################################################
810
811define append-path
812$(subst //,/,$(1)/$(2))
813endef
814
815
816###########################################################
817## Package filtering
818###########################################################
819
820# Given a list of installed modules (short or long names)
821# return a list of the packages (yes, .apk packages, not
822# modules in general) that are overridden by this list and,
823# therefore, should not be installed.
824# $(1): mixed list of installed modules
825# TODO: This is fragile; find a reliable way to get this information.
826define _get-package-overrides
827 $(eval ### Discard any words containing slashes, unless they end in .apk, \
828        ### in which case trim off the directory component and the suffix. \
829        ### If there are no slashes, keep the entire word.)
830 $(eval _gpo_names := $(subst /,@@@ @@@,$(1)))
831 $(eval _gpo_names := \
832     $(filter %.apk,$(_gpo_names)) \
833     $(filter-out %@@@ @@@%,$(_gpo_names)))
834 $(eval _gpo_names := $(patsubst %.apk,%,$(_gpo_names)))
835 $(eval _gpo_names := $(patsubst @@@%,%,$(_gpo_names)))
836
837 $(eval ### Remove any remaining words that contain dots.)
838 $(eval _gpo_names := $(subst .,@@@ @@@,$(_gpo_names)))
839 $(eval _gpo_names := $(filter-out %@@@ @@@%,$(_gpo_names)))
840
841 $(eval ### Now we have a list of any words that could possibly refer to \
842        ### packages, although there may be words that do not.  Only \
843        ### real packages will be present under PACKAGES.*, though.)
844 $(foreach _gpo_name,$(_gpo_names),$(PACKAGES.$(_gpo_name).OVERRIDES))
845endef
846
847define get-package-overrides
848$(sort $(strip $(call _get-package-overrides,$(1))))
849endef
850
851###########################################################
852## Output the command lines, or not
853###########################################################
854
855ifeq ($(strip $(SHOW_COMMANDS)),)
856define pretty
857@echo $1
858endef
859else
860define pretty
861endef
862endif
863
864###########################################################
865## Commands for munging the dependency files the compiler generates
866###########################################################
867# $(1): the input .d file
868# $(2): the output .P file
869define transform-d-to-p-args
870$(hide) cp $(1) $(2); \
871	sed -e 's/#.*//' -e 's/^[^:]*: *//' -e 's/ *\\$$//' \
872		-e '/^$$/ d' -e 's/$$/ :/' < $(1) >> $(2); \
873	rm -f $(1)
874endef
875
876define transform-d-to-p
877$(call transform-d-to-p-args,$(@:%.o=%.d),$(@:%.o=%.P))
878endef
879
880###########################################################
881## Commands for including the dependency files the compiler generates
882###########################################################
883# $(1): the .P file
884# $(2): the main build target
885ifeq ($(BUILDING_WITH_NINJA),true)
886define include-depfile
887$(eval $(2) : .KATI_DEPFILE := $1)
888endef
889else
890define include-depfile
891$(eval -include $1)
892endef
893endif
894
895###########################################################
896## Track source files compiled to objects
897###########################################################
898# $(1): list of sources
899# $(2): list of matching objects
900define track-src-file-obj
901$(eval $(call _track-src-file-obj,$(1)))
902endef
903define _track-src-file-obj
904i := w
905$(foreach s,$(1),
906my_tracked_src_files += $(s)
907my_src_file_obj_$(s) := $$(word $$(words $$(i)),$$(2))
908i += w)
909endef
910
911# $(1): list of sources
912# $(2): list of matching generated sources
913define track-src-file-gen
914$(eval $(call _track-src-file-gen,$(2)))
915endef
916define _track-src-file-gen
917i := w
918$(foreach s,$(1),
919my_tracked_gen_files += $(s)
920my_src_file_gen_$(s) := $$(word $$(words $$(i)),$$(1))
921i += w)
922endef
923
924# $(1): list of generated sources
925# $(2): list of matching objects
926define track-gen-file-obj
927$(call track-src-file-obj,$(foreach f,$(1),\
928  $(or $(my_src_file_gen_$(f)),$(f))),$(2))
929endef
930
931###########################################################
932## Commands for running lex
933###########################################################
934
935define transform-l-to-c-or-cpp
936@echo "Lex: $(PRIVATE_MODULE) <= $<"
937@mkdir -p $(dir $@)
938$(hide) $(LEX) -o$@ $<
939endef
940
941###########################################################
942## Commands for running yacc
943##
944###########################################################
945
946define transform-y-to-c-or-cpp
947@echo "Yacc: $(PRIVATE_MODULE) <= $<"
948@mkdir -p $(dir $@)
949$(YACC) $(PRIVATE_YACCFLAGS) \
950  --defines=$(basename $@).h \
951  -o $@ $<
952endef
953
954###########################################################
955## Commands to compile RenderScript to Java
956###########################################################
957
958## Merge multiple .d files generated by llvm-rs-cc. This is necessary
959## because ninja can handle only a single depfile per build target.
960## .d files generated by llvm-rs-cc define .stamp, .bc, and optionally
961## .java as build targets. However, there's no way to let ninja know
962## dependencies to .bc files and .java files, so we give up build
963## targets for them. As we write the .stamp file as the target by
964## ourselves, the awk script removes the first lines before the colon
965## and append a backslash to the last line to concatenate contents of
966## multiple files.
967# $(1): .d files to be merged
968# $(2): merged .d file
969define _merge-renderscript-d
970$(hide) echo '$@: $(backslash)' > $2
971$(foreach d,$1, \
972  $(hide) awk 'start { sub(/( \\)?$$/, " \\"); print } /:/ { start=1 }' < $d >> $2$(newline))
973$(hide) echo >> $2
974endef
975
976define transform-renderscripts-to-java-and-bc
977@echo "RenderScript: $(PRIVATE_MODULE) <= $(PRIVATE_RS_SOURCE_FILES)"
978$(hide) rm -rf $(PRIVATE_RS_OUTPUT_DIR)
979$(hide) mkdir -p $(PRIVATE_RS_OUTPUT_DIR)/res/raw
980$(hide) mkdir -p $(PRIVATE_RS_OUTPUT_DIR)/src
981$(hide) $(PRIVATE_RS_CC) \
982  -o $(PRIVATE_RS_OUTPUT_DIR)/res/raw \
983  -p $(PRIVATE_RS_OUTPUT_DIR)/src \
984  -d $(PRIVATE_RS_OUTPUT_DIR) \
985  -a $@ -MD \
986  $(addprefix -target-api , $(PRIVATE_RS_TARGET_API)) \
987  $(PRIVATE_RS_FLAGS) \
988  $(foreach inc,$(PRIVATE_RS_INCLUDES),$(addprefix -I , $(inc))) \
989  $(PRIVATE_RS_SOURCE_FILES)
990$(call _merge-renderscript-d,$(PRIVATE_DEP_FILES),$@.d)
991$(call transform-d-to-p-args,$@.d,$@.P)
992$(hide) mkdir -p $(dir $@)
993$(hide) touch $@
994endef
995
996define transform-bc-to-so
997@echo "Renderscript compatibility: $(notdir $@) <= $(notdir $<)"
998$(hide) mkdir -p $(dir $@)
999$(hide) $(BCC_COMPAT) -O3 -o $(dir $@)/$(notdir $(<:.bc=.o)) -fPIC -shared \
1000	-rt-path $(RS_PREBUILT_CLCORE) -mtriple $(RS_COMPAT_TRIPLE) $<
1001$(hide) $(PRIVATE_CXX) -shared -Wl,-soname,$(notdir $@) -nostdlib \
1002	-Wl,-rpath,\$$ORIGIN/../lib \
1003	$(dir $@)/$(notdir $(<:.bc=.o)) \
1004	$(RS_PREBUILT_COMPILER_RT) \
1005	-o $@ $(TARGET_GLOBAL_LDFLAGS) -Wl,--hash-style=sysv -L prebuilts/gcc/ \
1006	$(RS_PREBUILT_LIBPATH) -L $(TARGET_OUT_INTERMEDIATE_LIBRARIES) \
1007	-lRSSupport -lm -lc
1008endef
1009
1010###########################################################
1011## Commands to compile RenderScript to C++
1012###########################################################
1013
1014define transform-renderscripts-to-cpp-and-bc
1015@echo "RenderScript: $(PRIVATE_MODULE) <= $(PRIVATE_RS_SOURCE_FILES)"
1016$(hide) rm -rf $(PRIVATE_RS_OUTPUT_DIR)
1017$(hide) mkdir -p $(PRIVATE_RS_OUTPUT_DIR)/
1018$(hide) $(PRIVATE_RS_CC) \
1019  -o $(PRIVATE_RS_OUTPUT_DIR)/ \
1020  -d $(PRIVATE_RS_OUTPUT_DIR) \
1021  -a $@ -MD \
1022  -reflect-c++ \
1023  $(addprefix -target-api , $(PRIVATE_RS_TARGET_API)) \
1024  $(PRIVATE_RS_FLAGS) \
1025  $(addprefix -I , $(PRIVATE_RS_INCLUDES)) \
1026  $(PRIVATE_RS_SOURCE_FILES)
1027$(call _merge-renderscript-d,$(PRIVATE_DEP_FILES),$@.d)
1028$(call transform-d-to-p-args,$@.d,$@.P)
1029$(hide) mkdir -p $(dir $@)
1030$(hide) touch $@
1031endef
1032
1033
1034###########################################################
1035## Commands for running aidl
1036###########################################################
1037
1038define transform-aidl-to-java
1039@mkdir -p $(dir $@)
1040@echo "Aidl: $(PRIVATE_MODULE) <= $<"
1041$(hide) $(AIDL) -d$(patsubst %.java,%.P,$@) $(PRIVATE_AIDL_FLAGS) $< $@
1042endef
1043#$(AIDL) $(PRIVATE_AIDL_FLAGS) $< - | indent -nut -br -npcs -l1000 > $@
1044
1045define transform-aidl-to-cpp
1046@mkdir -p $(dir $@)
1047@mkdir -p $(PRIVATE_HEADER_OUTPUT_DIR)
1048@echo "Generating C++ from AIDL: $(PRIVATE_MODULE) <= $<"
1049$(hide) $(AIDL_CPP) -d$(basename $@).aidl.P $(PRIVATE_AIDL_FLAGS) \
1050    $< $(PRIVATE_HEADER_OUTPUT_DIR) $@
1051endef
1052
1053## Given a .aidl file path generate the rule to compile it a .cpp file.
1054# $(1): a .aidl source file
1055# $(2): a directory to place the generated .cpp files in
1056# $(3): name of a variable to add the path to the generated source file to
1057#
1058# You must call this with $(eval).
1059define define-aidl-cpp-rule
1060define-aidl-cpp-rule-src := $(patsubst %.aidl,%$(LOCAL_CPP_EXTENSION),$(subst ../,dotdot/,$(addprefix $(2)/,$(1))))
1061$$(define-aidl-cpp-rule-src) : $(LOCAL_PATH)/$(1) $(AIDL_CPP)
1062	$$(transform-aidl-to-cpp)
1063$(3) += $$(define-aidl-cpp-rule-src)
1064endef
1065
1066###########################################################
1067## Commands for running java-event-log-tags.py
1068###########################################################
1069
1070define transform-logtags-to-java
1071@mkdir -p $(dir $@)
1072@echo "logtags: $@ <= $<"
1073$(hide) $(JAVATAGS) -o $@ $^
1074endef
1075
1076
1077###########################################################
1078## Commands for running protoc to compile .proto into .java
1079###########################################################
1080
1081define transform-proto-to-java
1082@mkdir -p $(dir $@)
1083@echo "Protoc: $@ <= $(PRIVATE_PROTO_SRC_FILES)"
1084@rm -rf $(PRIVATE_PROTO_JAVA_OUTPUT_DIR)
1085@mkdir -p $(PRIVATE_PROTO_JAVA_OUTPUT_DIR)
1086$(hide) for f in $(PRIVATE_PROTO_SRC_FILES); do \
1087        $(PROTOC) \
1088        $(addprefix --proto_path=, $(PRIVATE_PROTO_INCLUDES)) \
1089        $(PRIVATE_PROTO_JAVA_OUTPUT_OPTION)="$(PRIVATE_PROTO_JAVA_OUTPUT_PARAMS):$(PRIVATE_PROTO_JAVA_OUTPUT_DIR)" \
1090        $(PRIVATE_PROTOC_FLAGS) \
1091        $$f || exit 33; \
1092        done
1093$(hide) touch $@
1094endef
1095
1096######################################################################
1097## Commands for running protoc to compile .proto into .pb.cc (or.pb.c) and .pb.h
1098######################################################################
1099define transform-proto-to-cc
1100@echo "Protoc: $@ <= $<"
1101@mkdir -p $(dir $@)
1102$(hide) $(PROTOC) \
1103	$(addprefix --proto_path=, $(PRIVATE_PROTO_INCLUDES)) \
1104	$(PRIVATE_PROTOC_FLAGS) \
1105	$<
1106endef
1107
1108
1109######################################################################
1110## Commands for generating DBus adaptors from .dbus-xml files.
1111######################################################################
1112define generate-dbus-adaptors
1113@echo "Generating DBus adaptors for $(PRIVATE_MODULE)"
1114@mkdir -p $(dir $@)
1115$(hide) $(DBUS_GENERATOR) \
1116	--service-config=$(PRIVATE_DBUS_SERVICE_CONFIG) \
1117	--adaptor=$@ \
1118	$<
1119endef
1120
1121######################################################################
1122## Commands for generating DBus proxies from .dbus-xml files.
1123######################################################################
1124define generate-dbus-proxies
1125@echo "Generating DBus proxies for $(PRIVATE_MODULE)"
1126@mkdir -p $(dir $@)
1127$(hide) $(DBUS_GENERATOR) \
1128	--service-config=$(PRIVATE_DBUS_SERVICE_CONFIG) \
1129	--proxy=$@ \
1130	$(filter %.dbus-xml,$^)
1131endef
1132
1133
1134###########################################################
1135## Commands for running gcc to compile a C++ file
1136###########################################################
1137
1138define transform-cpp-to-o
1139@echo "target $(PRIVATE_ARM_MODE) C++: $(PRIVATE_MODULE) <= $<"
1140@mkdir -p $(dir $@)
1141$(hide) $(RELATIVE_PWD) $(PRIVATE_CXX) \
1142	$(addprefix -I , $(PRIVATE_C_INCLUDES)) \
1143	$(shell cat $(PRIVATE_IMPORT_INCLUDES)) \
1144	$(addprefix -isystem ,\
1145	    $(if $(PRIVATE_NO_DEFAULT_COMPILER_FLAGS),, \
1146	        $(filter-out $(PRIVATE_C_INCLUDES), \
1147	            $(PRIVATE_TARGET_PROJECT_INCLUDES) \
1148	            $(PRIVATE_TARGET_C_INCLUDES)))) \
1149	-c \
1150	$(if $(PRIVATE_NO_DEFAULT_COMPILER_FLAGS),, \
1151	    $(PRIVATE_TARGET_GLOBAL_CFLAGS) \
1152	    $(PRIVATE_TARGET_GLOBAL_CPPFLAGS) \
1153	    $(PRIVATE_ARM_CFLAGS) \
1154	 ) \
1155	$(PRIVATE_RTTI_FLAG) \
1156	$(PRIVATE_CFLAGS) \
1157	$(PRIVATE_CPPFLAGS) \
1158	$(PRIVATE_DEBUG_CFLAGS) \
1159	$(PRIVATE_CFLAGS_NO_OVERRIDE) \
1160	$(PRIVATE_CPPFLAGS_NO_OVERRIDE) \
1161	-MD -MF $(patsubst %.o,%.d,$@) -o $@ $<
1162$(transform-d-to-p)
1163endef
1164
1165
1166###########################################################
1167## Commands for running gcc to compile a C file
1168###########################################################
1169
1170# $(1): extra flags
1171define transform-c-or-s-to-o-no-deps
1172@mkdir -p $(dir $@)
1173$(hide) $(RELATIVE_PWD) $(PRIVATE_CC) \
1174	$(addprefix -I , $(PRIVATE_C_INCLUDES)) \
1175	$(shell cat $(PRIVATE_IMPORT_INCLUDES)) \
1176	$(addprefix -isystem ,\
1177	    $(if $(PRIVATE_NO_DEFAULT_COMPILER_FLAGS),, \
1178	        $(filter-out $(PRIVATE_C_INCLUDES), \
1179	            $(PRIVATE_TARGET_PROJECT_INCLUDES) \
1180	            $(PRIVATE_TARGET_C_INCLUDES)))) \
1181	-c \
1182	$(if $(PRIVATE_NO_DEFAULT_COMPILER_FLAGS),, \
1183	    $(PRIVATE_TARGET_GLOBAL_CFLAGS) \
1184	    $(PRIVATE_TARGET_GLOBAL_CONLYFLAGS) \
1185	    $(PRIVATE_ARM_CFLAGS) \
1186	 ) \
1187	 $(1) \
1188	-MD -MF $(patsubst %.o,%.d,$@) -o $@ $<
1189endef
1190
1191define transform-c-to-o-no-deps
1192@echo "target $(PRIVATE_ARM_MODE) C: $(PRIVATE_MODULE) <= $<"
1193$(call transform-c-or-s-to-o-no-deps, \
1194    $(PRIVATE_CFLAGS) \
1195    $(PRIVATE_CONLYFLAGS) \
1196    $(PRIVATE_DEBUG_CFLAGS) \
1197    $(PRIVATE_CFLAGS_NO_OVERRIDE))
1198endef
1199
1200define transform-s-to-o-no-deps
1201@echo "target asm: $(PRIVATE_MODULE) <= $<"
1202$(call transform-c-or-s-to-o-no-deps, $(PRIVATE_ASFLAGS))
1203endef
1204
1205define transform-c-to-o
1206$(transform-c-to-o-no-deps)
1207$(transform-d-to-p)
1208endef
1209
1210define transform-s-to-o
1211$(transform-s-to-o-no-deps)
1212$(transform-d-to-p)
1213endef
1214
1215# YASM compilation
1216define transform-asm-to-o
1217@mkdir -p $(dir $@)
1218$(hide) $(YASM) \
1219    $(addprefix -I , $(PRIVATE_C_INCLUDES)) \
1220    $($(PRIVATE_2ND_ARCH_VAR_PREFIX)TARGET_GLOBAL_YASM_FLAGS) \
1221    $(PRIVATE_ASFLAGS) \
1222    -o $@ $<
1223endef
1224
1225###########################################################
1226## Commands for running gcc to compile an Objective-C file
1227## This should never happen for target builds but this
1228## will error at build time.
1229###########################################################
1230
1231define transform-m-to-o-no-deps
1232@echo "target ObjC: $(PRIVATE_MODULE) <= $<"
1233$(call transform-c-or-s-to-o-no-deps, $(PRIVATE_CFLAGS) $(PRIVATE_DEBUG_CFLAGS))
1234endef
1235
1236define transform-m-to-o
1237$(transform-m-to-o-no-deps)
1238$(transform-d-to-p)
1239endef
1240
1241###########################################################
1242## Commands for running gcc to compile a host C++ file
1243###########################################################
1244
1245define transform-host-cpp-to-o
1246@echo "$($(PRIVATE_PREFIX)DISPLAY) C++: $(PRIVATE_MODULE) <= $<"
1247@mkdir -p $(dir $@)
1248$(hide) $(RELATIVE_PWD) $(PRIVATE_CXX) \
1249	$(addprefix -I , $(PRIVATE_C_INCLUDES)) \
1250	$(shell cat $(PRIVATE_IMPORT_INCLUDES)) \
1251	$(addprefix -isystem ,\
1252	    $(if $(PRIVATE_NO_DEFAULT_COMPILER_FLAGS),, \
1253	        $(filter-out $(PRIVATE_C_INCLUDES), \
1254	            $($(PRIVATE_PREFIX)PROJECT_INCLUDES) \
1255	            $(PRIVATE_HOST_C_INCLUDES)))) \
1256	-c \
1257	$(if $(PRIVATE_NO_DEFAULT_COMPILER_FLAGS),, \
1258	    $(PRIVATE_HOST_GLOBAL_CFLAGS) \
1259	    $(PRIVATE_HOST_GLOBAL_CPPFLAGS) \
1260	 ) \
1261	$(PRIVATE_CFLAGS) \
1262	$(PRIVATE_CPPFLAGS) \
1263	$(PRIVATE_DEBUG_CFLAGS) \
1264	$(PRIVATE_CFLAGS_NO_OVERRIDE) \
1265	$(PRIVATE_CPPFLAGS_NO_OVERRIDE) \
1266	-MD -MF $(patsubst %.o,%.d,$@) -o $@ $<
1267$(transform-d-to-p)
1268endef
1269
1270
1271###########################################################
1272## Commands for running gcc to compile a host C file
1273###########################################################
1274
1275# $(1): extra flags
1276define transform-host-c-or-s-to-o-no-deps
1277@mkdir -p $(dir $@)
1278$(hide) $(RELATIVE_PWD) $(PRIVATE_CC) \
1279	$(addprefix -I , $(PRIVATE_C_INCLUDES)) \
1280	$(shell cat $(PRIVATE_IMPORT_INCLUDES)) \
1281	$(addprefix -isystem ,\
1282	    $(if $(PRIVATE_NO_DEFAULT_COMPILER_FLAGS),, \
1283	        $(filter-out $(PRIVATE_C_INCLUDES), \
1284	            $($(PRIVATE_PREFIX)PROJECT_INCLUDES) \
1285	            $(PRIVATE_HOST_C_INCLUDES)))) \
1286	-c \
1287	$(if $(PRIVATE_NO_DEFAULT_COMPILER_FLAGS),, \
1288	    $(PRIVATE_HOST_GLOBAL_CFLAGS) \
1289	    $(PRIVATE_HOST_GLOBAL_CONLYFLAGS) \
1290	 ) \
1291	$(1) \
1292	$(PRIVATE_CFLAGS_NO_OVERRIDE) \
1293	-MD -MF $(patsubst %.o,%.d,$@) -o $@ $<
1294endef
1295
1296define transform-host-c-to-o-no-deps
1297@echo "$($(PRIVATE_PREFIX)DISPLAY) C: $(PRIVATE_MODULE) <= $<"
1298$(call transform-host-c-or-s-to-o-no-deps, $(PRIVATE_CFLAGS) $(PRIVATE_CONLYFLAGS) $(PRIVATE_DEBUG_CFLAGS))
1299endef
1300
1301define transform-host-s-to-o-no-deps
1302@echo "$($(PRIVATE_PREFIX)DISPLAY) asm: $(PRIVATE_MODULE) <= $<"
1303$(call transform-host-c-or-s-to-o-no-deps, $(PRIVATE_ASFLAGS))
1304endef
1305
1306define transform-host-c-to-o
1307$(transform-host-c-to-o-no-deps)
1308$(transform-d-to-p)
1309endef
1310
1311define transform-host-s-to-o
1312$(transform-host-s-to-o-no-deps)
1313$(transform-d-to-p)
1314endef
1315
1316###########################################################
1317## Commands for running gcc to compile a host Objective-C file
1318###########################################################
1319
1320define transform-host-m-to-o-no-deps
1321@echo "$($(PRIVATE_PREFIX)DISPLAY) ObjC: $(PRIVATE_MODULE) <= $<"
1322$(call transform-host-c-or-s-to-o-no-deps, $(PRIVATE_CFLAGS) $(PRIVATE_DEBUG_CFLAGS))
1323endef
1324
1325define transform-host-m-to-o
1326$(transform-host-m-to-o-no-deps)
1327$(transform-d-to-p)
1328endef
1329
1330###########################################################
1331## Commands for running gcc to compile a host Objective-C++ file
1332###########################################################
1333
1334define transform-host-mm-to-o
1335$(transform-host-cpp-to-o)
1336endef
1337
1338
1339###########################################################
1340## Rules to compile a single C/C++ source with ../ in the path
1341###########################################################
1342# Replace "../" in object paths with $(DOTDOT_REPLACEMENT).
1343DOTDOT_REPLACEMENT := dotdot/
1344
1345## Rule to compile a C++ source file with ../ in the path.
1346## Must be called with $(eval).
1347# $(1): the C++ source file in LOCAL_SRC_FILES.
1348# $(2): the additional dependencies.
1349# $(3): the variable name to collect the output object file.
1350define compile-dotdot-cpp-file
1351o := $(intermediates)/$(patsubst %$(LOCAL_CPP_EXTENSION),%.o,$(subst ../,$(DOTDOT_REPLACEMENT),$(1)))
1352$$(o) : $(TOPDIR)$(LOCAL_PATH)/$(1) $(2)
1353	$$(transform-$$(PRIVATE_HOST)cpp-to-o)
1354-include $$(o:%.o=%.P)
1355$(3) += $$(o)
1356endef
1357
1358## Rule to compile a C source file with ../ in the path.
1359## Must be called with $(eval).
1360# $(1): the C source file in LOCAL_SRC_FILES.
1361# $(2): the additional dependencies.
1362# $(3): the variable name to collect the output object file.
1363define compile-dotdot-c-file
1364o := $(intermediates)/$(patsubst %.c,%.o,$(subst ../,$(DOTDOT_REPLACEMENT),$(1)))
1365$$(o) : $(TOPDIR)$(LOCAL_PATH)/$(1) $(2)
1366	$$(transform-$$(PRIVATE_HOST)c-to-o)
1367-include $$(o:%.o=%.P)
1368$(3) += $$(o)
1369endef
1370
1371## Rule to compile a .S source file with ../ in the path.
1372## Must be called with $(eval).
1373# $(1): the .S source file in LOCAL_SRC_FILES.
1374# $(2): the additional dependencies.
1375# $(3): the variable name to collect the output object file.
1376define compile-dotdot-s-file
1377o := $(intermediates)/$(patsubst %.S,%.o,$(subst ../,$(DOTDOT_REPLACEMENT),$(1)))
1378$$(o) : $(TOPDIR)$(LOCAL_PATH)/$(1) $(2)
1379	$$(transform-$$(PRIVATE_HOST)s-to-o)
1380-include $$(o:%.o=%.P)
1381$(3) += $$(o)
1382endef
1383
1384## Rule to compile a .s source file with ../ in the path.
1385## Must be called with $(eval).
1386# $(1): the .s source file in LOCAL_SRC_FILES.
1387# $(2): the additional dependencies.
1388# $(3): the variable name to collect the output object file.
1389define compile-dotdot-s-file-no-deps
1390o := $(intermediates)/$(patsubst %.s,%.o,$(subst ../,$(DOTDOT_REPLACEMENT),$(1)))
1391$$(o) : $(TOPDIR)$(LOCAL_PATH)/$(1) $(2)
1392	$$(transform-$$(PRIVATE_HOST)s-to-o-no-deps)
1393$(3) += $$(o)
1394endef
1395
1396###########################################################
1397## Commands for running ar
1398###########################################################
1399
1400define _concat-if-arg2-not-empty
1401$(if $(2),$(hide) $(1) $(2))
1402endef
1403
1404# Split long argument list into smaller groups and call the command repeatedly
1405# Call the command at least once even if there are no arguments, as otherwise
1406# the output file won't be created.
1407#
1408# $(1): the command without arguments
1409# $(2): the arguments
1410define split-long-arguments
1411$(hide) $(1) $(wordlist 1,500,$(2))
1412$(call _concat-if-arg2-not-empty,$(1),$(wordlist 501,1000,$(2)))
1413$(call _concat-if-arg2-not-empty,$(1),$(wordlist 1001,1500,$(2)))
1414$(call _concat-if-arg2-not-empty,$(1),$(wordlist 1501,2000,$(2)))
1415$(call _concat-if-arg2-not-empty,$(1),$(wordlist 2001,2500,$(2)))
1416$(call _concat-if-arg2-not-empty,$(1),$(wordlist 2501,3000,$(2)))
1417$(call _concat-if-arg2-not-empty,$(1),$(wordlist 3001,99999,$(2)))
1418endef
1419
1420# $(1): the full path of the source static library.
1421define _extract-and-include-single-target-whole-static-lib
1422$(hide) ldir=$(PRIVATE_INTERMEDIATES_DIR)/WHOLE/$(basename $(notdir $(1)))_objs;\
1423    rm -rf $$ldir; \
1424    mkdir -p $$ldir; \
1425    cp $(1) $$ldir; \
1426    lib_to_include=$$ldir/$(notdir $(1)); \
1427    filelist=; \
1428    subdir=0; \
1429    for f in `$($(PRIVATE_2ND_ARCH_VAR_PREFIX)TARGET_AR) t $(1)`; do \
1430        if [ -e $$ldir/$$f ]; then \
1431            mkdir $$ldir/$$subdir; \
1432            ext=$$subdir/; \
1433            subdir=$$((subdir+1)); \
1434            $($(PRIVATE_2ND_ARCH_VAR_PREFIX)TARGET_AR) m $$lib_to_include $$f; \
1435        else \
1436            ext=; \
1437        fi; \
1438        $($(PRIVATE_2ND_ARCH_VAR_PREFIX)TARGET_AR) p $$lib_to_include $$f > $$ldir/$$ext$$f; \
1439        filelist="$$filelist $$ldir/$$ext$$f"; \
1440    done ; \
1441    $($(PRIVATE_2ND_ARCH_VAR_PREFIX)TARGET_AR) $($(PRIVATE_2ND_ARCH_VAR_PREFIX)TARGET_GLOBAL_ARFLAGS) \
1442        $(PRIVATE_ARFLAGS) $@ $$filelist
1443
1444endef
1445
1446# $(1): the full path of the source static library.
1447define extract-and-include-whole-static-libs-first
1448$(if $(strip $(1)),
1449$(hide) cp $(1) $@)
1450endef
1451
1452define extract-and-include-target-whole-static-libs
1453$(call extract-and-include-whole-static-libs-first, $(firstword $(PRIVATE_ALL_WHOLE_STATIC_LIBRARIES)))
1454$(foreach lib,$(wordlist 2,999,$(PRIVATE_ALL_WHOLE_STATIC_LIBRARIES)), \
1455    $(call _extract-and-include-single-target-whole-static-lib, $(lib)))
1456endef
1457
1458# Explicitly delete the archive first so that ar doesn't
1459# try to add to an existing archive.
1460define transform-o-to-static-lib
1461@echo "target StaticLib: $(PRIVATE_MODULE) ($@)"
1462@mkdir -p $(dir $@)
1463@rm -f $@
1464$(extract-and-include-target-whole-static-libs)
1465$(call split-long-arguments,$($(PRIVATE_2ND_ARCH_VAR_PREFIX)TARGET_AR) \
1466    $($(PRIVATE_2ND_ARCH_VAR_PREFIX)TARGET_GLOBAL_ARFLAGS) \
1467    $(PRIVATE_ARFLAGS) $@,$(PRIVATE_ALL_OBJECTS))
1468endef
1469
1470###########################################################
1471## Commands for running host ar
1472###########################################################
1473
1474# $(1): the full path of the source static library.
1475define _extract-and-include-single-host-whole-static-lib
1476$(hide) ldir=$(PRIVATE_INTERMEDIATES_DIR)/WHOLE/$(basename $(notdir $(1)))_objs;\
1477    rm -rf $$ldir; \
1478    mkdir -p $$ldir; \
1479    cp $(1) $$ldir; \
1480    lib_to_include=$$ldir/$(notdir $(1)); \
1481    filelist=; \
1482    subdir=0; \
1483    for f in `$($(PRIVATE_2ND_ARCH_VAR_PREFIX)$(PRIVATE_PREFIX)AR) t $(1) | \grep '\.o$$'`; do \
1484        if [ -e $$ldir/$$f ]; then \
1485           mkdir $$ldir/$$subdir; \
1486           ext=$$subdir/; \
1487           subdir=$$((subdir+1)); \
1488           $($(PRIVATE_2ND_ARCH_VAR_PREFIX)$(PRIVATE_PREFIX)AR) m $$lib_to_include $$f; \
1489        else \
1490           ext=; \
1491        fi; \
1492        $($(PRIVATE_2ND_ARCH_VAR_PREFIX)$(PRIVATE_PREFIX)AR) p $$lib_to_include $$f > $$ldir/$$ext$$f; \
1493        filelist="$$filelist $$ldir/$$ext$$f"; \
1494    done ; \
1495    $($(PRIVATE_2ND_ARCH_VAR_PREFIX)$(PRIVATE_PREFIX)AR) $($(PRIVATE_2ND_ARCH_VAR_PREFIX)$(PRIVATE_PREFIX)GLOBAL_ARFLAGS) \
1496        $(PRIVATE_ARFLAGS) $@ $$filelist
1497
1498endef
1499
1500define extract-and-include-host-whole-static-libs
1501$(call extract-and-include-whole-static-libs-first, $(firstword $(PRIVATE_ALL_WHOLE_STATIC_LIBRARIES)))
1502$(foreach lib,$(wordlist 2,999,$(PRIVATE_ALL_WHOLE_STATIC_LIBRARIES)), \
1503    $(call _extract-and-include-single-host-whole-static-lib, $(lib)))
1504endef
1505
1506# Explicitly delete the archive first so that ar doesn't
1507# try to add to an existing archive.
1508define transform-host-o-to-static-lib
1509@echo "$($(PRIVATE_PREFIX)DISPLAY) StaticLib: $(PRIVATE_MODULE) ($@)"
1510@mkdir -p $(dir $@)
1511@rm -f $@
1512$(extract-and-include-host-whole-static-libs)
1513$(call split-long-arguments,$($(PRIVATE_2ND_ARCH_VAR_PREFIX)$(PRIVATE_PREFIX)AR) \
1514    $($(PRIVATE_2ND_ARCH_VAR_PREFIX)$(PRIVATE_PREFIX)GLOBAL_ARFLAGS) \
1515    $(PRIVATE_ARFLAGS) $@,$(PRIVATE_ALL_OBJECTS))
1516endef
1517
1518
1519###########################################################
1520## Commands for running gcc to link a shared library or package
1521###########################################################
1522
1523# ld just seems to be so finicky with command order that we allow
1524# it to be overriden en-masse see combo/linux-arm.make for an example.
1525ifneq ($(HOST_CUSTOM_LD_COMMAND),true)
1526define transform-host-o-to-shared-lib-inner
1527$(hide) $(PRIVATE_CXX) \
1528	-Wl,-rpath-link=$($(PRIVATE_2ND_ARCH_VAR_PREFIX)$(PRIVATE_PREFIX)OUT_INTERMEDIATE_LIBRARIES) \
1529	-Wl,-rpath,\$$ORIGIN/../$(notdir $($(PRIVATE_2ND_ARCH_VAR_PREFIX)$(PRIVATE_PREFIX)OUT_SHARED_LIBRARIES)) \
1530	-Wl,-rpath,\$$ORIGIN/$(notdir $($(PRIVATE_2ND_ARCH_VAR_PREFIX)$(PRIVATE_PREFIX)OUT_SHARED_LIBRARIES)) \
1531	-shared -Wl,-soname,$(notdir $@) \
1532	$($(PRIVATE_2ND_ARCH_VAR_PREFIX)$(PRIVATE_PREFIX)GLOBAL_LD_DIRS) \
1533	$(if $(PRIVATE_NO_DEFAULT_COMPILER_FLAGS),, \
1534	   $(PRIVATE_HOST_GLOBAL_LDFLAGS) \
1535	) \
1536	$(PRIVATE_LDFLAGS) \
1537	$(PRIVATE_ALL_OBJECTS) \
1538	-Wl,--whole-archive \
1539	$(call normalize-host-libraries,$(PRIVATE_ALL_WHOLE_STATIC_LIBRARIES)) \
1540	-Wl,--no-whole-archive \
1541	$(if $(PRIVATE_GROUP_STATIC_LIBRARIES),-Wl$(comma)--start-group) \
1542	$(call normalize-host-libraries,$(PRIVATE_ALL_STATIC_LIBRARIES)) \
1543	$(if $(PRIVATE_GROUP_STATIC_LIBRARIES),-Wl$(comma)--end-group) \
1544	$(if $(filter true,$(NATIVE_COVERAGE)),-lgcov) \
1545	$(if $(filter true,$(NATIVE_COVERAGE)),$(PRIVATE_HOST_LIBPROFILE_RT)) \
1546	$(call normalize-host-libraries,$(PRIVATE_ALL_SHARED_LIBRARIES)) \
1547	-o $@ \
1548	$(PRIVATE_LDLIBS)
1549endef
1550endif
1551
1552define transform-host-o-to-shared-lib
1553@echo "$($(PRIVATE_PREFIX)DISPLAY) SharedLib: $(PRIVATE_MODULE) ($@)"
1554@mkdir -p $(dir $@)
1555$(transform-host-o-to-shared-lib-inner)
1556endef
1557
1558define transform-host-o-to-package
1559@echo "$($(PRIVATE_PREFIX)DISPLAY) Package: $(PRIVATE_MODULE) ($@)"
1560@mkdir -p $(dir $@)
1561$(transform-host-o-to-shared-lib-inner)
1562endef
1563
1564
1565###########################################################
1566## Commands for running gcc to link a shared library or package
1567###########################################################
1568
1569define transform-o-to-shared-lib-inner
1570$(hide) $(PRIVATE_CXX) \
1571	-nostdlib -Wl,-soname,$(notdir $@) \
1572	-Wl,--gc-sections \
1573	$(if $(filter true,$(PRIVATE_CLANG)),-shared,-Wl$(comma)-shared) \
1574	$(PRIVATE_TARGET_GLOBAL_LD_DIRS) \
1575	$(PRIVATE_TARGET_CRTBEGIN_SO_O) \
1576	$(PRIVATE_ALL_OBJECTS) \
1577	-Wl,--whole-archive \
1578	$(call normalize-target-libraries,$(PRIVATE_ALL_WHOLE_STATIC_LIBRARIES)) \
1579	-Wl,--no-whole-archive \
1580	$(if $(PRIVATE_GROUP_STATIC_LIBRARIES),-Wl$(comma)--start-group) \
1581	$(call normalize-target-libraries,$(PRIVATE_ALL_STATIC_LIBRARIES)) \
1582	$(if $(PRIVATE_GROUP_STATIC_LIBRARIES),-Wl$(comma)--end-group) \
1583	$(if $(filter true,$(NATIVE_COVERAGE)),$(PRIVATE_TARGET_COVERAGE_LIB)) \
1584	$(PRIVATE_TARGET_LIBATOMIC) \
1585	$(PRIVATE_TARGET_LIBGCC) \
1586	$(call normalize-target-libraries,$(PRIVATE_ALL_SHARED_LIBRARIES)) \
1587	-o $@ \
1588	$(PRIVATE_TARGET_GLOBAL_LDFLAGS) \
1589	$(PRIVATE_LDFLAGS) \
1590	$(PRIVATE_TARGET_CRTEND_SO_O) \
1591	$(PRIVATE_LDLIBS)
1592endef
1593
1594define transform-o-to-shared-lib
1595@echo "target SharedLib: $(PRIVATE_MODULE) ($@)"
1596@mkdir -p $(dir $@)
1597$(transform-o-to-shared-lib-inner)
1598endef
1599
1600###########################################################
1601## Commands for filtering a target executable or library
1602###########################################################
1603
1604ifneq ($(TARGET_BUILD_VARIANT),user)
1605  TARGET_STRIP_EXTRA = && $(PRIVATE_OBJCOPY) --add-gnu-debuglink=$< $@
1606  TARGET_STRIP_KEEP_SYMBOLS_EXTRA = --add-gnu-debuglink=$<
1607endif
1608
1609define transform-to-stripped
1610@echo "target Strip: $(PRIVATE_MODULE) ($@)"
1611@mkdir -p $(dir $@)
1612$(hide) $(PRIVATE_STRIP) --strip-all $< -o $@ \
1613  $(if $(PRIVATE_NO_DEBUGLINK),,$(TARGET_STRIP_EXTRA))
1614endef
1615
1616define transform-to-stripped-keep-symbols
1617@echo "target Strip (keep symbols): $(PRIVATE_MODULE) ($@)"
1618@mkdir -p $(dir $@)
1619$(hide) $(PRIVATE_OBJCOPY) \
1620    `$(PRIVATE_READELF) -S $< | awk '/.debug_/ {print "-R " $$2}' | xargs` \
1621    $(TARGET_STRIP_KEEP_SYMBOLS_EXTRA) $< $@
1622endef
1623
1624###########################################################
1625## Commands for packing a target executable or library
1626###########################################################
1627
1628define pack-elf-relocations
1629@echo "target Pack Relocations: $(PRIVATE_MODULE) ($@)"
1630$(copy-file-to-target)
1631$(hide) $(RELOCATION_PACKER) $@
1632endef
1633
1634###########################################################
1635## Commands for running gcc to link an executable
1636###########################################################
1637
1638define transform-o-to-executable-inner
1639$(hide) $(PRIVATE_CXX) -pie \
1640	-nostdlib -Bdynamic \
1641	-Wl,-dynamic-linker,$(PRIVATE_LINKER) \
1642	-Wl,--gc-sections \
1643	-Wl,-z,nocopyreloc \
1644	$(PRIVATE_TARGET_GLOBAL_LD_DIRS) \
1645	-Wl,-rpath-link=$(PRIVATE_TARGET_OUT_INTERMEDIATE_LIBRARIES) \
1646	$(PRIVATE_TARGET_CRTBEGIN_DYNAMIC_O) \
1647	$(PRIVATE_ALL_OBJECTS) \
1648	-Wl,--whole-archive \
1649	$(call normalize-target-libraries,$(PRIVATE_ALL_WHOLE_STATIC_LIBRARIES)) \
1650	-Wl,--no-whole-archive \
1651	$(if $(PRIVATE_GROUP_STATIC_LIBRARIES),-Wl$(comma)--start-group) \
1652	$(call normalize-target-libraries,$(PRIVATE_ALL_STATIC_LIBRARIES)) \
1653	$(if $(PRIVATE_GROUP_STATIC_LIBRARIES),-Wl$(comma)--end-group) \
1654	$(if $(filter true,$(NATIVE_COVERAGE)),$(PRIVATE_TARGET_COVERAGE_LIB)) \
1655	$(PRIVATE_TARGET_LIBATOMIC) \
1656	$(PRIVATE_TARGET_LIBGCC) \
1657	$(call normalize-target-libraries,$(PRIVATE_ALL_SHARED_LIBRARIES)) \
1658	-o $@ \
1659	$(PRIVATE_TARGET_GLOBAL_LDFLAGS) \
1660	$(PRIVATE_LDFLAGS) \
1661	$(PRIVATE_TARGET_CRTEND_O) \
1662	$(PRIVATE_LDLIBS)
1663endef
1664
1665define transform-o-to-executable
1666@echo "target Executable: $(PRIVATE_MODULE) ($@)"
1667@mkdir -p $(dir $@)
1668$(transform-o-to-executable-inner)
1669endef
1670
1671
1672###########################################################
1673## Commands for linking a static executable. In practice,
1674## we only use this on arm, so the other platforms don't
1675## have transform-o-to-static-executable defined.
1676## Clang driver needs -static to create static executable.
1677## However, bionic/linker uses -shared to overwrite.
1678## Linker for x86 targets does not allow coexistance of -static and -shared,
1679## so we add -static only if -shared is not used.
1680###########################################################
1681
1682define transform-o-to-static-executable-inner
1683$(hide) $(PRIVATE_CXX) \
1684	-nostdlib -Bstatic \
1685	$(if $(filter $(PRIVATE_LDFLAGS),-shared),,-static) \
1686	-Wl,--gc-sections \
1687	-o $@ \
1688	$(PRIVATE_TARGET_GLOBAL_LD_DIRS) \
1689	$(PRIVATE_TARGET_CRTBEGIN_STATIC_O) \
1690	$(PRIVATE_TARGET_GLOBAL_LDFLAGS) \
1691	$(PRIVATE_LDFLAGS) \
1692	$(PRIVATE_ALL_OBJECTS) \
1693	-Wl,--whole-archive \
1694	$(call normalize-target-libraries,$(PRIVATE_ALL_WHOLE_STATIC_LIBRARIES)) \
1695	-Wl,--no-whole-archive \
1696	$(call normalize-target-libraries,$(filter-out %libcompiler_rt.a,$(filter-out %libc_nomalloc.a,$(filter-out %libc.a,$(PRIVATE_ALL_STATIC_LIBRARIES))))) \
1697	-Wl,--start-group \
1698	$(call normalize-target-libraries,$(filter %libc.a,$(PRIVATE_ALL_STATIC_LIBRARIES))) \
1699	$(call normalize-target-libraries,$(filter %libc_nomalloc.a,$(PRIVATE_ALL_STATIC_LIBRARIES))) \
1700	$(if $(filter true,$(NATIVE_COVERAGE)),$(PRIVATE_TARGET_COVERAGE_LIB)) \
1701	$(PRIVATE_TARGET_LIBATOMIC) \
1702	$(call normalize-target-libraries,$(filter %libcompiler_rt.a,$(PRIVATE_ALL_STATIC_LIBRARIES))) \
1703	$(PRIVATE_TARGET_LIBGCC) \
1704	-Wl,--end-group \
1705	$(PRIVATE_TARGET_CRTEND_O)
1706endef
1707
1708define transform-o-to-static-executable
1709@echo "target StaticExecutable: $(PRIVATE_MODULE) ($@)"
1710@mkdir -p $(dir $@)
1711$(transform-o-to-static-executable-inner)
1712endef
1713
1714
1715###########################################################
1716## Commands for running gcc to link a host executable
1717###########################################################
1718ifdef BUILD_HOST_static
1719HOST_FPIE_FLAGS :=
1720else
1721HOST_FPIE_FLAGS := -pie
1722# Force the correct entry point to workaround a bug in binutils that manifests with -pie
1723ifeq ($(HOST_CROSS_OS),windows)
1724HOST_CROSS_FPIE_FLAGS += -Wl,-e_mainCRTStartup
1725endif
1726endif
1727
1728ifneq ($(HOST_CUSTOM_LD_COMMAND),true)
1729define transform-host-o-to-executable-inner
1730$(hide) $(PRIVATE_CXX) \
1731	$(PRIVATE_ALL_OBJECTS) \
1732	-Wl,--whole-archive \
1733	$(call normalize-host-libraries,$(PRIVATE_ALL_WHOLE_STATIC_LIBRARIES)) \
1734	-Wl,--no-whole-archive \
1735	$(if $(PRIVATE_GROUP_STATIC_LIBRARIES),-Wl$(comma)--start-group) \
1736	$(call normalize-host-libraries,$(PRIVATE_ALL_STATIC_LIBRARIES)) \
1737	$(if $(PRIVATE_GROUP_STATIC_LIBRARIES),-Wl$(comma)--end-group) \
1738	$(if $(filter true,$(NATIVE_COVERAGE)),-lgcov) \
1739	$(if $(filter true,$(NATIVE_COVERAGE)),$(PRIVATE_HOST_LIBPROFILE_RT)) \
1740	$(call normalize-host-libraries,$(PRIVATE_ALL_SHARED_LIBRARIES)) \
1741	-Wl,-rpath-link=$($(PRIVATE_2ND_ARCH_VAR_PREFIX)$(PRIVATE_PREFIX)OUT_INTERMEDIATE_LIBRARIES) \
1742	-Wl,-rpath,\$$ORIGIN/../$(notdir $($(PRIVATE_2ND_ARCH_VAR_PREFIX)$(PRIVATE_PREFIX)OUT_SHARED_LIBRARIES)) \
1743	-Wl,-rpath,\$$ORIGIN/$(notdir $($(PRIVATE_2ND_ARCH_VAR_PREFIX)$(PRIVATE_PREFIX)OUT_SHARED_LIBRARIES)) \
1744	$($(PRIVATE_2ND_ARCH_VAR_PREFIX)$(PRIVATE_PREFIX)GLOBAL_LD_DIRS) \
1745	$(if $(PRIVATE_NO_DEFAULT_COMPILER_FLAGS),, \
1746		$(PRIVATE_HOST_GLOBAL_LDFLAGS) \
1747	) \
1748	$(PRIVATE_LDFLAGS) \
1749	-o $@ \
1750	$(PRIVATE_LDLIBS)
1751endef
1752endif
1753
1754define transform-host-o-to-executable
1755@echo "$($(PRIVATE_PREFIX)DISPLAY) Executable: $(PRIVATE_MODULE) ($@)"
1756@mkdir -p $(dir $@)
1757$(transform-host-o-to-executable-inner)
1758endef
1759
1760
1761###########################################################
1762## Commands for running javac to make .class files
1763###########################################################
1764
1765# Add BUILD_NUMBER to apps default version name if it's unbundled build.
1766ifdef TARGET_BUILD_APPS
1767APPS_DEFAULT_VERSION_NAME := $(PLATFORM_VERSION)-$(BUILD_NUMBER_FROM_FILE)
1768else
1769APPS_DEFAULT_VERSION_NAME := $(PLATFORM_VERSION)
1770endif
1771
1772# TODO: Right now we generate the asset resources twice, first as part
1773# of generating the Java classes, then at the end when packaging the final
1774# assets.  This should be changed to do one of two things: (1) Don't generate
1775# any resource files the first time, only create classes during that stage;
1776# or (2) Don't use the -c flag with the second stage, instead taking the
1777# resource files from the first stage as additional input.  My original intent
1778# was to use approach (2), but this requires a little more work in the tool.
1779# Maybe we should just use approach (1).
1780
1781# This rule creates the R.java and Manifest.java files, both of which
1782# are PRODUCT-neutral.  Don't pass PRIVATE_PRODUCT_AAPT_CONFIG to this invocation.
1783define create-resource-java-files
1784@mkdir -p $(PRIVATE_SOURCE_INTERMEDIATES_DIR)
1785@mkdir -p $(dir $(PRIVATE_RESOURCE_PUBLICS_OUTPUT))
1786$(hide) $(AAPT) package $(PRIVATE_AAPT_FLAGS) -m \
1787    $(eval # PRIVATE_PRODUCT_AAPT_CONFIG is intentionally missing-- see comment.) \
1788    $(addprefix -J , $(PRIVATE_SOURCE_INTERMEDIATES_DIR)) \
1789    $(addprefix -M , $(PRIVATE_ANDROID_MANIFEST)) \
1790    $(addprefix -P , $(PRIVATE_RESOURCE_PUBLICS_OUTPUT)) \
1791    $(addprefix -S , $(PRIVATE_RESOURCE_DIR)) \
1792    $(addprefix -A , $(PRIVATE_ASSET_DIR)) \
1793    $(addprefix -I , $(PRIVATE_AAPT_INCLUDES)) \
1794    $(addprefix -G , $(PRIVATE_PROGUARD_OPTIONS_FILE)) \
1795    $(addprefix --min-sdk-version , $(PRIVATE_DEFAULT_APP_TARGET_SDK)) \
1796    $(addprefix --target-sdk-version , $(PRIVATE_DEFAULT_APP_TARGET_SDK)) \
1797    $(if $(filter --version-code,$(PRIVATE_AAPT_FLAGS)),,--version-code $(PLATFORM_SDK_VERSION)) \
1798    $(if $(filter --version-name,$(PRIVATE_AAPT_FLAGS)),,--version-name $(APPS_DEFAULT_VERSION_NAME)) \
1799    $(addprefix --rename-manifest-package , $(PRIVATE_MANIFEST_PACKAGE_NAME)) \
1800    $(addprefix --rename-instrumentation-target-package , $(PRIVATE_MANIFEST_INSTRUMENTATION_FOR)) \
1801    --skip-symbols-without-default-localization
1802endef
1803
1804# Search for generated R.java/Manifest.java, copy the found R.java as $@.
1805# Also copy them to a central 'R' directory to make it easier to add the files to an IDE.
1806define find-generated-R.java
1807$(hide) for GENERATED_MANIFEST_FILE in `find $(PRIVATE_SOURCE_INTERMEDIATES_DIR) \
1808  -name Manifest.java 2> /dev/null`; do \
1809    dir=`awk '/package/{gsub(/\./,"/",$$2);gsub(/;/,"",$$2);print $$2;exit}' $$GENERATED_MANIFEST_FILE`; \
1810    mkdir -p $(TARGET_COMMON_OUT_ROOT)/R/$$dir; \
1811    $(ACP) -fp $$GENERATED_MANIFEST_FILE $(TARGET_COMMON_OUT_ROOT)/R/$$dir; \
1812  done;
1813$(hide) for GENERATED_R_FILE in `find $(PRIVATE_SOURCE_INTERMEDIATES_DIR) \
1814  -name R.java 2> /dev/null`; do \
1815    dir=`awk '/package/{gsub(/\./,"/",$$2);gsub(/;/,"",$$2);print $$2;exit}' $$GENERATED_R_FILE`; \
1816    mkdir -p $(TARGET_COMMON_OUT_ROOT)/R/$$dir; \
1817    $(ACP) -fp $$GENERATED_R_FILE $(TARGET_COMMON_OUT_ROOT)/R/$$dir \
1818      || exit 31; \
1819    $(ACP) -fp $$GENERATED_R_FILE $@ || exit 32; \
1820  done;
1821@# Ensure that the target file is always created, i.e. also in case we did not
1822@# enter the GENERATED_R_FILE-loop above. This avoids unnecessary rebuilding.
1823$(hide) touch $@
1824endef
1825
1826###########################################################
1827# AAPT2 compilation and link
1828###########################################################
1829define aapt2-compile-one-resource-file
1830@mkdir -p $(dir $@)
1831$(hide) $(AAPT2) compile -o $(dir $@) $(PRIVATE_AAPT2_CFLAGS) --legacy $<
1832endef
1833
1834define aapt2-compile-resource-dirs
1835@mkdir -p $(dir $@)
1836$(hide) $(AAPT2) compile -o $@ $(addprefix --dir ,$(PRIVATE_SOURCE_RES_DIRS)) \
1837  $(PRIVATE_AAPT2_CFLAGS) --legacy
1838endef
1839
1840# Set up rule to compile one resource file with aapt2.
1841# Must be called with $(eval).
1842# $(1): the source file
1843# $(2): the output file
1844define aapt2-compile-one-resource-file-rule
1845$(2) : $(1) $(AAPT2)
1846	@echo "AAPT2 compile $$@ <- $$<"
1847	$$(call aapt2-compile-one-resource-file)
1848endef
1849
1850# Convert input resource file path to output file path.
1851# values-[config]/<file>.xml -> values-[config]_<file>.arsc.flat;
1852# For other resource file, just replace the last "/" with "_" and
1853# add .flat extension.
1854#
1855# $(1): the input resource file path
1856# $(2): the base dir of the output file path
1857# Returns: the compiled output file path
1858define aapt2-compiled-resource-out-file
1859$(eval _p_w := $(strip $(subst /,$(space),$(dir $(1)))))$(2)/$(subst $(space),/,$(_p_w))_$(if $(filter values%,$(lastword $(_p_w))),$(patsubst %.xml,%.arsc,$(notdir $(1))),$(notdir $(1))).flat
1860endef
1861
1862define aapt2-link
1863$(hide) $(AAPT2) link -o $@ \
1864  $(PRIVATE_AAPT_FLAGS) \
1865  $(addprefix --manifest ,$(PRIVATE_ANDROID_MANIFEST)) \
1866  $(addprefix -I ,$(PRIVATE_AAPT_INCLUDES)) \
1867  $(addprefix -I ,$(PRIVATE_SHARED_ANDROID_LIBRARIES)) \
1868  $(addprefix --java ,$(PRIVATE_SOURCE_INTERMEDIATES_DIR)) \
1869  $(addprefix --proguard ,$(PRIVATE_PROGUARD_OPTIONS_FILE)) \
1870  $(addprefix --min-sdk-version ,$(PRIVATE_DEFAULT_APP_TARGET_SDK)) \
1871  $(addprefix --target-sdk-version ,$(PRIVATE_DEFAULT_APP_TARGET_SDK)) \
1872  $(if $(filter --product,$(PRIVATE_AAPT_FLAGS)),,$(addprefix --product ,$(PRIVATE_TARGET_AAPT_CHARACTERISTICS))) \
1873  $(addprefix -c ,$(PRIVATE_PRODUCT_AAPT_CONFIG)) \
1874  $(addprefix --preferred-density ,$(PRIVATE_PRODUCT_AAPT_PREF_CONFIG)) \
1875  $(if $(filter --version-code,$(PRIVATE_AAPT_FLAGS)),,--version-code $(PLATFORM_SDK_VERSION)) \
1876  $(if $(filter --version-name,$(PRIVATE_AAPT_FLAGS)),,--version-name $(APPS_DEFAULT_VERSION_NAME)) \
1877  $(addprefix --rename-manifest-package ,$(PRIVATE_MANIFEST_PACKAGE_NAME)) \
1878  $(addprefix --rename-instrumentation-target-package ,$(PRIVATE_MANIFEST_INSTRUMENTATION_FOR)) \
1879  $(addprefix -R , $(PRIVATE_OVERLAY_FLAT)) \
1880  $(PRIVATE_RES_FLAT)
1881endef
1882
1883###########################################################
1884xlint_unchecked := -Xlint:unchecked
1885
1886# emit-line, <word list>, <output file>
1887define emit-line
1888   $(if $(1),echo -n '$(strip $(1)) ' >> $(2))
1889endef
1890
1891# dump-words-to-file, <word list>, <output file>
1892define dump-words-to-file
1893        @rm -f $(2)
1894        @touch $(2)
1895        @$(call emit-line,$(wordlist 1,200,$(1)),$(2))
1896        @$(call emit-line,$(wordlist 201,400,$(1)),$(2))
1897        @$(call emit-line,$(wordlist 401,600,$(1)),$(2))
1898        @$(call emit-line,$(wordlist 601,800,$(1)),$(2))
1899        @$(call emit-line,$(wordlist 801,1000,$(1)),$(2))
1900        @$(call emit-line,$(wordlist 1001,1200,$(1)),$(2))
1901        @$(call emit-line,$(wordlist 1201,1400,$(1)),$(2))
1902        @$(call emit-line,$(wordlist 1401,1600,$(1)),$(2))
1903        @$(call emit-line,$(wordlist 1601,1800,$(1)),$(2))
1904        @$(call emit-line,$(wordlist 1801,2000,$(1)),$(2))
1905        @$(call emit-line,$(wordlist 2001,2200,$(1)),$(2))
1906        @$(call emit-line,$(wordlist 2201,2400,$(1)),$(2))
1907        @$(call emit-line,$(wordlist 2401,2600,$(1)),$(2))
1908        @$(call emit-line,$(wordlist 2601,2800,$(1)),$(2))
1909        @$(call emit-line,$(wordlist 2801,3000,$(1)),$(2))
1910        @$(call emit-line,$(wordlist 3001,3200,$(1)),$(2))
1911        @$(call emit-line,$(wordlist 3201,3400,$(1)),$(2))
1912        @$(call emit-line,$(wordlist 3401,3600,$(1)),$(2))
1913        @$(call emit-line,$(wordlist 3601,3800,$(1)),$(2))
1914        @$(call emit-line,$(wordlist 3801,4000,$(1)),$(2))
1915        @$(call emit-line,$(wordlist 4001,4200,$(1)),$(2))
1916        @$(call emit-line,$(wordlist 4201,4400,$(1)),$(2))
1917        @$(call emit-line,$(wordlist 4401,4600,$(1)),$(2))
1918        @$(call emit-line,$(wordlist 4601,4800,$(1)),$(2))
1919        @$(call emit-line,$(wordlist 4801,5000,$(1)),$(2))
1920        @$(call emit-line,$(wordlist 5001,5200,$(1)),$(2))
1921        @$(call emit-line,$(wordlist 5201,5400,$(1)),$(2))
1922        @$(if $(wordlist 5401,5402,$(1)),$(error Too many words ($(words $(1)))))
1923endef
1924
1925# For a list of jar files, unzip them to a specified directory,
1926# but make sure that no META-INF files come along for the ride,
1927# unless PRIVATE_DONT_DELETE_JAR_META_INF is set.
1928#
1929# $(1): files to unzip
1930# $(2): destination directory
1931define unzip-jar-files
1932  $(hide) for f in $(1); \
1933  do \
1934    if [ ! -f $$f ]; then \
1935      echo Missing file $$f; \
1936      exit 1; \
1937    fi; \
1938    unzip -qo $$f -d $(2); \
1939  done
1940  $(if $(PRIVATE_DONT_DELETE_JAR_META_INF),,$(hide) rm -rf $(2)/META-INF)
1941endef
1942
1943# Call jack
1944#
1945define call-jack
1946 JACK_VERSION=$(PRIVATE_JACK_VERSION) $(JACK) $(DEFAULT_JACK_EXTRA_ARGS)
1947endef
1948
1949# Common definition to invoke javac on the host and target.
1950#
1951# Some historical notes:
1952# - below we write the list of java files to java-source-list to avoid argument
1953#   list length problems with Cygwin
1954# - we filter out duplicate java file names because eclipse's compiler
1955#   doesn't like them.
1956#
1957# $(1): javac
1958# $(2): bootclasspath
1959define compile-java
1960$(hide) rm -f $@
1961$(hide) rm -rf $(PRIVATE_CLASS_INTERMEDIATES_DIR)
1962$(hide) mkdir -p $(dir $@)
1963$(hide) mkdir -p $(PRIVATE_CLASS_INTERMEDIATES_DIR)
1964$(call unzip-jar-files,$(PRIVATE_STATIC_JAVA_LIBRARIES),$(PRIVATE_CLASS_INTERMEDIATES_DIR))
1965$(call dump-words-to-file,$(PRIVATE_JAVA_SOURCES),$(PRIVATE_CLASS_INTERMEDIATES_DIR)/java-source-list)
1966$(hide) if [ -d "$(PRIVATE_SOURCE_INTERMEDIATES_DIR)" ]; then \
1967          find $(PRIVATE_SOURCE_INTERMEDIATES_DIR) -name '*.java' -and -not -name '.*' >> $(PRIVATE_CLASS_INTERMEDIATES_DIR)/java-source-list; \
1968fi
1969$(hide) tr ' ' '\n' < $(PRIVATE_CLASS_INTERMEDIATES_DIR)/java-source-list \
1970    | $(NORMALIZE_PATH) | sort -u > $(PRIVATE_CLASS_INTERMEDIATES_DIR)/java-source-list-uniq
1971$(hide) if [ -s $(PRIVATE_CLASS_INTERMEDIATES_DIR)/java-source-list-uniq ] ; then \
1972    $(1) -encoding UTF-8 \
1973    $(if $(findstring true,$(PRIVATE_WARNINGS_ENABLE)),$(xlint_unchecked),) \
1974    $(2) \
1975    $(addprefix -classpath ,$(strip \
1976        $(call normalize-path-list,$(PRIVATE_ALL_JAVA_LIBRARIES)))) \
1977    $(if $(findstring true,$(PRIVATE_WARNINGS_ENABLE)),$(xlint_unchecked),) \
1978    -extdirs "" -d $(PRIVATE_CLASS_INTERMEDIATES_DIR) \
1979    $(PRIVATE_JAVACFLAGS) \
1980    \@$(PRIVATE_CLASS_INTERMEDIATES_DIR)/java-source-list-uniq \
1981    || ( rm -rf $(PRIVATE_CLASS_INTERMEDIATES_DIR) ; exit 41 ) \
1982fi
1983$(if $(PRIVATE_JAVA_LAYERS_FILE), $(hide) build/tools/java-layers.py \
1984    $(PRIVATE_JAVA_LAYERS_FILE) \@$(PRIVATE_CLASS_INTERMEDIATES_DIR)/java-source-list-uniq,)
1985$(hide) rm -f $(PRIVATE_CLASS_INTERMEDIATES_DIR)/java-source-list
1986$(hide) rm -f $(PRIVATE_CLASS_INTERMEDIATES_DIR)/java-source-list-uniq
1987$(if $(PRIVATE_JAR_EXCLUDE_FILES), $(hide) find $(PRIVATE_CLASS_INTERMEDIATES_DIR) \
1988    -name $(word 1, $(PRIVATE_JAR_EXCLUDE_FILES)) \
1989    $(addprefix -o -name , $(wordlist 2, 999, $(PRIVATE_JAR_EXCLUDE_FILES))) \
1990    | xargs rm -rf)
1991$(if $(PRIVATE_JAR_PACKAGES), \
1992    $(hide) find $(PRIVATE_CLASS_INTERMEDIATES_DIR) -mindepth 1 -type f \
1993        $(foreach pkg, $(PRIVATE_JAR_PACKAGES), \
1994            -not -path $(PRIVATE_CLASS_INTERMEDIATES_DIR)/$(subst .,/,$(pkg))/\*) -delete ; \
1995        find $(PRIVATE_CLASS_INTERMEDIATES_DIR) -empty -delete)
1996$(if $(PRIVATE_JAR_EXCLUDE_PACKAGES), $(hide) rm -rf \
1997    $(foreach pkg, $(PRIVATE_JAR_EXCLUDE_PACKAGES), \
1998        $(PRIVATE_CLASS_INTERMEDIATES_DIR)/$(subst .,/,$(pkg))))
1999$(if $(PRIVATE_RMTYPEDEFS), $(hide) $(RMTYPEDEFS) -v $(PRIVATE_CLASS_INTERMEDIATES_DIR))
2000$(if $(PRIVATE_JAR_MANIFEST), \
2001    $(hide) sed -e "s/%BUILD_NUMBER%/$(BUILD_NUMBER_FROM_FILE)/" \
2002            $(PRIVATE_JAR_MANIFEST) > $(dir $@)/manifest.mf && \
2003        jar -cfm $@ $(dir $@)/manifest.mf \
2004            -C $(PRIVATE_CLASS_INTERMEDIATES_DIR) ., \
2005    $(hide) jar -cf $@ -C $(PRIVATE_CLASS_INTERMEDIATES_DIR) .)
2006$(if $(PRIVATE_EXTRA_JAR_ARGS),$(call add-java-resources-to,$@))
2007endef
2008
2009define transform-java-to-classes.jar
2010@echo "target Java: $(PRIVATE_MODULE) ($(PRIVATE_CLASS_INTERMEDIATES_DIR))"
2011$(call compile-java,$(TARGET_JAVAC),$(PRIVATE_BOOTCLASSPATH))
2012endef
2013
2014# Invoke Jack to compile java from source to dex and jack files.
2015#
2016# Some historical notes:
2017# - below we write the list of java files to java-source-list to avoid argument
2018#   list length problems with Cygwin
2019# - we filter out duplicate java file names because Jack doesn't like them.
2020define jack-java-to-dex
2021$(hide) rm -f $@
2022$(hide) rm -f $(PRIVATE_CLASSES_JACK)
2023$(hide) rm -rf $(PRIVATE_JACK_INTERMEDIATES_DIR)
2024$(hide) mkdir -p $(dir $@)
2025$(hide) mkdir -p $(dir $(PRIVATE_CLASSES_JACK))
2026$(hide) mkdir -p $(PRIVATE_JACK_INTERMEDIATES_DIR)
2027$(if $(PRIVATE_JACK_INCREMENTAL_DIR),$(hide) mkdir -p $(PRIVATE_JACK_INCREMENTAL_DIR))
2028$(call dump-words-to-file,$(PRIVATE_JAVA_SOURCES),$(PRIVATE_JACK_INTERMEDIATES_DIR)/java-source-list)
2029$(hide) if [ -d "$(PRIVATE_SOURCE_INTERMEDIATES_DIR)" ]; then \
2030          find $(PRIVATE_SOURCE_INTERMEDIATES_DIR) -name '*.java' >> $(PRIVATE_JACK_INTERMEDIATES_DIR)/java-source-list; \
2031fi
2032$(hide) tr ' ' '\n' < $(PRIVATE_JACK_INTERMEDIATES_DIR)/java-source-list \
2033    | $(NORMALIZE_PATH) | sort -u > $(PRIVATE_JACK_INTERMEDIATES_DIR)/java-source-list-uniq
2034$(if $(PRIVATE_JACK_PROGUARD_FLAGS), \
2035    $(hide) echo -basedirectory $(CURDIR) > $@.flags; \
2036    echo $(PRIVATE_JACK_PROGUARD_FLAGS) >> $@.flags; \
2037)
2038$(if $(PRIVATE_EXTRA_JAR_ARGS),
2039    $(hide) mkdir -p $@.res.tmp
2040    $(hide) $(call create-empty-package-at,$@.res.tmp.zip)
2041    $(hide) $(call add-java-resources-to,$@.res.tmp.zip)
2042    $(hide) unzip -qo $@.res.tmp.zip -d $@.res.tmp
2043    $(hide) rm $@.res.tmp.zip)
2044$(hide) if [ -s $(PRIVATE_JACK_INTERMEDIATES_DIR)/java-source-list-uniq ] ; then \
2045    export tmpEcjArg="@$(PRIVATE_JACK_INTERMEDIATES_DIR)/java-source-list-uniq"; \
2046else \
2047    export tmpEcjArg=""; \
2048fi; \
2049$(call call-jack) \
2050    $(strip $(PRIVATE_JACK_FLAGS)) \
2051    $(strip $(PRIVATE_JACK_COVERAGE_OPTIONS)) \
2052    $(if $(NO_OPTIMIZE_DX), \
2053        -D jack.dex.optimize="false") \
2054    $(if $(PRIVATE_RMTYPEDEFS), \
2055        -D jack.android.remove-typedef="true") \
2056    $(addprefix --classpath ,$(strip \
2057        $(call normalize-path-list,$(PRIVATE_BOOTCLASSPATH_JAVA_LIBRARIES) $(PRIVATE_ALL_JACK_LIBRARIES)))) \
2058    $(addprefix --import ,$(call reverse-list,$(PRIVATE_STATIC_JACK_LIBRARIES))) \
2059    $(if $(PRIVATE_EXTRA_JAR_ARGS),--import-resource $@.res.tmp) \
2060    -D jack.android.min-api-level=$(PRIVATE_JACK_MIN_SDK_VERSION) \
2061    -D jack.import.resource.policy=keep-first \
2062    -D jack.import.type.policy=keep-first \
2063    --output-jack $(PRIVATE_CLASSES_JACK) \
2064    $(if $(PRIVATE_JACK_INCREMENTAL_DIR),--incremental-folder $(PRIVATE_JACK_INCREMENTAL_DIR)) \
2065    --output-dex $(PRIVATE_JACK_INTERMEDIATES_DIR) \
2066    $(addprefix --config-jarjar ,$(strip $(PRIVATE_JARJAR_RULES))) \
2067    $(if $(PRIVATE_JACK_PROGUARD_FLAGS),--config-proguard $@.flags) \
2068    $$tmpEcjArg \
2069    || ( rm -rf $(PRIVATE_CLASSES_JACK); exit 41 )
2070$(hide) mv $(PRIVATE_JACK_INTERMEDIATES_DIR)/classes*.dex $(dir $@)
2071$(hide) rm -f $(PRIVATE_JACK_INTERMEDIATES_DIR)/java-source-list
2072$(if $(PRIVATE_EXTRA_JAR_ARGS),$(hide) rm -rf $@.res.tmp)
2073$(hide) mv $(PRIVATE_JACK_INTERMEDIATES_DIR)/java-source-list-uniq $(PRIVATE_JACK_INTERMEDIATES_DIR).java-source-list
2074$(if $(PRIVATE_JAR_PACKAGES), $(hide) echo unsupported options PRIVATE_JAR_PACKAGES in $@; exit 53)
2075$(if $(PRIVATE_JAR_EXCLUDE_PACKAGES), $(hide) echo unsupported options JAR_EXCLUDE_PACKAGES in $@; exit 53)
2076$(if $(PRIVATE_JAR_MANIFEST), $(hide) echo unsupported options JAR_MANIFEST in $@; exit 53)
2077endef
2078
2079# Invoke Jack to compile java source just to check it compiles correctly.
2080#
2081# Some historical notes:
2082# - below we write the list of java files to java-source-list to avoid argument
2083#   list length problems with Cygwin
2084# - we filter out duplicate java file names because Jack doesn't like them.
2085define jack-check-java
2086$(hide) rm -f $@
2087$(hide) rm -f $@.java-source-list
2088$(hide) rm -f $@.java-source-list-uniq
2089$(hide) mkdir -p $(dir $@)
2090$(if $(PRIVATE_JACK_INCREMENTAL_DIR),$(hide) mkdir -p $(PRIVATE_JACK_INCREMENTAL_DIR))
2091$(call dump-words-to-file,$(PRIVATE_JAVA_SOURCES),$@.java-source-list)
2092$(hide) if [ -d "$(PRIVATE_SOURCE_INTERMEDIATES_DIR)" ]; then \
2093          find $(PRIVATE_SOURCE_INTERMEDIATES_DIR) -name '*.java' >> $@.java-source-list; \
2094fi
2095$(hide) tr ' ' '\n' < $@.java-source-list \
2096    | sort -u > $@.java-source-list-uniq
2097$(hide) if [ -s $@.java-source-list-uniq ] ; then \
2098	$(call call-jack,$(PRIVATE_JACK_EXTRA_ARGS)) \
2099	    $(strip $(PRIVATE_JACK_FLAGS)) \
2100	    $(strip $(PRIVATE_JACK_DEBUG_FLAGS)) \
2101	    $(addprefix --classpath ,$(strip \
2102	        $(call normalize-path-list,$(call reverse-list,$(PRIVATE_STATIC_JACK_LIBRARIES)) $(PRIVATE_BOOTCLASSPATH_JAVA_LIBRARIES) $(PRIVATE_ALL_JACK_LIBRARIES)))) \
2103	    -D jack.import.resource.policy=keep-first \
2104	    -D jack.android.min-api-level=$(PRIVATE_JACK_MIN_SDK_VERSION) \
2105	    -D jack.import.type.policy=keep-first \
2106	    $(if $(PRIVATE_JACK_INCREMENTAL_DIR),--incremental-folder $(PRIVATE_JACK_INCREMENTAL_DIR)) \
2107	    @$@.java-source-list-uniq; \
2108fi
2109touch $@
2110endef
2111
2112define transform-jar-to-jack
2113	$(hide) mkdir -p $(dir $@)
2114	$(hide) mkdir -p $@.tmpjill.res
2115	$(hide) unzip -qo $< -d $@.tmpjill.res
2116	$(hide) find $@.tmpjill.res -iname "*.class" -delete
2117	$(hide) $(call call-jack) \
2118	    $(PRIVATE_JACK_FLAGS) \
2119        -D jack.import.resource.policy=keep-first \
2120        -D jack.import.type.policy=keep-first \
2121        -D jack.android.min-api-level=$(PRIVATE_JACK_MIN_SDK_VERSION) \
2122	    --import $< \
2123	    --import-resource $@.tmpjill.res \
2124	    --output-jack $@
2125	$(hide) rm -rf $@.tmpjill.res
2126endef
2127
2128# Moves $1.tmp to $1 if necessary. This is designed to be used with
2129# .KATI_RESTAT. For kati, this function doesn't update the timestamp
2130# of $1 when $1.tmp is identical to $1 so that ninja won't rebuild
2131# targets which depend on $1. For GNU make, this function simply
2132# copies $1.tmp to $1.
2133ifeq ($(BUILDING_WITH_NINJA),true)
2134define commit-change-for-toc
2135$(hide) if cmp -s $1.tmp $1 ; then \
2136 rm $1.tmp ; \
2137else \
2138 mv $1.tmp $1 ; \
2139fi
2140endef
2141else
2142define commit-change-for-toc
2143@# make doesn't support restat. We always update .toc files so the dependents will always be updated too.
2144$(hide) mv $1.tmp $1
2145endef
2146endif
2147
2148## Rule to create a table of contents from a .jar file.
2149## Must be called with $(eval).
2150# $(1): A .jar file
2151define _transform-jar-to-toc
2152$1.toc: $1 | $(IJAR)
2153	@echo Generating TOC: $$@
2154	$(hide) $(IJAR) $$< $$@.tmp
2155	$$(call commit-change-for-toc,$$@)
2156endef
2157
2158## Define a rule which generates .jar.toc and mark it as .KATI_RESTAT.
2159# $(1): A .jar file
2160define define-jar-to-toc-rule
2161$(eval $(call _transform-jar-to-toc,$1))\
2162$(eval .KATI_RESTAT: $1.toc)
2163endef
2164
2165ifeq (,$(TARGET_BUILD_APPS))
2166
2167## Rule to create a table of contents from a .dex file.
2168## Must be called with $(eval).
2169# $(1): The directory which contains classes*.dex files
2170define _transform-dex-to-toc
2171$1/classes.dex.toc: PRIVATE_INPUT_DEX_FILES := $1/classes*.dex
2172$1/classes.dex.toc: $1/classes.dex $(DEXDUMP)
2173	@echo Generating TOC: $$@
2174	$(hide) $(DEXDUMP) -l xml $$(PRIVATE_INPUT_DEX_FILES) > $$@.tmp
2175	$$(call commit-change-for-toc,$$@)
2176endef
2177
2178## Define a rule which generates .dex.toc and mark it as .KATI_RESTAT.
2179# $(1): The directory which contains classes*.dex files
2180define define-dex-to-toc-rule
2181$(eval $(call _transform-dex-to-toc,$1))\
2182$(eval .KATI_RESTAT: $1/classes.dex.toc)
2183endef
2184
2185else
2186
2187# Turn off .toc optimization for apps build as we cannot build dexdump.
2188define define-dex-to-toc-rule
2189endef
2190
2191endif  # TARGET_BUILD_APPS
2192
2193
2194# Invoke Jack to compile java from source to jack files without shrink or obfuscation.
2195#
2196# Some historical notes:
2197# - below we write the list of java files to java-source-list to avoid argument
2198#   list length problems with Cygwin
2199# - we filter out duplicate java file names because Jack doesn't like them.
2200define java-to-jack
2201$(hide) rm -f $@
2202$(hide) rm -rf $(PRIVATE_JACK_INTERMEDIATES_DIR)
2203$(hide) mkdir -p $(dir $@)
2204$(hide) mkdir -p $(PRIVATE_JACK_INTERMEDIATES_DIR)
2205$(if $(PRIVATE_JACK_INCREMENTAL_DIR),$(hide) mkdir -p $(PRIVATE_JACK_INCREMENTAL_DIR))
2206$(call dump-words-to-file,$(PRIVATE_JAVA_SOURCES),$(PRIVATE_JACK_INTERMEDIATES_DIR)/java-source-list)
2207$(hide) if [ -d "$(PRIVATE_SOURCE_INTERMEDIATES_DIR)" ]; then \
2208          find $(PRIVATE_SOURCE_INTERMEDIATES_DIR) -name '*.java' >> $(PRIVATE_JACK_INTERMEDIATES_DIR)/java-source-list; \
2209fi
2210$(hide) tr ' ' '\n' < $(PRIVATE_JACK_INTERMEDIATES_DIR)/java-source-list \
2211    | $(NORMALIZE_PATH) | sort -u > $(PRIVATE_JACK_INTERMEDIATES_DIR)/java-source-list-uniq
2212$(if $(PRIVATE_JACK_PROGUARD_FLAGS), \
2213    $(hide) echo -basedirectory $(CURDIR) > $@.flags; \
2214    echo $(PRIVATE_JACK_PROGUARD_FLAGS) >> $@.flags; \
2215)
2216$(if $(PRIVATE_EXTRA_JAR_ARGS),
2217	$(hide) mkdir -p $@.res.tmp
2218	$(hide) $(call create-empty-package-at,$@.res.tmp.zip)
2219	$(hide) $(call add-java-resources-to,$@.res.tmp.zip)
2220	$(hide) unzip -qo $@.res.tmp.zip -d $@.res.tmp
2221	$(hide) rm $@.res.tmp.zip)
2222$(hide) if [ -s $(PRIVATE_JACK_INTERMEDIATES_DIR)/java-source-list-uniq ] ; then \
2223    export tmpEcjArg="@$(PRIVATE_JACK_INTERMEDIATES_DIR)/java-source-list-uniq"; \
2224else \
2225    export tmpEcjArg=""; \
2226fi; \
2227$(call call-jack) \
2228    $(strip $(PRIVATE_JACK_FLAGS)) \
2229    $(if $(NO_OPTIMIZE_DX), \
2230        -D jack.dex.optimize="false") \
2231    $(addprefix --classpath ,$(strip \
2232        $(call normalize-path-list,$(PRIVATE_BOOTCLASSPATH_JAVA_LIBRARIES) $(PRIVATE_ALL_JACK_LIBRARIES)))) \
2233    $(addprefix --import ,$(call reverse-list,$(PRIVATE_STATIC_JACK_LIBRARIES))) \
2234    $(if $(PRIVATE_EXTRA_JAR_ARGS),--import-resource $@.res.tmp) \
2235    -D jack.import.resource.policy=keep-first \
2236    -D jack.import.type.policy=keep-first \
2237    -D jack.android.min-api-level=$(PRIVATE_JACK_MIN_SDK_VERSION) \
2238    $(if $(PRIVATE_JACK_INCREMENTAL_DIR),--incremental-folder $(PRIVATE_JACK_INCREMENTAL_DIR)) \
2239    --output-jack $@ \
2240    $(addprefix --config-jarjar ,$(strip $(PRIVATE_JARJAR_RULES))) \
2241    $(if $(PRIVATE_JACK_PROGUARD_FLAGS),--config-proguard $@.flags) \
2242    $$tmpEcjArg \
2243    || ( rm -f $@ ; exit 41 )
2244$(hide) rm -f $(PRIVATE_JACK_INTERMEDIATES_DIR)/java-source-list
2245$(if $(PRIVATE_EXTRA_JAR_ARGS),$(hide) rm -rf $@.res.tmp)
2246$(hide) mv $(PRIVATE_JACK_INTERMEDIATES_DIR)/java-source-list-uniq $(PRIVATE_JACK_INTERMEDIATES_DIR).java-source-list
2247$(if $(PRIVATE_JAR_PACKAGES), $(hide) echo unsupported options PRIVATE_JAR_PACKAGES in $@; exit 53)
2248$(if $(PRIVATE_JAR_EXCLUDE_PACKAGES), $(hide) echo unsupported options JAR_EXCLUDE_PACKAGES in $@; exit 53)
2249$(if $(PRIVATE_JAR_MANIFEST), $(hide) echo unsupported options JAR_MANIFEST in $@; exit 53)
2250endef
2251
2252define transform-classes.jar-to-emma
2253$(hide) java -classpath $(EMMA_JAR) emma instr -outmode fullcopy -outfile \
2254    $(PRIVATE_EMMA_COVERAGE_FILE) -ip $< -d $(PRIVATE_EMMA_INTERMEDIATES_DIR) \
2255    $(addprefix -ix , $(PRIVATE_EMMA_COVERAGE_FILTER))
2256endef
2257
2258#TODO: use a smaller -Xmx value for most libraries;
2259#      only core.jar and framework.jar need a heap this big.
2260define transform-classes.jar-to-dex
2261@echo "target Dex: $(PRIVATE_MODULE)"
2262@mkdir -p $(dir $@)
2263$(hide) rm -f $(dir $@)classes*.dex
2264$(hide) $(DX) \
2265    -JXms16M -JXmx2048M \
2266    --dex --output=$(dir $@) \
2267    $(if $(NO_OPTIMIZE_DX), \
2268        --no-optimize) \
2269    $(if $(GENERATE_DEX_DEBUG), \
2270	    --debug --verbose \
2271	    --dump-to=$(@:.dex=.lst) \
2272	    --dump-width=1000) \
2273    $(PRIVATE_DX_FLAGS) \
2274    $<
2275endef
2276
2277# Create a mostly-empty .jar file that we'll add to later.
2278# The MacOS jar tool doesn't like creating empty jar files,
2279# so we need to give it something.
2280# $(1) package to create
2281define create-empty-package-at
2282@mkdir -p $(dir $(1))
2283$(hide) touch $(dir $(1))zipdummy
2284$(hide) (cd $(dir $(1)) && jar cf $(notdir $(1)) zipdummy)
2285$(hide) zip -qd $(1) zipdummy
2286$(hide) rm $(dir $(1))zipdummy
2287endef
2288
2289# Create a mostly-empty .jar file that we'll add to later.
2290# The MacOS jar tool doesn't like creating empty jar files,
2291# so we need to give it something.
2292define create-empty-package
2293$(call create-empty-package-at,$@)
2294endef
2295
2296# Copy an arhchive file and delete any class files and empty folders inside.
2297# $(1): the source archive file.
2298# $(2): the destination archive file.
2299define initialize-package-file
2300@mkdir -p $(dir $(2))
2301$(hide) cp -f $(1) $(2)
2302$(hide) zip -qd $(2) "*.class" \
2303    $(if $(strip $(PRIVATE_DONT_DELETE_JAR_DIRS)),,"*/") \
2304    || true # Ignore the error when nothing to delete.
2305endef
2306
2307#TODO: we kinda want to build different asset packages for
2308#      different configurations, then combine them later (or something).
2309#      Per-locale, etc.
2310#      A list of dynamic and static parameters;  build layers for
2311#      dynamic params that lay over the static ones.
2312#TODO: update the manifest to point to the package file
2313#Note that the version numbers are given to aapt as simple default
2314#values; applications can override these by explicitly stating
2315#them in their manifest.
2316define add-assets-to-package
2317$(hide) $(AAPT) package -u $(PRIVATE_AAPT_FLAGS) \
2318    $(addprefix -c , $(PRIVATE_PRODUCT_AAPT_CONFIG)) \
2319    $(addprefix --preferred-density , $(PRIVATE_PRODUCT_AAPT_PREF_CONFIG)) \
2320    $(addprefix -M , $(PRIVATE_ANDROID_MANIFEST)) \
2321    $(addprefix -S , $(PRIVATE_RESOURCE_DIR)) \
2322    $(addprefix -A , $(PRIVATE_ASSET_DIR)) \
2323    $(addprefix -I , $(PRIVATE_AAPT_INCLUDES)) \
2324    $(addprefix --min-sdk-version , $(PRIVATE_DEFAULT_APP_TARGET_SDK)) \
2325    $(addprefix --target-sdk-version , $(PRIVATE_DEFAULT_APP_TARGET_SDK)) \
2326    $(if $(filter --product,$(PRIVATE_AAPT_FLAGS)),,$(addprefix --product , $(PRIVATE_TARGET_AAPT_CHARACTERISTICS))) \
2327    $(if $(filter --version-code,$(PRIVATE_AAPT_FLAGS)),,--version-code $(PLATFORM_SDK_VERSION)) \
2328    $(if $(filter --version-name,$(PRIVATE_AAPT_FLAGS)),,--version-name $(APPS_DEFAULT_VERSION_NAME)) \
2329    $(addprefix --rename-manifest-package , $(PRIVATE_MANIFEST_PACKAGE_NAME)) \
2330    $(addprefix --rename-instrumentation-target-package , $(PRIVATE_MANIFEST_INSTRUMENTATION_FOR)) \
2331    --skip-symbols-without-default-localization \
2332    -F $@
2333endef
2334
2335# We need the extra blank line, so that the command will be on a separate line.
2336# $(1): the ABI name
2337# $(2): the list of shared libraies
2338define _add-jni-shared-libs-to-package-per-abi
2339$(hide) cp $(2) $(dir $@)lib/$(1)
2340
2341endef
2342
2343# For apps_only build, don't uncompress/page-align the jni libraries,
2344# because the apk may be run on older platforms that don't support loading jni directly from apk.
2345ifdef TARGET_BUILD_APPS
2346JNI_COMPRESS_FLAGS :=
2347ZIPALIGN_PAGE_ALIGN_FLAGS :=
2348else
2349JNI_COMPRESS_FLAGS := -0
2350ZIPALIGN_PAGE_ALIGN_FLAGS := -p
2351endif
2352
2353define add-jni-shared-libs-to-package
2354$(hide) rm -rf $(dir $@)lib
2355$(hide) mkdir -p $(addprefix $(dir $@)lib/,$(PRIVATE_JNI_SHARED_LIBRARIES_ABI))
2356$(foreach abi,$(PRIVATE_JNI_SHARED_LIBRARIES_ABI),\
2357  $(call _add-jni-shared-libs-to-package-per-abi,$(abi),\
2358    $(patsubst $(abi):%,%,$(filter $(abi):%,$(PRIVATE_JNI_SHARED_LIBRARIES)))))
2359$(hide) (cd $(dir $@) && zip -qrX $(JNI_COMPRESS_FLAGS) $(notdir $@) lib)
2360$(hide) rm -rf $(dir $@)lib
2361endef
2362
2363#TODO: update the manifest to point to the dex file
2364define add-dex-to-package
2365$(call add-dex-to-package-arg,$@)
2366endef
2367
2368# $(1): the package file.
2369define add-dex-to-package-arg
2370$(hide) find $(dir $(PRIVATE_DEX_FILE)) -maxdepth 1 -name "classes*.dex" | sort | xargs zip -qjX $(1)
2371endef
2372
2373# Add java resources added by the current module.
2374# $(1) destination package
2375#
2376define add-java-resources-to
2377$(call dump-words-to-file, $(PRIVATE_EXTRA_JAR_ARGS), $(1).jar-arg-list)
2378$(hide) jar uf $(1) @$(1).jar-arg-list
2379@rm -f $(1).jar-arg-list
2380endef
2381
2382# Add resources carried by static Jack libraries.
2383#
2384define add-carried-jack-resources
2385 $(hide) if [ -d $(PRIVATE_JACK_INTERMEDIATES_DIR) ] ; then \
2386    find $(PRIVATE_JACK_INTERMEDIATES_DIR) -type f | sort \
2387        | sed -e "s?^$(PRIVATE_JACK_INTERMEDIATES_DIR)/? -C \"$(PRIVATE_JACK_INTERMEDIATES_DIR)\" \"?" -e "s/$$/\"/" \
2388        > $(dir $@)jack_res_jar_flags; \
2389    if [ -s $(dir $@)jack_res_jar_flags ] ; then \
2390        jar uf $@ @$(dir $@)jack_res_jar_flags; \
2391    fi; \
2392fi
2393endef
2394
2395# Returns the minSdkVersion of the specified APK as a decimal number. If the
2396# version is a codename, returns the current platform SDK version (always a
2397# decimal number) instead. If the APK does not specify a minSdkVersion, returns
2398# 0 to match how the Android platform interprets this situation at runtime.
2399#
2400define get-package-min-sdk-version-int
2401$$(($(AAPT) dump badging $(1) 2>&1 | grep '^sdkVersion' || echo "sdkVersion:'0'") \
2402    | cut -d"'" -f2 | \
2403    sed -e s/^$(PLATFORM_VERSION_CODENAME)$$/$(PLATFORM_SDK_VERSION)/)
2404endef
2405
2406# Sign a package using the specified key/cert.
2407#
2408define sign-package
2409$(call sign-package-arg,$@)
2410endef
2411
2412# $(1): the package file we are signing.
2413define sign-package-arg
2414$(hide) mv $(1) $(1).unsigned
2415$(hide) java -Djava.library.path=$(SIGNAPK_JNI_LIBRARY_PATH) -jar $(SIGNAPK_JAR) \
2416    --min-sdk-version $(call get-package-min-sdk-version-int,$@.unsigned) \
2417    $(PRIVATE_CERTIFICATE) $(PRIVATE_PRIVATE_KEY) \
2418    $(PRIVATE_ADDITIONAL_CERTIFICATES) $(1).unsigned $(1).signed
2419$(hide) mv $(1).signed $(1)
2420endef
2421
2422# Align STORED entries of a package on 4-byte boundaries to make them easier to mmap.
2423#
2424define align-package
2425$(hide) mv $@ $@.unaligned
2426$(hide) $(ZIPALIGN) \
2427    -f \
2428    $(ZIPALIGN_PAGE_ALIGN_FLAGS) \
2429    4 \
2430    $@.unaligned $@.aligned
2431$(hide) mv $@.aligned $@
2432endef
2433
2434# Remove dynamic timestamps from packages
2435#
2436ifndef TARGET_BUILD_APPS
2437define remove-timestamps-from-package
2438$(hide) $(ZIPTIME) $@
2439endef
2440endif
2441
2442# Uncompress shared libraries embedded in an apk.
2443#
2444define uncompress-shared-libs
2445$(hide) if unzip -l $@ $(PRIVATE_EMBEDDED_JNI_LIBS) >/dev/null ; then \
2446  rm -rf $(dir $@)uncompressedlibs && mkdir $(dir $@)uncompressedlibs; \
2447  unzip $@ $(PRIVATE_EMBEDDED_JNI_LIBS) -d $(dir $@)uncompressedlibs && \
2448  zip -d $@ 'lib/*.so' && \
2449  ( cd $(dir $@)uncompressedlibs && find lib -type f | sort | zip -D -X -0 ../$(notdir $@) -@ ) && \
2450  rm -rf $(dir $@)uncompressedlibs; \
2451  fi
2452endef
2453
2454define install-dex-debug
2455$(hide) if [ -f "$(PRIVATE_INTERMEDIATES_DIR)/classes.dex" ]; then \
2456	    mkdir -p $(TOP)/dalvik/DEBUG-FILES; \
2457	    $(ACP) $(PRIVATE_INTERMEDIATES_DIR)/classes.dex \
2458		$(TOP)/dalvik/DEBUG-FILES/$(PRIVATE_MODULE).dex; \
2459	fi
2460$(hide) if [ -f "$(PRIVATE_INTERMEDIATES_DIR)/classes.lst" ]; then \
2461	    mkdir -p $(TOP)/dalvik/DEBUG-FILES; \
2462	    $(ACP) $(PRIVATE_INTERMEDIATES_DIR)/classes.lst \
2463		$(TOP)/dalvik/DEBUG-FILES/$(PRIVATE_MODULE).lst; \
2464	fi
2465endef
2466
2467# TODO(joeo): If we can ever upgrade to post 3.81 make and get the
2468# new prebuilt rules to work, we should change this to copy the
2469# resources to the out directory and then copy the resources.
2470
2471# Note: we intentionally don't clean PRIVATE_CLASS_INTERMEDIATES_DIR
2472# in transform-java-to-classes for the sake of vm-tests.
2473define transform-host-java-to-package
2474@echo "$($(PRIVATE_PREFIX)DISPLAY) Java: $(PRIVATE_MODULE) ($(PRIVATE_CLASS_INTERMEDIATES_DIR))"
2475$(call compile-java,$(HOST_JAVAC),$(PRIVATE_BOOTCLASSPATH))
2476endef
2477
2478###########################################################
2479## Commands for copying files
2480###########################################################
2481
2482# Define a rule to copy a header.  Used via $(eval) by copy_headers.make.
2483# $(1): source header
2484# $(2): destination header
2485define copy-one-header
2486$(2): $(1)
2487	@echo "Header: $$@"
2488	$$(copy-file-to-new-target-with-cp)
2489endef
2490
2491# Define a rule to copy a file.  For use via $(eval).
2492# $(1): source file
2493# $(2): destination file
2494define copy-one-file
2495$(2): $(1) | $(ACP)
2496	@echo "Copy: $$@"
2497	$$(copy-file-to-target)
2498endef
2499
2500# Copies many files.
2501# $(1): The files to copy.  Each entry is a ':' separated src:dst pair
2502# Evaluates to the list of the dst files (ie suitable for a dependency list)
2503define copy-many-files
2504$(foreach f, $(1), $(strip \
2505    $(eval _cmf_tuple := $(subst :, ,$(f))) \
2506    $(eval _cmf_src := $(word 1,$(_cmf_tuple))) \
2507    $(eval _cmf_dest := $(word 2,$(_cmf_tuple))) \
2508    $(eval $(call copy-one-file,$(_cmf_src),$(_cmf_dest))) \
2509    $(_cmf_dest)))
2510endef
2511
2512# Copy the file only if it's a well-formed xml file. For use via $(eval).
2513# $(1): source file
2514# $(2): destination file, must end with .xml.
2515define copy-xml-file-checked
2516$(2): $(1) | $(ACP)
2517	@echo "Copy xml: $$@"
2518	$(hide) xmllint $$< >/dev/null  # Don't print the xml file to stdout.
2519	$$(copy-file-to-target)
2520endef
2521
2522# The -t option to acp and the -p option to cp is
2523# required for OSX.  OSX has a ridiculous restriction
2524# where it's an error for a .a file's modification time
2525# to disagree with an internal timestamp, and this
2526# macro is used to install .a files (among other things).
2527
2528# Copy a single file from one place to another,
2529# preserving permissions and overwriting any existing
2530# file.
2531# We disable the "-t" option for acp cannot handle
2532# high resolution timestamp correctly on file systems like ext4.
2533# Therefore copy-file-to-target is the same as copy-file-to-new-target.
2534define copy-file-to-target
2535@mkdir -p $(dir $@)
2536$(hide) $(ACP) -fp $< $@
2537endef
2538
2539# The same as copy-file-to-target, but use the local
2540# cp command instead of acp.
2541define copy-file-to-target-with-cp
2542@mkdir -p $(dir $@)
2543$(hide) cp -fp $< $@
2544endef
2545
2546# The same as copy-file-to-target, but use the zipalign tool to do so.
2547define copy-file-to-target-with-zipalign
2548@mkdir -p $(dir $@)
2549$(hide) $(ZIPALIGN) -f 4 $< $@
2550endef
2551
2552# The same as copy-file-to-target, but strip out "# comment"-style
2553# comments (for config files and such).
2554define copy-file-to-target-strip-comments
2555@mkdir -p $(dir $@)
2556$(hide) sed -e 's/#.*$$//' -e 's/[ \t]*$$//' -e '/^$$/d' < $< > $@
2557endef
2558
2559# The same as copy-file-to-target, but don't preserve
2560# the old modification time.
2561define copy-file-to-new-target
2562@mkdir -p $(dir $@)
2563$(hide) $(ACP) -fp $< $@
2564endef
2565
2566# The same as copy-file-to-new-target, but use the local
2567# cp command instead of acp.
2568define copy-file-to-new-target-with-cp
2569@mkdir -p $(dir $@)
2570$(hide) cp -f $< $@
2571endef
2572
2573# Copy a prebuilt file to a target location.
2574define transform-prebuilt-to-target
2575@echo "$(if $(PRIVATE_IS_HOST_MODULE),host,target) Prebuilt: $(PRIVATE_MODULE) ($@)"
2576$(copy-file-to-target)
2577endef
2578
2579# Copy a prebuilt file to a target location, using zipalign on it.
2580define transform-prebuilt-to-target-with-zipalign
2581@echo "$(if $(PRIVATE_IS_HOST_MODULE),host,target) Prebuilt APK: $(PRIVATE_MODULE) ($@)"
2582$(copy-file-to-target-with-zipalign)
2583endef
2584
2585# Copy a prebuilt file to a target location, stripping "# comment" comments.
2586define transform-prebuilt-to-target-strip-comments
2587@echo "$(if $(PRIVATE_IS_HOST_MODULE),host,target) Prebuilt: $(PRIVATE_MODULE) ($@)"
2588$(copy-file-to-target-strip-comments)
2589endef
2590
2591# Copy a list of files/directories to target location, with sub dir structure preserved.
2592# For example $(HOST_OUT_EXECUTABLES)/aapt -> $(staging)/bin/aapt .
2593# $(1): the source list of files/directories.
2594# $(2): the path prefix to strip. In the above example it would be $(HOST_OUT).
2595# $(3): the target location.
2596define copy-files-with-structure
2597$(foreach t,$(1),\
2598  $(eval s := $(patsubst $(2)%,%,$(t)))\
2599  $(hide) mkdir -p $(dir $(3)/$(s)); cp -Rf $(t) $(3)/$(s)$(newline))
2600endef
2601
2602
2603###########################################################
2604## Commands to call Proguard
2605###########################################################
2606define transform-jar-to-proguard
2607@echo Proguard: $@
2608$(hide) $(PROGUARD) -injars $< -outjars $@ $(PRIVATE_PROGUARD_FLAGS) \
2609    $(addprefix -injars , $(PRIVATE_EXTRA_INPUT_JAR))
2610endef
2611
2612###########################################################
2613## Stuff source generated from one-off tools
2614###########################################################
2615
2616define transform-generated-source
2617@echo "target Generated: $(PRIVATE_MODULE) <= $<"
2618@mkdir -p $(dir $@)
2619$(hide) $(PRIVATE_CUSTOM_TOOL)
2620endef
2621
2622
2623###########################################################
2624## Assertions about attributes of the target
2625###########################################################
2626
2627# $(1): The file to check
2628ifndef get-file-size
2629$(error HOST_OS must define get-file-size)
2630endif
2631
2632# Convert a partition data size (eg, as reported in /proc/mtd) to the
2633# size of the image used to flash that partition (which includes a
2634# spare area for each page).
2635# $(1): the partition data size
2636define image-size-from-data-size
2637$(strip $(eval _isfds_value := $$(shell echo $$$$(($(1) / $(BOARD_NAND_PAGE_SIZE) * \
2638  ($(BOARD_NAND_PAGE_SIZE)+$(BOARD_NAND_SPARE_SIZE))))))\
2639$(if $(filter 0, $(_isfds_value)),$(shell echo $$(($(BOARD_NAND_PAGE_SIZE)+$(BOARD_NAND_SPARE_SIZE)))),$(_isfds_value))\
2640$(eval _isfds_value :=))
2641endef
2642
2643# $(1): The file(s) to check (often $@)
2644# $(2): The maximum total image size, in decimal bytes.
2645#    Make sure to take into account any reserved space needed for the FS.
2646#
2647# If $(2) is empty, evaluates to "true"
2648#
2649# Reserve bad blocks.  Make sure that MAX(1% of partition size, 2 blocks)
2650# is left over after the image has been flashed.  Round the 1% up to the
2651# next whole flash block size.
2652define assert-max-file-size
2653$(if $(2), \
2654  size=$$(for i in $(1); do $(call get-file-size,$$i); echo +; done; echo 0); \
2655  total=$$(( $$( echo "$$size" ) )); \
2656  printname=$$(echo -n "$(1)" | tr " " +); \
2657  img_blocksize=$(call image-size-from-data-size,$(BOARD_FLASH_BLOCK_SIZE)); \
2658  twoblocks=$$((img_blocksize * 2)); \
2659  onepct=$$((((($(2) / 100) - 1) / img_blocksize + 1) * img_blocksize)); \
2660  reserve=$$((twoblocks > onepct ? twoblocks : onepct)); \
2661  maxsize=$$(($(2) - reserve)); \
2662  echo "$$printname maxsize=$$maxsize blocksize=$$img_blocksize total=$$total reserve=$$reserve"; \
2663  if [ "$$total" -gt "$$maxsize" ]; then \
2664    echo "error: $$printname too large ($$total > [$(2) - $$reserve])"; \
2665    false; \
2666  elif [ "$$total" -gt $$((maxsize - 32768)) ]; then \
2667    echo "WARNING: $$printname approaching size limit ($$total now; limit $$maxsize)"; \
2668  fi \
2669 , \
2670  true \
2671 )
2672endef
2673
2674# Like assert-max-file-size, but the second argument is a partition
2675# size, which we'll convert to a max image size before checking it
2676# against the files.
2677#
2678# $(1): The file(s) to check (often $@)
2679# $(2): The partition size.
2680define assert-max-image-size
2681$(if $(2), \
2682  $(call assert-max-file-size,$(1),$(call image-size-from-data-size,$(2))))
2683endef
2684
2685
2686###########################################################
2687## Define device-specific radio files
2688###########################################################
2689INSTALLED_RADIOIMAGE_TARGET :=
2690
2691# Copy a radio image file to the output location, and add it to
2692# INSTALLED_RADIOIMAGE_TARGET.
2693# $(1): filename
2694define add-radio-file
2695  $(eval $(call add-radio-file-internal,$(1),$(notdir $(1))))
2696endef
2697define add-radio-file-internal
2698INSTALLED_RADIOIMAGE_TARGET += $$(PRODUCT_OUT)/$(2)
2699$$(PRODUCT_OUT)/$(2) : $$(LOCAL_PATH)/$(1) | $$(ACP)
2700	$$(transform-prebuilt-to-target)
2701endef
2702
2703# Version of add-radio-file that also arranges for the version of the
2704# file to be checked against the contents of
2705# $(TARGET_BOARD_INFO_FILE).
2706# $(1): filename
2707# $(2): name of version variable in board-info (eg, "version-baseband")
2708define add-radio-file-checked
2709  $(eval $(call add-radio-file-checked-internal,$(1),$(notdir $(1)),$(2)))
2710endef
2711define add-radio-file-checked-internal
2712INSTALLED_RADIOIMAGE_TARGET += $$(PRODUCT_OUT)/$(2)
2713BOARD_INFO_CHECK += $(3):$(LOCAL_PATH)/$(1)
2714$$(PRODUCT_OUT)/$(2) : $$(LOCAL_PATH)/$(1) | $$(ACP)
2715	$$(transform-prebuilt-to-target)
2716endef
2717
2718
2719###########################################################
2720# Override the package defined in $(1), setting the
2721# variables listed below differently.
2722#
2723#  $(1): The makefile to override (relative to the source
2724#        tree root)
2725#  $(2): Old LOCAL_PACKAGE_NAME value.
2726#  $(3): New LOCAL_PACKAGE_NAME value.
2727#  $(4): New LOCAL_MANIFEST_PACKAGE_NAME value.
2728#  $(5): New LOCAL_CERTIFICATE value.
2729#  $(6): New LOCAL_INSTRUMENTATION_FOR value.
2730#  $(7): New LOCAL_MANIFEST_INSTRUMENTATION_FOR value.
2731#
2732# Note that LOCAL_PACKAGE_OVERRIDES is NOT cleared in
2733# clear_vars.mk.
2734###########################################################
2735define inherit-package
2736  $(eval $(call inherit-package-internal,$(1),$(2),$(3),$(4),$(5),$(6),$(7)))
2737endef
2738
2739define inherit-package-internal
2740  LOCAL_PACKAGE_OVERRIDES \
2741      := $(strip $(1))||$(strip $(2))||$(strip $(3))||$(strip $(4))||&&$(strip $(5))||&&$(strip $(6))||&&$(strip $(7)) $(LOCAL_PACKAGE_OVERRIDES)
2742  include $(1)
2743  LOCAL_PACKAGE_OVERRIDES \
2744      := $(wordlist 1,$(words $(LOCAL_PACKAGE_OVERRIDES)), $(LOCAL_PACKAGE_OVERRIDES))
2745endef
2746
2747# To be used with inherit-package above
2748# Evalutes to true if the package was overridden
2749define set-inherited-package-variables
2750$(strip $(call set-inherited-package-variables-internal))
2751endef
2752
2753define keep-or-override
2754$(eval $(1) := $(if $(2),$(2),$($(1))))
2755endef
2756
2757define set-inherited-package-variables-internal
2758  $(eval _o := $(subst ||, ,$(lastword $(LOCAL_PACKAGE_OVERRIDES))))
2759  $(eval _n := $(subst ||, ,$(firstword $(LOCAL_PACKAGE_OVERRIDES))))
2760  $(if $(filter $(word 2,$(_n)),$(LOCAL_PACKAGE_NAME)), \
2761    $(eval LOCAL_PACKAGE_NAME := $(word 3,$(_o))) \
2762    $(eval LOCAL_MANIFEST_PACKAGE_NAME := $(word 4,$(_o))) \
2763    $(call keep-or-override,LOCAL_CERTIFICATE,$(patsubst &&%,%,$(word 5,$(_o)))) \
2764    $(call keep-or-override,LOCAL_INSTRUMENTATION_FOR,$(patsubst &&%,%,$(word 6,$(_o)))) \
2765    $(call keep-or-override,LOCAL_MANIFEST_INSTRUMENTATION_FOR,$(patsubst &&%,%,$(word 7,$(_o)))) \
2766    $(eval LOCAL_OVERRIDES_PACKAGES := $(sort $(LOCAL_OVERRIDES_PACKAGES) $(word 2,$(_o)))) \
2767    true \
2768  ,)
2769endef
2770
2771###########################################################
2772## API Check
2773###########################################################
2774
2775# eval this to define a rule that runs apicheck.
2776#
2777# Args:
2778#    $(1)  target
2779#    $(2)  stable api file
2780#    $(3)  api file to be tested
2781#    $(4)  stable removed api file
2782#    $(5)  removed api file to be tested
2783#    $(6)  arguments for apicheck
2784#    $(7)  command to run if apicheck failed
2785#    $(8)  target dependent on this api check
2786#    $(9)  additional dependencies
2787define check-api
2788$(TARGET_OUT_COMMON_INTERMEDIATES)/PACKAGING/$(strip $(1))-timestamp: $(2) $(3) $(4) $(APICHECK) $(9)
2789	@echo "Checking API:" $(1)
2790	$(hide) ( $(APICHECK_COMMAND) $(6) $(2) $(3) $(4) $(5) || ( $(7) ; exit 38 ) )
2791	$(hide) mkdir -p $$(dir $$@)
2792	$(hide) touch $$@
2793$(8): $(TARGET_OUT_COMMON_INTERMEDIATES)/PACKAGING/$(strip $(1))-timestamp
2794endef
2795
2796## Whether to build from source if prebuilt alternative exists
2797###########################################################
2798# $(1): module name
2799# $(2): LOCAL_PATH
2800# Expands to empty string if not from source.
2801ifeq (true,$(ANDROID_BUILD_FROM_SOURCE))
2802define if-build-from-source
2803true
2804endef
2805else
2806define if-build-from-source
2807$(if $(filter $(ANDROID_NO_PREBUILT_MODULES),$(1))$(filter \
2808    $(addsuffix %,$(ANDROID_NO_PREBUILT_PATHS)),$(2)),true)
2809endef
2810endif
2811
2812# Include makefile $(1) if build from source for module $(2)
2813# $(1): the makefile to include
2814# $(2): module name
2815# $(3): LOCAL_PATH
2816define include-if-build-from-source
2817$(if $(call if-build-from-source,$(2),$(3)),$(eval include $(1)))
2818endef
2819
2820# Return the arch for the source file of a prebuilt
2821# Return "none" if no matching arch found and return empty
2822# if the input is empty, so the result can be passed to
2823# LOCAL_MODULE_TARGET_ARCH.
2824# $(1) the list of archs supported by the prebuilt
2825define get-prebuilt-src-arch
2826$(strip $(if $(filter $(TARGET_ARCH),$(1)),$(TARGET_ARCH),\
2827  $(if $(filter $(TARGET_2ND_ARCH),$(1)),$(TARGET_2ND_ARCH),$(if $(1),none))))
2828endef
2829
2830###########################################################
2831## Other includes
2832###########################################################
2833
2834# -----------------------------------------------------------------
2835# Rules and functions to help copy important files to DIST_DIR
2836# when requested.
2837include $(BUILD_SYSTEM)/distdir.mk
2838
2839# Include any vendor specific definitions.mk file
2840-include $(TOPDIR)vendor/*/build/core/definitions.mk
2841-include $(TOPDIR)device/*/build/core/definitions.mk
2842-include $(TOPDIR)product/*/build/core/definitions.mk
2843
2844# broken:
2845#	$(foreach file,$^,$(if $(findstring,.a,$(suffix $file)),-l$(file),$(file)))
2846
2847###########################################################
2848## Misc notes
2849###########################################################
2850
2851#DEPDIR = .deps
2852#df = $(DEPDIR)/$(*F)
2853
2854#SRCS = foo.c bar.c ...
2855
2856#%.o : %.c
2857#	@$(MAKEDEPEND); \
2858#	  cp $(df).d $(df).P; \
2859#	  sed -e 's/#.*//' -e 's/^[^:]*: *//' -e 's/ *\\$$//' \
2860#	      -e '/^$$/ d' -e 's/$$/ :/' < $(df).d >> $(df).P; \
2861#	  rm -f $(df).d
2862#	$(COMPILE.c) -o $@ $<
2863
2864#-include $(SRCS:%.c=$(DEPDIR)/%.P)
2865
2866
2867#%.o : %.c
2868#	$(COMPILE.c) -MD -o $@ $<
2869#	@cp $*.d $*.P; \
2870#	  sed -e 's/#.*//' -e 's/^[^:]*: *//' -e 's/ *\\$$//' \
2871#	      -e '/^$$/ d' -e 's/$$/ :/' < $*.d >> $*.P; \
2872#	  rm -f $*.d
2873