1# Makefile to build the SDK repository packages.
2
3.PHONY: sdk_repo
4
5SDK_REPO_DEPS       :=
6SDK_REPO_XML_ARGS   :=
7SDK_EXTRAS_DEPS     :=
8SDK_EXTRAS_XML_ARGS :=
9
10# Define the name of a package zip file to generate
11# $1=OS (e.g. linux-x86, windows, etc)
12# $2=sdk zip (e.g. out/host/linux.../android-eng-sdk.zip)
13# $3=package to create (e.g. tools, docs, etc.)
14#
15define sdk-repo-pkg-zip
16$(dir $(2))/sdk-repo-$(1)-$(3)-$(FILE_NAME_TAG).zip
17endef
18
19# Defines the rule to build an SDK repository package by zipping all
20# the content of the given directory.
21# E.g. given a folder out/host/linux.../sdk/android-eng-sdk/tools
22# this generates an sdk-repo-linux-tools that contains tools/*
23#
24# $1=variable where to accumulate args for mk_sdk_repo_xml.
25# $2=OS (e.g. linux-x86, windows, etc)
26# $3=sdk zip (e.g. out/host/linux.../android-eng-sdk.zip)
27# $4=package to create (e.g. tools, docs, etc.)
28#
29# The rule depends on the SDK zip file, which is defined by $2.
30#
31define mk-sdk-repo-pkg-1
32$(call sdk-repo-pkg-zip,$(2),$(3),$(4)): $(3)
33	@echo "Building SDK repository package $(4) from $(notdir $(3))"
34	$(hide) cd $(basename $(3)) && \
35	        rm  -f   ../$(notdir $(call sdk-repo-pkg-zip,$(2),$(3),$(4))) && \
36	        zip -9rq ../$(notdir $(call sdk-repo-pkg-zip,$(2),$(3),$(4))) $(4)/*
37$(call dist-for-goals, sdk_repo, $(call sdk-repo-pkg-zip,$(2),$(3),$(4)))
38$(1) += $(4) $(2) \
39    $(call sdk-repo-pkg-zip,$(2),$(3),$(4)):$(notdir $(call sdk-repo-pkg-zip,$(2),$(3),$(4)))
40endef
41
42# Defines the rule to build an SDK repository package when the
43# package directory contains a single platform-related inner directory.
44# E.g. given a folder out/host/linux.../sdk/android-eng-sdk/samples/android-N
45# this generates an sdk-repo-linux-samples that contains android-N/*
46#
47# $1=variable where to accumulate args for mk_sdk_repo_xml.
48# $2=OS (e.g. linux-x86, windows, etc)
49# $3=sdk zip (e.g. out/host/linux.../android-eng-sdk.zip)
50# $4=package to create (e.g. platforms, samples, etc.)
51#
52# The rule depends on the SDK zip file, which is defined by $2.
53#
54define mk-sdk-repo-pkg-2
55$(call sdk-repo-pkg-zip,$(2),$(3),$(4)): $(3)
56	@echo "Building SDK repository package $(4) from $(notdir $(3))"
57	$(hide) cd $(basename $(3))/$(4) && \
58	        rm  -f   ../../$(notdir $(call sdk-repo-pkg-zip,$(2),$(3),$(4))) && \
59	        zip -9rq ../../$(notdir $(call sdk-repo-pkg-zip,$(2),$(3),$(4))) *
60$(call dist-for-goals, sdk_repo, $(call sdk-repo-pkg-zip,$(2),$(3),$(4)))
61$(1) += $(4) $(2) \
62    $(call sdk-repo-pkg-zip,$(2),$(3),$(4)):$(notdir $(call sdk-repo-pkg-zip,$(2),$(3),$(4)))
63endef
64
65# Defines the rule to build an SDK repository package when the
66# package directory contains 3 levels from the sdk dir, for example
67# to package SDK/extra/android/support or SDK/system-images/android-N/armeabi.
68# Because we do not know the intermediary directory name, this only works
69# if each directory contains a single sub-directory (e.g. sdk/$4/*/* must be
70# unique.)
71#
72# $1=variable where to accumulate args for mk_sdk_repo_xml.
73# $2=OS (e.g. linux-x86, windows, etc)
74# $3=sdk zip (e.g. out/host/linux.../android-eng-sdk.zip)
75# $4=package to create (e.g. system-images, support, etc.)
76# $5=the root of directory to package in the sdk (e.g. extra/android).
77#    this must be a 2-segment path, the last one can be *.
78#
79# The rule depends on the SDK zip file, which is defined by $2.
80#
81define mk-sdk-repo-pkg-3
82$(call sdk-repo-pkg-zip,$(2),$(3),$(4)): $(3)
83	@echo "Building SDK repository package $(4) from $(notdir $(3))"
84	$(hide) cd $(basename $(3))/$(5) && \
85	        rm  -f   ../../../$(notdir $(call sdk-repo-pkg-zip,$(2),$(3),$(4))) && \
86	        zip -9rq ../../../$(notdir $(call sdk-repo-pkg-zip,$(2),$(3),$(4))) *
87$(call dist-for-goals, sdk_repo, $(call sdk-repo-pkg-zip,$(2),$(3),$(4)))
88$(1) += $(4) $(2) \
89    $(call sdk-repo-pkg-zip,$(2),$(3),$(4)):$(notdir $(call sdk-repo-pkg-zip,$(2),$(3),$(4)))
90endef
91
92# Defines the rule to build an SDK sources package.
93#
94# $1=variable where to accumulate args for mk_sdk_repo_xml.
95# $2=OS (e.g. linux-x86, windows, etc)
96# $3=sdk zip (e.g. out/host/linux.../android-eng-sdk.zip)
97# $4=package to create, must be "sources"
98#
99define mk-sdk-repo-sources
100$(call sdk-repo-pkg-zip,$(2),$(3),$(4)): $(3) $(HOST_OUT)/development/sdk/source_source.properties
101	@echo "Building SDK sources package"
102	$(hide) $(TOPDIR)development/build/tools/mk_sources_zip.py --exec-zip \
103	            $(HOST_OUT)/development/sdk/source_source.properties \
104	            $(call sdk-repo-pkg-zip,$(2),$(3),$(4)) \
105	            $(TOPDIR).
106$(call dist-for-goals, sdk_repo, $(call sdk-repo-pkg-zip,$(2),$(3),$(4)))
107$(1) += $(4) $(2) \
108    $(call sdk-repo-pkg-zip,$(2),$(3),$(4)):$(notdir $(call sdk-repo-pkg-zip,$(2),$(3),$(4)))
109endef
110
111# -----------------------------------------------------------------
112# Rules for main host sdk
113
114ifneq ($(filter sdk win_sdk,$(MAKECMDGOALS)),)
115
116# Similarly capture all sys-img.xml that are now split out of repository.xml
117$(eval $(call mk-sdk-repo-pkg-3,SDK_SYSIMG_XML_ARGS,$(HOST_OS),$(MAIN_SDK_ZIP),system-images,system-images/*))
118
119SDK_SYSIMG_DEPS += \
120    $(call sdk-repo-pkg-zip,$(HOST_OS),$(MAIN_SDK_ZIP),system-images) \
121
122# All these go in the main repository.xml
123$(eval $(call mk-sdk-repo-pkg-2,SDK_REPO_XML_ARGS,$(HOST_OS),$(MAIN_SDK_ZIP),build-tools))
124$(eval $(call mk-sdk-repo-pkg-1,SDK_REPO_XML_ARGS,$(HOST_OS),$(MAIN_SDK_ZIP),platform-tools))
125$(eval $(call mk-sdk-repo-pkg-1,SDK_REPO_XML_ARGS,$(HOST_OS),$(MAIN_SDK_ZIP),docs))
126$(eval $(call mk-sdk-repo-pkg-2,SDK_REPO_XML_ARGS,$(HOST_OS),$(MAIN_SDK_ZIP),platforms))
127$(eval $(call mk-sdk-repo-pkg-2,SDK_REPO_XML_ARGS,$(HOST_OS),$(MAIN_SDK_ZIP),samples))
128$(eval $(call mk-sdk-repo-sources,SDK_REPO_XML_ARGS,$(HOST_OS),$(MAIN_SDK_ZIP),sources))
129
130SDK_REPO_DEPS += \
131    $(call sdk-repo-pkg-zip,$(HOST_OS),$(MAIN_SDK_ZIP),build-tools) \
132    $(call sdk-repo-pkg-zip,$(HOST_OS),$(MAIN_SDK_ZIP),platform-tools) \
133    $(call sdk-repo-pkg-zip,$(HOST_OS),$(MAIN_SDK_ZIP),docs) \
134    $(call sdk-repo-pkg-zip,$(HOST_OS),$(MAIN_SDK_ZIP),platforms) \
135    $(call sdk-repo-pkg-zip,$(HOST_OS),$(MAIN_SDK_ZIP),samples) \
136    $(call sdk-repo-pkg-zip,$(HOST_OS),$(MAIN_SDK_ZIP),sources)
137
138endif
139
140# -----------------------------------------------------------------
141# Rules for win_sdk
142
143ifneq ($(WIN_SDK_ZIP),)
144
145# docs, platforms and samples have nothing OS-dependent right now.
146$(eval $(call mk-sdk-repo-pkg-2,SDK_REPO_XML_ARGS,windows,$(WIN_SDK_ZIP),build-tools))
147$(eval $(call mk-sdk-repo-pkg-1,SDK_REPO_XML_ARGS,windows,$(WIN_SDK_ZIP),platform-tools))
148
149SDK_REPO_DEPS += \
150    $(call sdk-repo-pkg-zip,windows,$(WIN_SDK_ZIP),build-tools) \
151    $(call sdk-repo-pkg-zip,windows,$(WIN_SDK_ZIP),platform-tools)
152
153endif
154
155# -----------------------------------------------------------------
156# Pickup the most recent xml schema for repository and add-on
157
158SDK_REPO_XSD := \
159    $(lastword \
160      $(wildcard \
161        $(TOPDIR)prebuilts/devtools/repository/sdk-repository-*.xsd \
162    ))
163
164SDK_ADDON_XSD := \
165    $(lastword \
166      $(wildcard \
167        $(TOPDIR)prebuilts/devtools/repository/sdk-addon-*.xsd \
168    ))
169
170SDK_SYSIMG_XSD := \
171    $(lastword \
172      $(wildcard \
173        $(TOPDIR)prebuilts/devtools/repository/sdk-sys-img-*.xsd \
174    ))
175
176
177# -----------------------------------------------------------------
178# Rules for sdk addon
179
180ifneq ($(filter sdk_addon,$(MAKECMDGOALS)),)
181ifneq ($(ADDON_SDK_ZIP),)
182
183# ADDON_SDK_ZIP is defined in build/core/tasks/sdk-addon.sh and is
184# already packaged correctly. All we have to do is dist it with
185# a different destination name.
186
187RENAMED_ADDON_ZIP := $(ADDON_SDK_ZIP):$(notdir $(call sdk-repo-pkg-zip,$(HOST_OS),$(ADDON_SDK_ZIP),addon))
188
189$(call dist-for-goals, sdk_repo, $(RENAMED_ADDON_ZIP))
190
191# Also generate the addon.xml using the latest schema and the renamed addon zip
192
193SDK_ADDON_XML := $(dir $(ADDON_SDK_ZIP))/addon.xml
194
195$(SDK_ADDON_XML): $(ADDON_SDK_ZIP)
196	$(hide) $(TOPDIR)development/build/tools/mk_sdk_repo_xml.sh \
197	            $(SDK_ADDON_XML) $(SDK_ADDON_XSD) add-on $(HOST_OS) $(RENAMED_ADDON_ZIP)
198
199$(call dist-for-goals, sdk_repo, $(SDK_ADDON_XML))
200
201endif
202
203ifneq ($(ADDON_SDK_IMG_ZIP),)
204
205# Copy/rename the ADDON_SDK_IMG_ZIP file as an sdk-repo zip in the dist dir
206
207RENAMED_ADDON_IMG_ZIP := $(ADDON_SDK_IMG_ZIP):$(notdir $(call sdk-repo-pkg-zip,$(HOST_OS),$(ADDON_SDK_IMG_ZIP),system-images))
208
209$(call dist-for-goals, sdk_repo, $(RENAMED_ADDON_IMG_ZIP))
210
211# Generate the system-image XML for the addon sys-img
212
213SDK_ADDON_IMG_XML := $(dir $(ADDON_SDK_ZIP))/addon-sys-img.xml
214
215$(SDK_ADDON_IMG_XML): $(ADDON_SDK_IMG_ZIP)
216	$(hide) $(TOPDIR)development/build/tools/mk_sdk_repo_xml.sh \
217	            $(SDK_ADDON_IMG_XML) $(SDK_SYSIMG_XSD) system-image $(HOST_OS) $(RENAMED_ADDON_IMG_ZIP)
218
219$(call dist-for-goals, sdk_repo, $(SDK_ADDON_IMG_XML))
220
221endif
222endif
223
224# -----------------------------------------------------------------
225# Rules for the SDK Repository XML
226
227SDK_REPO_XML   := $(MAIN_SDK_DIR)/repository.xml
228SDK_EXTRAS_XML := $(MAIN_SDK_DIR)/repo-extras.xml
229SDK_SYSIMG_XML := $(MAIN_SDK_DIR)/repo-sys-img.xml
230
231ifneq ($(SDK_REPO_XML_ARGS),)
232
233$(SDK_REPO_XML): $(SDK_REPO_DEPS)
234	$(hide) $(TOPDIR)development/build/tools/mk_sdk_repo_xml.sh \
235	            $(SDK_REPO_XML) $(SDK_REPO_XSD) $(SDK_REPO_XML_ARGS)
236
237$(call dist-for-goals, sdk_repo, $(SDK_REPO_XML))
238
239else
240
241$(SDK_REPO_XML): ;
242
243endif
244
245
246ifneq ($(SDK_EXTRAS_XML_ARGS),)
247
248$(SDK_EXTRAS_XML): $(SDK_EXTRAS_DEPS)
249	$(hide) $(TOPDIR)development/build/tools/mk_sdk_repo_xml.sh \
250	            $(SDK_EXTRAS_XML) $(SDK_ADDON_XSD) $(SDK_EXTRAS_XML_ARGS)
251
252$(call dist-for-goals, sdk_repo, $(SDK_EXTRAS_XML))
253
254else
255
256$(SDK_EXTRAS_XML): ;
257
258endif
259
260
261ifneq ($(SDK_SYSIMG_XML_ARGS),)
262
263$(SDK_SYSIMG_XML): $(SDK_SYSIMG_DEPS)
264	$(hide) $(TOPDIR)development/build/tools/mk_sdk_repo_xml.sh \
265	            $(SDK_SYSIMG_XML) $(SDK_SYSIMG_XSD) $(SDK_SYSIMG_XML_ARGS)
266
267$(call dist-for-goals, sdk_repo, $(SDK_SYSIMG_XML))
268
269else
270
271$(SDK_SYSIMG_XML): ;
272
273endif
274
275# -----------------------------------------------------------------
276
277sdk_repo: $(SDK_REPO_DEPS) $(SDK_REPO_XML) $(SDK_EXTRAS_XML) $(SDK_SYSIMG_XML)
278	@echo "Packing of SDK repository done"
279
280