1 # Copyright (C) 2008 The Android Open Source Project
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
7 # http://www.apache.org/licenses/LICENSE-2.0
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.
16 # Rules for running apicheck to confirm that you haven't broken
17 # api compatibility or added apis illegally.
20 # skip api check for PDK buid
21 ifeq (,$(filter true, $(WITHOUT_CHECK_API) $(TARGET_BUILD_PDK)))
25 # Run the checkapi rules by default.
28 last_released_sdk_version := $(lastword $(call numerically_sort, \
29 $(filter-out current, \
30 $(patsubst $(SRC_API_DIR)/%.txt,%, $(wildcard $(SRC_API_DIR)/*.txt)) \
34 .PHONY: check-public-api
35 checkapi : check-public-api
39 # INTERNAL_PLATFORM_API_FILE is the one build by droiddoc.
40 # 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.
44 # Check that the API we're building hasn't broken the last-released
46 $(eval $(call check-api, \
47 checkpublicapi-last, \
48 $(SRC_API_DIR)/$(last_released_sdk_version).txt, \
49 $(INTERNAL_PLATFORM_API_FILE), \
50 frameworks/base/api/removed.txt, \
51 $(INTERNAL_PLATFORM_REMOVED_API_FILE), \
52 -hide 2 -hide 3 -hide 4 -hide 5 -hide 6 -hide 24 -hide 25 -hide 26 -hide 27 \
53 -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, \
57 $(call doc-timestamp-for,api-stubs) \
60 # Check that the API we're building hasn't changed from the not-yet-released
62 $(eval $(call check-api, \
63 checkpublicapi-current, \
64 frameworks/base/api/current.txt, \
65 $(INTERNAL_PLATFORM_API_FILE), \
66 frameworks/base/api/removed.txt, \
67 $(INTERNAL_PLATFORM_REMOVED_API_FILE), \
68 -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 \
71 -error 25 -error 26 -error 27, \
72 cat $(BUILD_SYSTEM)/apicheck_msg_current.txt, \
74 $(call doc-timestamp-for,api-stubs) \
77 .PHONY: update-public-api
78 update-public-api: $(INTERNAL_PLATFORM_API_FILE) | $(ACP)
79 @echo Copying current.txt
80 $(hide) $(ACP) $(INTERNAL_PLATFORM_API_FILE) frameworks/base/api/current.txt
81 @echo Copying removed.txt
82 $(hide) $(ACP) $(INTERNAL_PLATFORM_REMOVED_API_FILE) frameworks/base/api/removed.txt
84 update-api : update-public-api
86 #####################Check System API#####################
87 .PHONY: check-system-api
88 checkapi : check-system-api
90 # Check that the System API we're building hasn't broken the last-released
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, \
103 $(call doc-timestamp-for,system-api-stubs) \
106 # Check that the System API we're building hasn't changed from the not-yet-released
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, \
118 cat $(BUILD_SYSTEM)/apicheck_msg_current.txt, \
120 $(call doc-timestamp-for,system-api-stubs) \
123 .PHONY: update-system-api
124 update-api : update-system-api
126 update-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
132 #####################Check Test API#####################
133 .PHONY: check-test-api
134 checkapi : check-test-api
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, \
152 $(call doc-timestamp-for,test-api-stubs) \
155 .PHONY: update-test-api
156 update-api : update-test-api
158 update-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