• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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# Extras are now located in addon.xml, not in repository.xml.
117$(eval $(call mk-sdk-repo-pkg-3,SDK_EXTRAS_XML_ARGS,$(HOST_OS),$(MAIN_SDK_ZIP),support,extras/android))
118
119SDK_EXTRAS_DEPS += \
120    $(call sdk-repo-pkg-zip,$(HOST_OS),$(MAIN_SDK_ZIP),support)
121
122# Similarly capture all sys-img.xml that are now split out of repository.xml
123$(eval $(call mk-sdk-repo-pkg-3,SDK_SYSIMG_XML_ARGS,$(HOST_OS),$(MAIN_SDK_ZIP),system-images,system-images/*))
124
125SDK_SYSIMG_DEPS += \
126    $(call sdk-repo-pkg-zip,$(HOST_OS),$(MAIN_SDK_ZIP),system-images) \
127
128# All these go in the main repository.xml
129$(eval $(call mk-sdk-repo-pkg-2,SDK_REPO_XML_ARGS,$(HOST_OS),$(MAIN_SDK_ZIP),build-tools))
130$(eval $(call mk-sdk-repo-pkg-1,SDK_REPO_XML_ARGS,$(HOST_OS),$(MAIN_SDK_ZIP),platform-tools))
131$(eval $(call mk-sdk-repo-pkg-1,SDK_REPO_XML_ARGS,$(HOST_OS),$(MAIN_SDK_ZIP),docs))
132$(eval $(call mk-sdk-repo-pkg-2,SDK_REPO_XML_ARGS,$(HOST_OS),$(MAIN_SDK_ZIP),platforms))
133$(eval $(call mk-sdk-repo-pkg-2,SDK_REPO_XML_ARGS,$(HOST_OS),$(MAIN_SDK_ZIP),samples))
134$(eval $(call mk-sdk-repo-sources,SDK_REPO_XML_ARGS,$(HOST_OS),$(MAIN_SDK_ZIP),sources))
135
136SDK_REPO_DEPS += \
137    $(call sdk-repo-pkg-zip,$(HOST_OS),$(MAIN_SDK_ZIP),build-tools) \
138    $(call sdk-repo-pkg-zip,$(HOST_OS),$(MAIN_SDK_ZIP),platform-tools) \
139    $(call sdk-repo-pkg-zip,$(HOST_OS),$(MAIN_SDK_ZIP),docs) \
140    $(call sdk-repo-pkg-zip,$(HOST_OS),$(MAIN_SDK_ZIP),platforms) \
141    $(call sdk-repo-pkg-zip,$(HOST_OS),$(MAIN_SDK_ZIP),samples) \
142    $(call sdk-repo-pkg-zip,$(HOST_OS),$(MAIN_SDK_ZIP),sources)
143
144endif
145
146# -----------------------------------------------------------------
147# Rules for win_sdk
148
149ifneq ($(WIN_SDK_ZIP),)
150
151# docs, platforms and samples have nothing OS-dependent right now.
152$(eval $(call mk-sdk-repo-pkg-2,SDK_REPO_XML_ARGS,windows,$(WIN_SDK_ZIP),build-tools))
153$(eval $(call mk-sdk-repo-pkg-1,SDK_REPO_XML_ARGS,windows,$(WIN_SDK_ZIP),platform-tools))
154
155SDK_REPO_DEPS += \
156    $(call sdk-repo-pkg-zip,windows,$(WIN_SDK_ZIP),build-tools) \
157    $(call sdk-repo-pkg-zip,windows,$(WIN_SDK_ZIP),platform-tools)
158
159endif
160
161# -----------------------------------------------------------------
162# Pickup the most recent xml schema for repository and add-on
163
164SDK_REPO_XSD := \
165    $(lastword \
166      $(wildcard \
167        $(TOPDIR)prebuilts/devtools/repository/sdk-repository-*.xsd \
168    ))
169
170SDK_ADDON_XSD := \
171    $(lastword \
172      $(wildcard \
173        $(TOPDIR)prebuilts/devtools/repository/sdk-addon-*.xsd \
174    ))
175
176SDK_SYSIMG_XSD := \
177    $(lastword \
178      $(wildcard \
179        $(TOPDIR)prebuilts/devtools/repository/sdk-sys-img-*.xsd \
180    ))
181
182
183# -----------------------------------------------------------------
184# Rules for sdk addon
185
186ifneq ($(filter sdk_addon,$(MAKECMDGOALS)),)
187ifneq ($(ADDON_SDK_ZIP),)
188
189# ADDON_SDK_ZIP is defined in build/core/tasks/sdk-addon.sh and is
190# already packaged correctly. All we have to do is dist it with
191# a different destination name.
192
193RENAMED_ADDON_ZIP := $(ADDON_SDK_ZIP):$(notdir $(call sdk-repo-pkg-zip,$(HOST_OS),$(ADDON_SDK_ZIP),addon))
194
195$(call dist-for-goals, sdk_repo, $(RENAMED_ADDON_ZIP))
196
197# Also generate the addon.xml using the latest schema and the renamed addon zip
198
199SDK_ADDON_XML := $(dir $(ADDON_SDK_ZIP))/addon.xml
200
201$(SDK_ADDON_XML): $(ADDON_SDK_ZIP)
202	$(hide) $(TOPDIR)development/build/tools/mk_sdk_repo_xml.sh \
203	            $(SDK_ADDON_XML) $(SDK_ADDON_XSD) add-on $(HOST_OS) $(RENAMED_ADDON_ZIP)
204
205$(call dist-for-goals, sdk_repo, $(SDK_ADDON_XML))
206
207endif
208
209ifneq ($(ADDON_SDK_IMG_ZIP),)
210
211# Copy/rename the ADDON_SDK_IMG_ZIP file as an sdk-repo zip in the dist dir
212
213RENAMED_ADDON_IMG_ZIP := $(ADDON_SDK_IMG_ZIP):$(notdir $(call sdk-repo-pkg-zip,$(HOST_OS),$(ADDON_SDK_IMG_ZIP),system-images))
214
215$(call dist-for-goals, sdk_repo, $(RENAMED_ADDON_IMG_ZIP))
216
217# Generate the system-image XML for the addon sys-img
218
219SDK_ADDON_IMG_XML := $(dir $(ADDON_SDK_ZIP))/addon-sys-img.xml
220
221$(SDK_ADDON_IMG_XML): $(ADDON_SDK_IMG_ZIP)
222	$(hide) $(TOPDIR)development/build/tools/mk_sdk_repo_xml.sh \
223	            $(SDK_ADDON_IMG_XML) $(SDK_SYSIMG_XSD) system-image $(HOST_OS) $(RENAMED_ADDON_IMG_ZIP)
224
225$(call dist-for-goals, sdk_repo, $(SDK_ADDON_IMG_XML))
226
227endif
228endif
229
230# -----------------------------------------------------------------
231# Rules for the SDK Repository XML
232
233SDK_REPO_XML   := $(MAIN_SDK_DIR)/repository.xml
234SDK_EXTRAS_XML := $(MAIN_SDK_DIR)/repo-extras.xml
235SDK_SYSIMG_XML := $(MAIN_SDK_DIR)/repo-sys-img.xml
236
237ifneq ($(SDK_REPO_XML_ARGS),)
238
239$(SDK_REPO_XML): $(SDK_REPO_DEPS)
240	$(hide) $(TOPDIR)development/build/tools/mk_sdk_repo_xml.sh \
241	            $(SDK_REPO_XML) $(SDK_REPO_XSD) $(SDK_REPO_XML_ARGS)
242
243$(call dist-for-goals, sdk_repo, $(SDK_REPO_XML))
244
245else
246
247$(SDK_REPO_XML): ;
248
249endif
250
251
252ifneq ($(SDK_EXTRAS_XML_ARGS),)
253
254$(SDK_EXTRAS_XML): $(SDK_EXTRAS_DEPS)
255	$(hide) $(TOPDIR)development/build/tools/mk_sdk_repo_xml.sh \
256	            $(SDK_EXTRAS_XML) $(SDK_ADDON_XSD) $(SDK_EXTRAS_XML_ARGS)
257
258$(call dist-for-goals, sdk_repo, $(SDK_EXTRAS_XML))
259
260else
261
262$(SDK_EXTRAS_XML): ;
263
264endif
265
266
267ifneq ($(SDK_SYSIMG_XML_ARGS),)
268
269$(SDK_SYSIMG_XML): $(SDK_SYSIMG_DEPS)
270	$(hide) $(TOPDIR)development/build/tools/mk_sdk_repo_xml.sh \
271	            $(SDK_SYSIMG_XML) $(SDK_SYSIMG_XSD) $(SDK_SYSIMG_XML_ARGS)
272
273$(call dist-for-goals, sdk_repo, $(SDK_SYSIMG_XML))
274
275else
276
277$(SDK_SYSIMG_XML): ;
278
279endif
280
281# -----------------------------------------------------------------
282
283sdk_repo: $(SDK_REPO_DEPS) $(SDK_REPO_XML) $(SDK_EXTRAS_XML) $(SDK_SYSIMG_XML)
284	@echo "Packing of SDK repository done"
285
286