blob: 1d867d18df3da0db91d727eb7c6977f568c3d6fa [file] [log] [blame]
The Android Open Source Project88b60792009-03-03 19:28:42 -08001# Copyright (C) 2008 The Android Open Source Project
2#
3# Licensed under the Apache License, Version 2.0 (the "License");
4# you may not use this file except in compliance with the License.
5# You may obtain a copy of the License at
6#
7# http://www.apache.org/licenses/LICENSE-2.0
8#
9# Unless required by applicable law or agreed to in writing, software
10# distributed under the License is distributed on an "AS IS" BASIS,
11# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12# See the License for the specific language governing permissions and
13# limitations under the License.
14
15#
16# Rules for running apicheck to confirm that you haven't broken
17# api compatibility or added apis illegally.
18#
19
Mike Lockwooddaf5e222012-10-18 10:17:47 -070020# skip api check for PDK buid
21ifeq (,$(filter true, $(WITHOUT_CHECK_API) $(TARGET_BUILD_PDK)))
The Android Open Source Project88b60792009-03-03 19:28:42 -080022
23.PHONY: checkapi
24
The Android Open Source Project88b60792009-03-03 19:28:42 -080025# Run the checkapi rules by default.
26droidcore: checkapi
27
Joe Onorato15ee93b2011-04-08 15:03:48 -070028last_released_sdk_version := $(lastword $(call numerically_sort, \
Ying Wangc065da22012-11-14 15:57:07 -080029 $(filter-out current, \
Joe Onorato15ee93b2011-04-08 15:03:48 -070030 $(patsubst $(SRC_API_DIR)/%.txt,%, $(wildcard $(SRC_API_DIR)/*.txt)) \
31 )\
32 ))
Ying Wang0f6f4ca2010-06-09 10:26:26 -070033
Ying Wang668ae252015-01-09 14:05:38 -080034.PHONY: check-public-api
35checkapi : check-public-api
36
37.PHONY: update-api
38
The Android Open Source Project88b60792009-03-03 19:28:42 -080039# INTERNAL_PLATFORM_API_FILE is the one build by droiddoc.
Ying Wangc065da22012-11-14 15:57:07 -080040# Note that since INTERNAL_PLATFORM_API_FILE is the byproduct of api-stubs module,
41# (See frameworks/base/Android.mk)
42# we need to add api-stubs as additional dependency of the api check.
The Android Open Source Project88b60792009-03-03 19:28:42 -080043
44# Check that the API we're building hasn't broken the last-released
45# SDK version.
46$(eval $(call check-api, \
Ying Wang668ae252015-01-09 14:05:38 -080047 checkpublicapi-last, \
Ying Wangc065da22012-11-14 15:57:07 -080048 $(SRC_API_DIR)/$(last_released_sdk_version).txt, \
49 $(INTERNAL_PLATFORM_API_FILE), \
Hui Shuf6a9b872014-03-13 15:38:29 -070050 frameworks/base/api/removed.txt, \
Hui Shue8af17e2014-02-21 14:18:19 -080051 $(INTERNAL_PLATFORM_REMOVED_API_FILE), \
Jeff Browndd243372013-04-01 13:40:55 -070052 -hide 2 -hide 3 -hide 4 -hide 5 -hide 6 -hide 24 -hide 25 -hide 26 -hide 27 \
Ying Wangc065da22012-11-14 15:57:07 -080053 -error 7 -error 8 -error 9 -error 10 -error 11 -error 12 -error 13 -error 14 -error 15 \
54 -error 16 -error 17 -error 18 , \
55 cat $(BUILD_SYSTEM)/apicheck_msg_last.txt, \
Ying Wang668ae252015-01-09 14:05:38 -080056 check-public-api, \
Nan Zhang0aa96a02018-03-12 16:33:26 -070057 $(OUT_DOCS)/api-stubs-docs-stubs.srcjar \
Ying Wangc065da22012-11-14 15:57:07 -080058 ))
The Android Open Source Project88b60792009-03-03 19:28:42 -080059
60# Check that the API we're building hasn't changed from the not-yet-released
61# SDK version.
62$(eval $(call check-api, \
Ying Wang668ae252015-01-09 14:05:38 -080063 checkpublicapi-current, \
Ying Wang19cc22b2012-12-04 15:07:34 -080064 frameworks/base/api/current.txt, \
Ying Wangc065da22012-11-14 15:57:07 -080065 $(INTERNAL_PLATFORM_API_FILE), \
Hui Shue8af17e2014-02-21 14:18:19 -080066 frameworks/base/api/removed.txt, \
67 $(INTERNAL_PLATFORM_REMOVED_API_FILE), \
Ying Wangc065da22012-11-14 15:57:07 -080068 -error 2 -error 3 -error 4 -error 5 -error 6 \
69 -error 7 -error 8 -error 9 -error 10 -error 11 -error 12 -error 13 -error 14 -error 15 \
70 -error 16 -error 17 -error 18 -error 19 -error 20 -error 21 -error 23 -error 24 \
Jeff Browndd243372013-04-01 13:40:55 -070071 -error 25 -error 26 -error 27, \
Ying Wang668ae252015-01-09 14:05:38 -080072 cat $(BUILD_SYSTEM)/apicheck_msg_current.txt, \
73 check-public-api, \
Nan Zhang0aa96a02018-03-12 16:33:26 -070074 $(OUT_DOCS)/api-stubs-docs-stubs.srcjar \
Ying Wangc065da22012-11-14 15:57:07 -080075 ))
The Android Open Source Project88b60792009-03-03 19:28:42 -080076
Ying Wang668ae252015-01-09 14:05:38 -080077.PHONY: update-public-api
78update-public-api: $(INTERNAL_PLATFORM_API_FILE) | $(ACP)
Joe Onorato15ee93b2011-04-08 15:03:48 -070079 @echo Copying current.txt
Ying Wang19cc22b2012-12-04 15:07:34 -080080 $(hide) $(ACP) $(INTERNAL_PLATFORM_API_FILE) frameworks/base/api/current.txt
Hui Shue8af17e2014-02-21 14:18:19 -080081 @echo Copying removed.txt
82 $(hide) $(ACP) $(INTERNAL_PLATFORM_REMOVED_API_FILE) frameworks/base/api/removed.txt
The Android Open Source Project88b60792009-03-03 19:28:42 -080083
Ying Wang668ae252015-01-09 14:05:38 -080084update-api : update-public-api
Ying Wang829f68b2014-06-26 17:54:28 -070085
86#####################Check System API#####################
Ying Wang668ae252015-01-09 14:05:38 -080087.PHONY: check-system-api
88checkapi : check-system-api
Ying Wang829f68b2014-06-26 17:54:28 -070089
90# Check that the System API we're building hasn't broken the last-released
91# SDK version.
92$(eval $(call check-api, \
93 checksystemapi-last, \
94 $(SRC_SYSTEM_API_DIR)/$(last_released_sdk_version).txt, \
95 $(INTERNAL_PLATFORM_SYSTEM_API_FILE), \
96 frameworks/base/api/system-removed.txt, \
97 $(INTERNAL_PLATFORM_SYSTEM_REMOVED_API_FILE), \
98 -hide 2 -hide 3 -hide 4 -hide 5 -hide 6 -hide 24 -hide 25 -hide 26 -hide 27 \
99 -error 7 -error 8 -error 9 -error 10 -error 11 -error 12 -error 13 -error 14 -error 15 \
100 -error 16 -error 17 -error 18 , \
101 cat $(BUILD_SYSTEM)/apicheck_msg_last.txt, \
Ying Wang668ae252015-01-09 14:05:38 -0800102 check-system-api, \
Nan Zhang0aa96a02018-03-12 16:33:26 -0700103 $(OUT_DOCS)/system-api-stubs-docs-stubs.srcjar \
Ying Wang829f68b2014-06-26 17:54:28 -0700104 ))
105
106# Check that the System API we're building hasn't changed from the not-yet-released
107# SDK version.
108$(eval $(call check-api, \
109 checksystemapi-current, \
110 frameworks/base/api/system-current.txt, \
111 $(INTERNAL_PLATFORM_SYSTEM_API_FILE), \
112 frameworks/base/api/system-removed.txt, \
113 $(INTERNAL_PLATFORM_SYSTEM_REMOVED_API_FILE), \
114 -error 2 -error 3 -error 4 -error 5 -error 6 \
115 -error 7 -error 8 -error 9 -error 10 -error 11 -error 12 -error 13 -error 14 -error 15 \
116 -error 16 -error 17 -error 18 -error 19 -error 20 -error 21 -error 23 -error 24 \
117 -error 25 -error 26 -error 27, \
Ying Wang668ae252015-01-09 14:05:38 -0800118 cat $(BUILD_SYSTEM)/apicheck_msg_current.txt, \
119 check-system-api, \
Nan Zhang0aa96a02018-03-12 16:33:26 -0700120 $(OUT_DOCS)/system-api-stubs-docs-stubs.srcjar \
Ying Wang829f68b2014-06-26 17:54:28 -0700121 ))
122
123.PHONY: update-system-api
Ying Wang668ae252015-01-09 14:05:38 -0800124update-api : update-system-api
125
Ying Wang829f68b2014-06-26 17:54:28 -0700126update-system-api: $(INTERNAL_PLATFORM_SYSTEM_API_FILE) | $(ACP)
127 @echo Copying system-current.txt
128 $(hide) $(ACP) $(INTERNAL_PLATFORM_SYSTEM_API_FILE) frameworks/base/api/system-current.txt
129 @echo Copying system-removed.txt
130 $(hide) $(ACP) $(INTERNAL_PLATFORM_SYSTEM_REMOVED_API_FILE) frameworks/base/api/system-removed.txt
131
Michael Wright0fb087f2015-11-06 15:20:51 +0000132#####################Check Test API#####################
133.PHONY: check-test-api
134checkapi : check-test-api
135
136# Check that the Test API we're building hasn't changed from the not-yet-released
137# SDK version. Note that we don't check that we haven't broken the previous
138# SDK's API because the test API is meant only for CTS which is always
139# associated with the current release.
140$(eval $(call check-api, \
141 checktestapi-current, \
142 frameworks/base/api/test-current.txt, \
143 $(INTERNAL_PLATFORM_TEST_API_FILE), \
144 frameworks/base/api/test-removed.txt, \
145 $(INTERNAL_PLATFORM_TEST_REMOVED_API_FILE), \
146 -error 2 -error 3 -error 4 -error 5 -error 6 \
147 -error 7 -error 8 -error 9 -error 10 -error 11 -error 12 -error 13 -error 14 -error 15 \
148 -error 16 -error 17 -error 18 -error 19 -error 20 -error 21 -error 23 -error 24 \
149 -error 25 -error 26 -error 27, \
150 cat $(BUILD_SYSTEM)/apicheck_msg_current.txt, \
151 check-test-api, \
Nan Zhang0aa96a02018-03-12 16:33:26 -0700152 $(OUT_DOCS)/test-api-stubs-docs-stubs.srcjar \
Michael Wright0fb087f2015-11-06 15:20:51 +0000153 ))
154
155.PHONY: update-test-api
156update-api : update-test-api
157
158update-test-api: $(INTERNAL_PLATFORM_TEST_API_FILE) | $(ACP)
159 @echo Copying test-current.txt
160 $(hide) $(ACP) $(INTERNAL_PLATFORM_TEST_API_FILE) frameworks/base/api/test-current.txt
161 @echo Copying test-removed.txt
162 $(hide) $(ACP) $(INTERNAL_PLATFORM_TEST_REMOVED_API_FILE) frameworks/base/api/test-removed.txt
163
164
The Android Open Source Project88b60792009-03-03 19:28:42 -0800165endif