blob: 441363847a6bee02d2228d06b72c96361647d60b [file] [log] [blame]
Ying Wang78e75a92014-06-03 10:40:10 -07001LOCAL_PATH := $(call my-dir)
2
Raphaeld79eab52011-11-15 16:30:14 -08003# ===== SDK source.property files =====
4
5# Add all files to be generated from the source.prop templates to the SDK pre-requisites
Dan Willemsen55a8f532018-06-16 10:41:44 -07006sdk_props := $(patsubst \
7 $(TOPDIR)development/sdk/%_source.prop_template, \
8 $(HOST_OUT)/development/sdk/%_source.properties, \
9 $(wildcard $(TOPDIR)development/sdk/*_source.prop_template))
10sample_props := $(patsubst \
11 $(TOPDIR)development/samples/%_source.prop_template, \
12 $(HOST_OUT)/development/samples/%_source.properties, \
13 $(wildcard $(TOPDIR)development/samples/*_source.prop_template))
14sys_img_props := $(patsubst \
Raphael Moll26bcf6a2014-06-03 10:44:56 -070015 $(TOPDIR)development/sys-img/%_source.prop_template, \
16 $(HOST_OUT)/development/sys-img-$(TARGET_CPU_ABI)/%_source.properties, \
17 $(wildcard $(TOPDIR)development/sys-img/*_source.prop_template))
Dan Willemsen55a8f532018-06-16 10:41:44 -070018ALL_SDK_FILES += $(sdk_props) $(sample_props) $(sys_img_props)
Raphaeld79eab52011-11-15 16:30:14 -080019
20# Rule to convert a source.prop template into the desired source.property
Raphael Moll26bcf6a2014-06-03 10:44:56 -070021# This needs to vary based on the CPU ABI for the system-image files.
Raphaeld79eab52011-11-15 16:30:14 -080022# Rewritten variables:
23# - ${PLATFORM_VERSION} e.g. "1.0"
24# - ${PLATFORM_SDK_VERSION} e.g. "3", aka the API level
25# - ${PLATFORM_VERSION_CODENAME} e.g. "REL" (transformed into "") or "Cupcake"
Raphael Moll26bcf6a2014-06-03 10:44:56 -070026# - ${TARGET_ARCH} e.g. "arm", "x86", "mips" and their 64-bit variants.
27# - ${TARGET_CPU_ABI} e.g. "armeabi", "x86", "mips" and their 64-bit variants.
Dan Willemsen55a8f532018-06-16 10:41:44 -070028$(sys_img_props) : $(HOST_OUT)/development/sys-img-$(TARGET_CPU_ABI)/%_source.properties : $(TOPDIR)development/sys-img/%_source.prop_template
Raphaeld79eab52011-11-15 16:30:14 -080029 @echo Generate $@
30 $(hide) mkdir -p $(dir $@)
Raphael Moll40c71262014-05-16 11:40:45 -070031 $(hide) sed \
32 -e 's/$${PLATFORM_VERSION}/$(PLATFORM_VERSION)/' \
33 -e 's/$${PLATFORM_SDK_VERSION}/$(PLATFORM_SDK_VERSION)/' \
34 -e 's/$${PLATFORM_VERSION_CODENAME}/$(subst REL,,$(PLATFORM_VERSION_CODENAME))/' \
35 -e 's/$${TARGET_ARCH}/$(TARGET_ARCH)/' \
36 -e 's/$${TARGET_CPU_ABI}/$(TARGET_CPU_ABI)/' \
37 $< > $@ && sed -i -e '/^AndroidVersion.CodeName=\s*$$/d' $@
Raphaeld79eab52011-11-15 16:30:14 -080038
Dan Willemsen55a8f532018-06-16 10:41:44 -070039$(sdk_props) : $(HOST_OUT)/development/sdk/%_source.properties : $(TOPDIR)development/sdk/%_source.prop_template
Raphael Moll26bcf6a2014-06-03 10:44:56 -070040 @echo Generate $@
41 $(hide) mkdir -p $(dir $@)
42 $(hide) sed \
43 -e 's/$${PLATFORM_VERSION}/$(PLATFORM_VERSION)/' \
44 -e 's/$${PLATFORM_SDK_VERSION}/$(PLATFORM_SDK_VERSION)/' \
45 -e 's/$${PLATFORM_VERSION_CODENAME}/$(subst REL,,$(PLATFORM_VERSION_CODENAME))/' \
46 $< > $@ && sed -i -e '/^AndroidVersion.CodeName=\s*$$/d' $@
47
Dan Willemsen55a8f532018-06-16 10:41:44 -070048$(sample_props) : $(HOST_OUT)/development/samples/%_source.properties : $(TOPDIR)development/samples/%_source.prop_template
Xavier Ducrohetbea50d32012-02-15 18:31:46 -080049 @echo Generate $@
50 $(hide) mkdir -p $(dir $@)
Raphael Moll40c71262014-05-16 11:40:45 -070051 $(hide) sed\
52 -e 's/$${PLATFORM_VERSION}/$(PLATFORM_VERSION)/' \
53 -e 's/$${PLATFORM_SDK_VERSION}/$(PLATFORM_SDK_VERSION)/' \
54 -e 's/$${PLATFORM_VERSION_CODENAME}/$(subst REL,,$(PLATFORM_VERSION_CODENAME))/' \
55 $< > $@ && sed -i -e '/^AndroidVersion.CodeName=\s*$$/d' $@
Xavier Ducrohetbea50d32012-02-15 18:31:46 -080056
Raphaeld79eab52011-11-15 16:30:14 -080057
Ying Wang78e75a92014-06-03 10:40:10 -070058# ===== SDK jar file of stubs =====
59# A.k.a the "current" version of the public SDK (android.jar inside the SDK package).
Nan Zhang1c7b1a12018-02-28 16:28:17 -080060full_target := $(call intermediates-dir-for,JAVA_LIBRARIES,android_stubs_current,,COMMON)/classes.jar
Anton Hansson1ed8eb82020-11-05 21:08:45 +000061full_src_target := $(call intermediates-dir-for,ETC,frameworks-base-api-current.srcjar)/frameworks-base-api-current.srcjar
The Android Open Source Project52d4c302009-03-03 19:29:09 -080062
Ying Wang78e75a92014-06-03 10:40:10 -070063# android.jar is what we put in the SDK package.
Colin Cross89c55172019-11-04 14:52:47 -080064android_jar_intermediates := $(call intermediates-dir-for,PACKAGING,android_jar,,COMMON)
The Android Open Source Project52d4c302009-03-03 19:29:09 -080065android_jar_full_target := $(android_jar_intermediates)/android.jar
Narayan Kamathe54bbd82016-02-05 13:56:15 +000066android_jar_src_target := $(android_jar_intermediates)/android-stubs-src.jar
The Android Open Source Project52d4c302009-03-03 19:29:09 -080067
Jaewoong Jung3626b042019-03-12 18:17:14 -070068# unzip and zip android.jar before packaging it. (workaround for b/127733650)
69full_target_repackaged := $(android_jar_intermediates)/repackaged/repackaged.jar
70$(full_target_repackaged): $(full_target) | $(ZIPTIME)
71 @echo Repackaging SDK jar: $@
72 $(hide) rm -rf $(dir $@) && mkdir -p $(dir $@)
73 unzip -q $< -d $(dir $@)
74 cd $(dir $@) && zip -rqX $(notdir $@) *
75 $(remove-timestamps-from-package)
76
77$(android_jar_full_target): $(full_target_repackaged)
The Android Open Source Project52d4c302009-03-03 19:29:09 -080078 @echo Package SDK Stubs: $@
Dan Willemsenf230a382016-03-22 23:32:17 -070079 $(copy-file-to-target)
The Android Open Source Project52d4c302009-03-03 19:29:09 -080080
Narayan Kamathe54bbd82016-02-05 13:56:15 +000081$(android_jar_src_target): $(full_src_target)
82 @echo Package SDK Stubs Source: $@
83 $(hide)mkdir -p $(dir $@)
84 $(hide)$(ACP) $< $@
85
The Android Open Source Project52d4c302009-03-03 19:29:09 -080086ALL_SDK_FILES += $(android_jar_full_target)
Narayan Kamathe54bbd82016-02-05 13:56:15 +000087ALL_SDK_FILES += $(android_jar_src_target)
Ying Wangd46eaa62011-03-01 17:12:12 -080088
Colin Cross89c55172019-11-04 14:52:47 -080089# ===== SDK for system modules =====
90# A subset of the public SDK to convert to system modules for use with javac -source 9 -target 9
91ALL_SDK_FILES += $(call intermediates-dir-for,JAVA_LIBRARIES,core-current-stubs-for-system-modules,,COMMON)/classes.jar
92
Ying Wang78e75a92014-06-03 10:40:10 -070093# ====================================================
94
Ying Wang020d4ab2012-08-14 16:38:02 -070095# The uiautomator stubs
Jiyong Parke43dd952018-03-23 12:19:44 +090096ALL_SDK_FILES += $(TARGET_OUT_COMMON_INTERMEDIATES)/JAVA_LIBRARIES/android_uiautomator_intermediates/classes.jar
Ying Wangd46eaa62011-03-01 17:12:12 -080097
Ying Wanga89998d2015-04-21 16:56:05 -070098# org.apache.http.legacy.jar stubs
Jiyong Parkd06181a2018-05-02 20:44:00 +090099ALL_SDK_FILES += $(TARGET_OUT_COMMON_INTERMEDIATES)/JAVA_LIBRARIES/org.apache.http.legacy.stubs_intermediates/classes.jar
Ying Wanga89998d2015-04-21 16:56:05 -0700100
Zhomart Mukhamejanovbdb2a602020-07-24 15:24:50 -0700101# Android Automotive OS stubs
102ALL_SDK_FILES += $(OUT_DIR)/target/common/obj/JAVA_LIBRARIES/android.car-stubs_intermediates/classes.jar
103
Paul Duffin317f8c82017-10-16 12:38:04 +0100104# test stubs
Jiyong Parke43dd952018-03-23 12:19:44 +0900105ALL_SDK_FILES += $(TARGET_OUT_COMMON_INTERMEDIATES)/JAVA_LIBRARIES/android.test.mock.stubs_intermediates/classes.jar
106ALL_SDK_FILES += $(TARGET_OUT_COMMON_INTERMEDIATES)/JAVA_LIBRARIES/android.test.base.stubs_intermediates/classes.jar
107ALL_SDK_FILES += $(TARGET_OUT_COMMON_INTERMEDIATES)/JAVA_LIBRARIES/android.test.runner.stubs_intermediates/classes.jar
Paul Duffin317f8c82017-10-16 12:38:04 +0100108
Colin Cross15525022017-09-21 17:34:08 -0700109# core-lambda-stubs
110ALL_SDK_FILES += $(TARGET_OUT_COMMON_INTERMEDIATES)/JAVA_LIBRARIES/core-lambda-stubs_intermediates/classes.jar
111
Ivan Gavrilovicb6d3f472017-09-28 17:23:42 +0100112# shrinkedAndroid.jar for multidex support
113ALL_SDK_FILES += $(HOST_OUT_COMMON_INTERMEDIATES)/JAVA_LIBRARIES/shrinkedAndroid_intermediates/shrinkedAndroid.jar
114
Raphael Moll4f8a38e2014-06-04 23:19:19 -0700115# ======= Lint API XML ===========
Colin Cross0c40b602020-07-06 11:20:07 -0700116full_target := $(TARGET_OUT_COMMON_INTERMEDIATES)/PACKAGING/framework-doc-stubs_generated-api-versions.xml
117ALL_SDK_FILES += $(full_target)
118$(call dist-for-goals,sdk win_sdk,$(full_target):data/api-versions.xml)
Aurimas Liutikas1a6d5082020-03-12 16:26:06 -0700119
120# ======= Lint Annotations zip ===========
Colin Cross0c40b602020-07-06 11:20:07 -0700121full_target := $(TARGET_OUT_COMMON_INTERMEDIATES)/PACKAGING/framework-doc-stubs_annotations.zip
122ALL_SDK_FILES += $(full_target)
123$(call dist-for-goals,sdk win_sdk,$(full_target):data/annotations.zip)
Raphael Moll4f8a38e2014-06-04 23:19:19 -0700124
Colin Cross76aa9e12019-04-18 12:10:41 -0700125# ============ SDK AIDL ============
126$(eval $(call copy-one-file,$(FRAMEWORK_AIDL),$(TARGET_OUT_COMMON_INTERMEDIATES)/PACKAGING/framework.aidl))
127ALL_SDK_FILES += $(TARGET_OUT_COMMON_INTERMEDIATES)/PACKAGING/framework.aidl