Home | History | Annotate | Download | only in tools
      1 # Makefile to build the SDK repository packages.
      2 
      3 .PHONY: sdk_repo
      4 
      5 SDK_REPO_DEPS       :=
      6 SDK_REPO_XML_ARGS   :=
      7 SDK_EXTRAS_DEPS     :=
      8 SDK_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 #
     15 define sdk-repo-pkg-zip
     16 $(dir $(2))/sdk-repo-$(1)-$(3)-$(FILE_NAME_TAG).zip
     17 endef
     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 #
     31 define 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)))
     40 endef
     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 #
     54 define 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)))
     63 endef
     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 #
     81 define 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)))
     90 endef
     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 #
     99 define 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)))
    109 endef
    110 
    111 # -----------------------------------------------------------------
    112 # Rules for main host sdk
    113 
    114 ifneq ($(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 
    119 SDK_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 
    125 SDK_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 
    136 SDK_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 
    144 endif
    145 
    146 # -----------------------------------------------------------------
    147 # Rules for win_sdk
    148 
    149 ifneq ($(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 
    155 SDK_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 
    159 endif
    160 
    161 # -----------------------------------------------------------------
    162 # Pickup the most recent xml schema for repository and add-on
    163 
    164 SDK_REPO_XSD := \
    165     $(lastword \
    166       $(wildcard \
    167         $(TOPDIR)prebuilts/devtools/repository/sdk-repository-*.xsd \
    168     ))
    169 
    170 SDK_ADDON_XSD := \
    171     $(lastword \
    172       $(wildcard \
    173         $(TOPDIR)prebuilts/devtools/repository/sdk-addon-*.xsd \
    174     ))
    175 
    176 SDK_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 
    186 ifneq ($(filter sdk_addon,$(MAKECMDGOALS)),)
    187 ifneq ($(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 
    193 RENAMED_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 
    199 SDK_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 
    207 endif
    208 
    209 ifneq ($(ADDON_SDK_IMG_ZIP),)
    210 
    211 # Copy/rename the ADDON_SDK_IMG_ZIP file as an sdk-repo zip in the dist dir
    212 
    213 RENAMED_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 
    219 SDK_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 
    227 endif
    228 endif
    229 
    230 # -----------------------------------------------------------------
    231 # Rules for the SDK Repository XML
    232 
    233 SDK_REPO_XML   := $(MAIN_SDK_DIR)/repository.xml
    234 SDK_EXTRAS_XML := $(MAIN_SDK_DIR)/repo-extras.xml
    235 SDK_SYSIMG_XML := $(MAIN_SDK_DIR)/repo-sys-img.xml
    236 
    237 ifneq ($(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 
    245 else
    246 
    247 $(SDK_REPO_XML): ;
    248 
    249 endif
    250 
    251 
    252 ifneq ($(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 
    260 else
    261 
    262 $(SDK_EXTRAS_XML): ;
    263 
    264 endif
    265 
    266 
    267 ifneq ($(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 
    275 else
    276 
    277 $(SDK_SYSIMG_XML): ;
    278 
    279 endif
    280 
    281 # -----------------------------------------------------------------
    282 
    283 sdk_repo: $(SDK_REPO_DEPS) $(SDK_REPO_XML) $(SDK_EXTRAS_XML) $(SDK_SYSIMG_XML)
    284 	@echo "Packing of SDK repository done"
    285 
    286