xref: /aosp_15_r20/build/make/core/distdir.mk (revision 9e94795a3d4ef5c1d47486f9a02bb378756cea8a)
1*9e94795aSAndroid Build Coastguard Worker#
2*9e94795aSAndroid Build Coastguard Worker# Copyright (C) 2007 The Android Open Source Project
3*9e94795aSAndroid Build Coastguard Worker#
4*9e94795aSAndroid Build Coastguard Worker# Licensed under the Apache License, Version 2.0 (the "License");
5*9e94795aSAndroid Build Coastguard Worker# you may not use this file except in compliance with the License.
6*9e94795aSAndroid Build Coastguard Worker# You may obtain a copy of the License at
7*9e94795aSAndroid Build Coastguard Worker#
8*9e94795aSAndroid Build Coastguard Worker#      http://www.apache.org/licenses/LICENSE-2.0
9*9e94795aSAndroid Build Coastguard Worker#
10*9e94795aSAndroid Build Coastguard Worker# Unless required by applicable law or agreed to in writing, software
11*9e94795aSAndroid Build Coastguard Worker# distributed under the License is distributed on an "AS IS" BASIS,
12*9e94795aSAndroid Build Coastguard Worker# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*9e94795aSAndroid Build Coastguard Worker# See the License for the specific language governing permissions and
14*9e94795aSAndroid Build Coastguard Worker# limitations under the License.
15*9e94795aSAndroid Build Coastguard Worker#
16*9e94795aSAndroid Build Coastguard Worker
17*9e94795aSAndroid Build Coastguard Worker# When specifying "dist", the user has asked that we copy the important
18*9e94795aSAndroid Build Coastguard Worker# files from this build into DIST_DIR.
19*9e94795aSAndroid Build Coastguard Worker
20*9e94795aSAndroid Build Coastguard Worker# list of all goals that depend on any dist files
21*9e94795aSAndroid Build Coastguard Worker_all_dist_goals :=
22*9e94795aSAndroid Build Coastguard Worker# pairs of goal:distfile
23*9e94795aSAndroid Build Coastguard Worker_all_dist_goal_output_pairs :=
24*9e94795aSAndroid Build Coastguard Worker# pairs of srcfile:distfile
25*9e94795aSAndroid Build Coastguard Worker_all_dist_src_dst_pairs :=
26*9e94795aSAndroid Build Coastguard Worker
27*9e94795aSAndroid Build Coastguard Worker# Other parts of the system should use this function to associate
28*9e94795aSAndroid Build Coastguard Worker# certain files with certain goals.  When those goals are built
29*9e94795aSAndroid Build Coastguard Worker# and "dist" is specified, the marked files will be copied to DIST_DIR.
30*9e94795aSAndroid Build Coastguard Worker#
31*9e94795aSAndroid Build Coastguard Worker# $(1): a list of goals  (e.g. droid, sdk, ndk). These must be PHONY
32*9e94795aSAndroid Build Coastguard Worker# $(2): the dist files to add to those goals.  If the file contains ':',
33*9e94795aSAndroid Build Coastguard Worker#       the text following the colon is the name that the file is copied
34*9e94795aSAndroid Build Coastguard Worker#       to under the dist directory.  Subdirs are ok, and will be created
35*9e94795aSAndroid Build Coastguard Worker#       at copy time if necessary.
36*9e94795aSAndroid Build Coastguard Workerdefine dist-for-goals
37*9e94795aSAndroid Build Coastguard Worker$(if $(strip $(2)), \
38*9e94795aSAndroid Build Coastguard Worker  $(eval _all_dist_goals += $$(1))) \
39*9e94795aSAndroid Build Coastguard Worker$(foreach file,$(2), \
40*9e94795aSAndroid Build Coastguard Worker  $(eval src := $(call word-colon,1,$(file))) \
41*9e94795aSAndroid Build Coastguard Worker  $(eval dst := $(call word-colon,2,$(file))) \
42*9e94795aSAndroid Build Coastguard Worker  $(if $(dst),,$(eval dst := $$(notdir $$(src)))) \
43*9e94795aSAndroid Build Coastguard Worker  $(eval _all_dist_src_dst_pairs += $$(src):$$(dst)) \
44*9e94795aSAndroid Build Coastguard Worker  $(foreach goal,$(1), \
45*9e94795aSAndroid Build Coastguard Worker    $(eval _all_dist_goal_output_pairs += $$(goal):$$(dst))))
46*9e94795aSAndroid Build Coastguard Workerendef
47*9e94795aSAndroid Build Coastguard Worker
48*9e94795aSAndroid Build Coastguard Workerdefine add_file_name_tag_suffix
49*9e94795aSAndroid Build Coastguard Worker$(basename $(notdir $1))-FILE_NAME_TAG_PLACEHOLDER$(suffix $1)
50*9e94795aSAndroid Build Coastguard Workerendef
51*9e94795aSAndroid Build Coastguard Worker
52*9e94795aSAndroid Build Coastguard Worker# This function appends suffix FILE_NAME_TAG_PLACEHOLDER from the input file
53*9e94795aSAndroid Build Coastguard Worker# $(1): a list of goals  (e.g. droid, sdk, ndk). These must be PHONY
54*9e94795aSAndroid Build Coastguard Worker# $(2): the dist files to add to those goals.
55*9e94795aSAndroid Build Coastguard Workerdefine dist-for-goals-with-filenametag
56*9e94795aSAndroid Build Coastguard Worker$(if $(strip $(2)), \
57*9e94795aSAndroid Build Coastguard Worker  $(foreach file,$(2), \
58*9e94795aSAndroid Build Coastguard Worker    $(call dist-for-goals,$(1),$(file):$(call add_file_name_tag_suffix,$(file)))))
59*9e94795aSAndroid Build Coastguard Workerendef
60*9e94795aSAndroid Build Coastguard Worker.PHONY: shareprojects
61*9e94795aSAndroid Build Coastguard Worker
62*9e94795aSAndroid Build Coastguard Workerdefine __share-projects-rule
63*9e94795aSAndroid Build Coastguard Worker$(1) : PRIVATE_TARGETS := $(2)
64*9e94795aSAndroid Build Coastguard Worker$(1): $(2) $(COMPLIANCE_LISTSHARE)
65*9e94795aSAndroid Build Coastguard Worker	$(hide) rm -f $$@
66*9e94795aSAndroid Build Coastguard Worker	mkdir -p $$(dir $$@)
67*9e94795aSAndroid Build Coastguard Worker	$$(if $$(strip $$(PRIVATE_TARGETS)),OUT_DIR=$(OUT_DIR) $(COMPLIANCE_LISTSHARE) -o $$@ $$(PRIVATE_TARGETS),touch $$@)
68*9e94795aSAndroid Build Coastguard Workerendef
69*9e94795aSAndroid Build Coastguard Worker
70*9e94795aSAndroid Build Coastguard Worker# build list of projects to share in $(1) for meta_lic in $(2)
71*9e94795aSAndroid Build Coastguard Worker#
72*9e94795aSAndroid Build Coastguard Worker# $(1): the intermediate project sharing file
73*9e94795aSAndroid Build Coastguard Worker# $(2): the license metadata to base the sharing on
74*9e94795aSAndroid Build Coastguard Workerdefine _share-projects-rule
75*9e94795aSAndroid Build Coastguard Worker$(eval $(call __share-projects-rule,$(1),$(2)))
76*9e94795aSAndroid Build Coastguard Workerendef
77*9e94795aSAndroid Build Coastguard Worker
78*9e94795aSAndroid Build Coastguard Worker.PHONY: alllicensetexts
79*9e94795aSAndroid Build Coastguard Worker
80*9e94795aSAndroid Build Coastguard Workerdefine __license-texts-rule
81*9e94795aSAndroid Build Coastguard Worker$(2) : PRIVATE_GOAL := $(1)
82*9e94795aSAndroid Build Coastguard Worker$(2) : PRIVATE_TARGETS := $(3)
83*9e94795aSAndroid Build Coastguard Worker$(2) : PRIVATE_ROOTS := $(4)
84*9e94795aSAndroid Build Coastguard Worker$(2) : PRIVATE_ARGUMENT_FILE := $(call intermediates-dir-for,METAPACKAGING,licensetexts)/$(2)/arguments
85*9e94795aSAndroid Build Coastguard Worker$(2): $(3) $(TEXTNOTICE)
86*9e94795aSAndroid Build Coastguard Worker	$(hide) rm -f $$@
87*9e94795aSAndroid Build Coastguard Worker	mkdir -p $$(dir $$@)
88*9e94795aSAndroid Build Coastguard Worker	mkdir -p $$(dir $$(PRIVATE_ARGUMENT_FILE))
89*9e94795aSAndroid Build Coastguard Worker	$$(if $$(strip $$(PRIVATE_TARGETS)),$$(call dump-words-to-file,\
90*9e94795aSAndroid Build Coastguard Worker            -product="$$(PRIVATE_GOAL)" -title="$$(PRIVATE_GOAL)" \
91*9e94795aSAndroid Build Coastguard Worker            $$(addprefix -strip_prefix ,$$(PRIVATE_ROOTS)) \
92*9e94795aSAndroid Build Coastguard Worker            -strip_prefix=$(PRODUCT_OUT)/ -strip_prefix=$(HOST_OUT)/\
93*9e94795aSAndroid Build Coastguard Worker            $$(PRIVATE_TARGETS),\
94*9e94795aSAndroid Build Coastguard Worker            $$(PRIVATE_ARGUMENT_FILE)))
95*9e94795aSAndroid Build Coastguard Worker	$$(if $$(strip $$(PRIVATE_TARGETS)),OUT_DIR=$(OUT_DIR) $(TEXTNOTICE) -o $$@ @$$(PRIVATE_ARGUMENT_FILE),touch $$@)
96*9e94795aSAndroid Build Coastguard Workerendef
97*9e94795aSAndroid Build Coastguard Worker
98*9e94795aSAndroid Build Coastguard Worker# build list of projects to share in $(2) for meta_lic in $(3) for dist goals $(1)
99*9e94795aSAndroid Build Coastguard Worker# Strip `out/dist/` used as proxy for 'DIST_DIR'
100*9e94795aSAndroid Build Coastguard Worker#
101*9e94795aSAndroid Build Coastguard Worker# $(1): the name of the dist goals
102*9e94795aSAndroid Build Coastguard Worker# $(2): the intermediate project sharing file
103*9e94795aSAndroid Build Coastguard Worker# $(3): the license metadata to base the sharing on
104*9e94795aSAndroid Build Coastguard Workerdefine _license-texts-rule
105*9e94795aSAndroid Build Coastguard Worker$(eval $(call __license-texts-rule,$(1),$(2),$(3),out/dist/))
106*9e94795aSAndroid Build Coastguard Workerendef
107*9e94795aSAndroid Build Coastguard Worker
108*9e94795aSAndroid Build Coastguard Worker###########################################################
109*9e94795aSAndroid Build Coastguard Worker## License metadata build rule for dist target $(1) with meta_lic $(2) copied from $(3)
110*9e94795aSAndroid Build Coastguard Worker###########################################################
111*9e94795aSAndroid Build Coastguard Workerdefine _dist-target-license-metadata-rule
112*9e94795aSAndroid Build Coastguard Worker$(strip $(eval _meta :=$(2)))
113*9e94795aSAndroid Build Coastguard Worker$(strip $(eval _dep:=))
114*9e94795aSAndroid Build Coastguard Worker# 0p is the indicator for a non-copyrightable file where no party owns the copyright.
115*9e94795aSAndroid Build Coastguard Worker# i.e. pure data with no copyrightable expression.
116*9e94795aSAndroid Build Coastguard Worker# If all of the sources are 0p and only 0p, treat the copied file as 0p. Otherwise, all
117*9e94795aSAndroid Build Coastguard Worker# of the sources must either be 0p or originate from a single metadata file to copy.
118*9e94795aSAndroid Build Coastguard Worker$(strip $(foreach s,$(strip $(3)),\
119*9e94795aSAndroid Build Coastguard Worker  $(eval _dmeta:=$(ALL_TARGETS.$(s).META_LIC))\
120*9e94795aSAndroid Build Coastguard Worker  $(if $(strip $(_dmeta)),\
121*9e94795aSAndroid Build Coastguard Worker    $(if $(filter-out 0p,$(_dep)),\
122*9e94795aSAndroid Build Coastguard Worker      $(if $(filter-out $(_dep) 0p,$(_dmeta)),\
123*9e94795aSAndroid Build Coastguard Worker        $(error cannot copy target from multiple modules: $(1) from $(_dep) and $(_dmeta)),\
124*9e94795aSAndroid Build Coastguard Worker        $(if $(filter 0p,$(_dep)),$(eval _dep:=$(_dmeta)))),\
125*9e94795aSAndroid Build Coastguard Worker      $(eval _dep:=$(_dmeta))\
126*9e94795aSAndroid Build Coastguard Worker    ),\
127*9e94795aSAndroid Build Coastguard Worker    $(eval TARGETS_MISSING_LICENSE_METADATA += $(s) $(1)))))
128*9e94795aSAndroid Build Coastguard Worker
129*9e94795aSAndroid Build Coastguard Worker
130*9e94795aSAndroid Build Coastguard Workerifeq (0p,$(strip $(_dep)))
131*9e94795aSAndroid Build Coastguard Worker# Not copyrightable. No emcumbrances, no license text, no license kind etc.
132*9e94795aSAndroid Build Coastguard Worker$(_meta): PRIVATE_CONDITIONS := unencumbered
133*9e94795aSAndroid Build Coastguard Worker$(_meta): PRIVATE_SOURCES := $(3)
134*9e94795aSAndroid Build Coastguard Worker$(_meta): PRIVATE_INSTALLED := $(1)
135*9e94795aSAndroid Build Coastguard Worker# use `$(1)` which is the unique and relatively short `out/dist/$(target)`
136*9e94795aSAndroid Build Coastguard Worker$(_meta): PRIVATE_ARGUMENT_FILE := $(call intermediates-dir-for,METAPACKAGING,notice)/$(1)/arguments
137*9e94795aSAndroid Build Coastguard Worker$(_meta): $(BUILD_LICENSE_METADATA)
138*9e94795aSAndroid Build Coastguard Worker$(_meta) :
139*9e94795aSAndroid Build Coastguard Worker	rm -f $$@
140*9e94795aSAndroid Build Coastguard Worker	mkdir -p $$(dir $$@)
141*9e94795aSAndroid Build Coastguard Worker	mkdir -p $$(dir $$(PRIVATE_ARGUMENT_FILE))
142*9e94795aSAndroid Build Coastguard Worker	$$(call dump-words-to-file,\
143*9e94795aSAndroid Build Coastguard Worker	    $$(addprefix -c ,$$(PRIVATE_CONDITIONS))\
144*9e94795aSAndroid Build Coastguard Worker	    $$(addprefix -s ,$$(PRIVATE_SOURCES))\
145*9e94795aSAndroid Build Coastguard Worker	    $$(addprefix -t ,$$(PRIVATE_TARGETS))\
146*9e94795aSAndroid Build Coastguard Worker	    $$(addprefix -i ,$$(PRIVATE_INSTALLED)),\
147*9e94795aSAndroid Build Coastguard Worker	    $$(PRIVATE_ARGUMENT_FILE))
148*9e94795aSAndroid Build Coastguard Worker	OUT_DIR=$(OUT_DIR) $(BUILD_LICENSE_METADATA) \
149*9e94795aSAndroid Build Coastguard Worker	  @$$(PRIVATE_ARGUMENT_FILE) \
150*9e94795aSAndroid Build Coastguard Worker	  -o $$@
151*9e94795aSAndroid Build Coastguard Worker
152*9e94795aSAndroid Build Coastguard Workerelse ifneq (,$(strip $(_dep)))
153*9e94795aSAndroid Build Coastguard Worker# Not a missing target, copy metadata and `is_container` etc. from license metadata file `$(_dep)`
154*9e94795aSAndroid Build Coastguard Worker$(_meta): PRIVATE_DEST_TARGET := $(1)
155*9e94795aSAndroid Build Coastguard Worker$(_meta): PRIVATE_SOURCE_TARGETS := $(3)
156*9e94795aSAndroid Build Coastguard Worker$(_meta): PRIVATE_SOURCE_METADATA := $(_dep)
157*9e94795aSAndroid Build Coastguard Worker# use `$(1)` which is the unique and relatively short `out/dist/$(target)`
158*9e94795aSAndroid Build Coastguard Worker$(_meta): PRIVATE_ARGUMENT_FILE := $(call intermediates-dir-for,METAPACKAGING,copynotice)/$(1)/arguments
159*9e94795aSAndroid Build Coastguard Worker$(_meta) : $(_dep) $(COPY_LICENSE_METADATA)
160*9e94795aSAndroid Build Coastguard Worker	rm -f $$@
161*9e94795aSAndroid Build Coastguard Worker	mkdir -p $$(dir $$@)
162*9e94795aSAndroid Build Coastguard Worker	mkdir -p $$(dir $$(PRIVATE_ARGUMENT_FILE))
163*9e94795aSAndroid Build Coastguard Worker	$$(call dump-words-to-file,\
164*9e94795aSAndroid Build Coastguard Worker	    $$(addprefix -i ,$$(PRIVATE_DEST_TARGET))\
165*9e94795aSAndroid Build Coastguard Worker	    $$(addprefix -s ,$$(PRIVATE_SOURCE_TARGETS))\
166*9e94795aSAndroid Build Coastguard Worker	    $$(addprefix -d ,$$(PRIVATE_SOURCE_METADATA)),\
167*9e94795aSAndroid Build Coastguard Worker	    $$(PRIVATE_ARGUMENT_FILE))
168*9e94795aSAndroid Build Coastguard Worker	OUT_DIR=$(OUT_DIR) $(COPY_LICENSE_METADATA) \
169*9e94795aSAndroid Build Coastguard Worker	  @$$(PRIVATE_ARGUMENT_FILE) \
170*9e94795aSAndroid Build Coastguard Worker	  -o $$@
171*9e94795aSAndroid Build Coastguard Worker
172*9e94795aSAndroid Build Coastguard Workerendif
173*9e94795aSAndroid Build Coastguard Workerendef
174*9e94795aSAndroid Build Coastguard Worker
175*9e94795aSAndroid Build Coastguard Worker# use `out/dist/` as a proxy for 'DIST_DIR'
176*9e94795aSAndroid Build Coastguard Workerdefine _add_projects_to_share
177*9e94795aSAndroid Build Coastguard Worker$(strip $(eval _mdir := $(call intermediates-dir-for,METAPACKAGING,meta)/out/dist)) \
178*9e94795aSAndroid Build Coastguard Worker$(strip $(eval _idir := $(call intermediates-dir-for,METAPACKAGING,shareprojects))) \
179*9e94795aSAndroid Build Coastguard Worker$(strip $(eval _tdir := $(call intermediates-dir-for,METAPACKAGING,licensetexts))) \
180*9e94795aSAndroid Build Coastguard Worker$(strip $(eval _allt := $(sort $(foreach goal,$(_all_dist_goal_output_pairs),$(call word-colon,2,$(goal)))))) \
181*9e94795aSAndroid Build Coastguard Worker$(foreach target,$(_allt), \
182*9e94795aSAndroid Build Coastguard Worker  $(eval _goals := $(sort $(foreach dg,$(filter %:$(target),$(_all_dist_goal_output_pairs)),$(call word-colon,1,$(dg))))) \
183*9e94795aSAndroid Build Coastguard Worker  $(eval _srcs := $(sort $(foreach sdp,$(filter %:$(target),$(_all_dist_src_dst_pairs)),$(call word-colon,1,$(sdp))))) \
184*9e94795aSAndroid Build Coastguard Worker  $(eval $(call _dist-target-license-metadata-rule,out/dist/$(target),$(_mdir)/out/dist/$(target).meta_lic,$(_srcs))) \
185*9e94795aSAndroid Build Coastguard Worker  $(eval _f := $(_idir)/$(target).shareprojects) \
186*9e94795aSAndroid Build Coastguard Worker  $(eval _n := $(_tdir)/$(target).txt) \
187*9e94795aSAndroid Build Coastguard Worker  $(eval $(call dist-for-goals,$(_goals),$(_f):shareprojects/$(target).shareprojects)) \
188*9e94795aSAndroid Build Coastguard Worker  $(eval $(call dist-for-goals,$(_goals),$(_n):licensetexts/$(target).txt)) \
189*9e94795aSAndroid Build Coastguard Worker  $(eval $(call _share-projects-rule,$(_f),$(foreach t, $(filter-out $(TARGETS_MISSING_LICENSE_METADATA),out/dist/$(target)),$(_mdir)/$(t).meta_lic))) \
190*9e94795aSAndroid Build Coastguard Worker  $(eval $(call _license-texts-rule,$(_goals),$(_n),$(foreach t,$(filter-out $(TARGETS_MISSING_LICENSE_METADATA),out/dist/$(target)),$(_mdir)/$(t).meta_lic))) \
191*9e94795aSAndroid Build Coastguard Worker)
192*9e94795aSAndroid Build Coastguard Workerendef
193*9e94795aSAndroid Build Coastguard Worker
194*9e94795aSAndroid Build Coastguard Worker#------------------------------------------------------------------
195*9e94795aSAndroid Build Coastguard Worker# To be used at the end of the build to collect all the uses of
196*9e94795aSAndroid Build Coastguard Worker# dist-for-goals, and write them into a file for the packaging step to use.
197*9e94795aSAndroid Build Coastguard Worker
198*9e94795aSAndroid Build Coastguard Worker# $(1): The file to write
199*9e94795aSAndroid Build Coastguard Workerdefine dist-write-file
200*9e94795aSAndroid Build Coastguard Worker$(strip \
201*9e94795aSAndroid Build Coastguard Worker  $(call _add_projects_to_share)\
202*9e94795aSAndroid Build Coastguard Worker  $(if $(strip $(ANDROID_REQUIRE_LICENSE_METADATA)),\
203*9e94795aSAndroid Build Coastguard Worker    $(foreach target,$(sort $(TARGETS_MISSING_LICENSE_METADATA)),$(warning target $(target) missing license metadata))\
204*9e94795aSAndroid Build Coastguard Worker    $(if $(strip $(TARGETS_MISSING_LICENSE_METADATA)),\
205*9e94795aSAndroid Build Coastguard Worker      $(if $(filter true error,$(ANDROID_REQUIRE_LICENSE_METADATA)),\
206*9e94795aSAndroid Build Coastguard Worker        $(error $(words $(sort $(TARGETS_MISSING_LICENSE_METADATA))) targets need license metadata))))\
207*9e94795aSAndroid Build Coastguard Worker  $(foreach t,$(sort $(ALL_NON_MODULES)),$(call record-missing-non-module-dependencies,$(t))) \
208*9e94795aSAndroid Build Coastguard Worker  $(eval $(call report-missing-licenses-rule)) \
209*9e94795aSAndroid Build Coastguard Worker  $(eval $(call report-all-notice-library-names-rule)) \
210*9e94795aSAndroid Build Coastguard Worker  $(KATI_obsolete_var dist-for-goals,Cannot be used after dist-write-file) \
211*9e94795aSAndroid Build Coastguard Worker  $(foreach goal,$(sort $(_all_dist_goals)), \
212*9e94795aSAndroid Build Coastguard Worker    $(eval $$(goal): _dist_$$(goal))) \
213*9e94795aSAndroid Build Coastguard Worker  $(shell mkdir -p $(dir $(1))) \
214*9e94795aSAndroid Build Coastguard Worker  $(file >$(1).tmp, \
215*9e94795aSAndroid Build Coastguard Worker    DIST_GOAL_OUTPUT_PAIRS := $(sort $(_all_dist_goal_output_pairs)) \
216*9e94795aSAndroid Build Coastguard Worker    $(newline)DIST_SRC_DST_PAIRS := $(sort $(_all_dist_src_dst_pairs))) \
217*9e94795aSAndroid Build Coastguard Worker  $(shell if ! cmp -s $(1).tmp $(1); then \
218*9e94795aSAndroid Build Coastguard Worker            mv $(1).tmp $(1); \
219*9e94795aSAndroid Build Coastguard Worker          else \
220*9e94795aSAndroid Build Coastguard Worker            rm $(1).tmp; \
221*9e94795aSAndroid Build Coastguard Worker          fi))
222*9e94795aSAndroid Build Coastguard Workerendef
223*9e94795aSAndroid Build Coastguard Worker
224*9e94795aSAndroid Build Coastguard Worker.KATI_READONLY := dist-for-goals dist-write-file dist-for-goals-with-filenametag
225