blob: f0810713f39fc686d91aec094a384c50a07d208a [file] [log] [blame]
Jiyong Park7fb4b182019-12-20 14:35:43 +09001// Copyright (C) 2019 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// How stubs are generated:
16//
17// raw source files --(metalava)--> stub source files --(javac)--> stub jar files
18//
19// The metalava conversion is done by droidstub modules *-api-stubs-docs.
20// The javac compilation is done by java_library modules android_*_stubs_current.
21// The metalava conversion is also responsible for creating API signature files
22// and comparing them against the last API signature in api/*-current.txt files
23// and also against the latest frozen API signature in prebuilts/sdk/*/*/api/android.txt
24// files.
25
26/////////////////////////////////////////////////////////////////////
27// Common metalava configs
28/////////////////////////////////////////////////////////////////////
29
30packages_to_document = [
31 "android",
32 "dalvik",
33 "java",
34 "javax",
35 "junit",
36 "org.apache.http",
37 "org.json",
38 "org.w3c.dom",
39 "org.xml.sax",
40 "org.xmlpull",
41]
42
43stubs_defaults {
Anton Hansson537564e2020-03-06 17:16:06 +000044 name: "metalava-base-api-stubs-default",
Jiyong Park7fb4b182019-12-20 14:35:43 +090045 srcs: [
46 ":framework-non-updatable-sources",
Jiyong Park7fb4b182019-12-20 14:35:43 +090047 "core/java/**/*.logtags",
48 ":opt-telephony-srcs",
49 ":opt-net-voip-srcs",
Paul Duffin5c89e702020-03-26 15:33:48 +000050 ":art-module-public-api-stubs-source",
51 ":conscrypt-module-public-api-stubs-source",
52 ":android_icu4j_public_api_files",
Jiyong Park7fb4b182019-12-20 14:35:43 +090053 ],
54 libs: ["framework-internal-utils"],
55 installable: false,
56 annotations_enabled: true,
57 previous_api: ":last-released-public-api",
58 merge_annotations_dirs: [
59 "metalava-manual",
60 ],
Aurimas Liutikas94bac9c2020-03-12 17:06:12 -070061 api_levels_annotations_enabled: false,
Jiyong Park7fb4b182019-12-20 14:35:43 +090062 filter_packages: packages_to_document,
63}
64
Jiyong Park2e6cdcc2019-12-20 15:30:28 +090065stubs_defaults {
Anton Hansson537564e2020-03-06 17:16:06 +000066 name: "metalava-full-api-stubs-default",
67 defaults: ["metalava-base-api-stubs-default"],
Jiyong Park2e6cdcc2019-12-20 15:30:28 +090068 srcs: [":framework-updatable-sources"],
69 sdk_version: "core_platform",
70}
71
Anton Hansson537564e2020-03-06 17:16:06 +000072stubs_defaults {
73 name: "metalava-non-updatable-api-stubs-default",
74 defaults: ["metalava-base-api-stubs-default"],
Anton Hanssone53bec02020-03-20 09:12:52 +000075 sdk_version: "core_platform",
76 libs: ["framework-all"],
Anton Hansson537564e2020-03-06 17:16:06 +000077}
78
Jiyong Park7fb4b182019-12-20 14:35:43 +090079/////////////////////////////////////////////////////////////////////
80// *-api-stubs-docs modules providing source files for the stub libraries
81/////////////////////////////////////////////////////////////////////
82
Jiyong Park2e6cdcc2019-12-20 15:30:28 +090083// api-stubs-docs, system-api-stubs-docs, and test-api-stubs-docs have APIs
84// from the non-updatable part of the platform as well as from the updatable
85// modules
Jiyong Park7fb4b182019-12-20 14:35:43 +090086droidstubs {
87 name: "api-stubs-docs",
Anton Hansson537564e2020-03-06 17:16:06 +000088 defaults: ["metalava-full-api-stubs-default"],
Jiyong Park7fb4b182019-12-20 14:35:43 +090089 api_filename: "public_api.txt",
90 private_api_filename: "private.txt",
91 removed_api_filename: "removed.txt",
92 arg_files: [
93 "core/res/AndroidManifest.xml",
94 ],
95 args: metalava_framework_docs_args,
96 check_api: {
97 current: {
98 api_file: "api/current.txt",
99 removed_api_file: "api/removed.txt",
100 },
101 last_released: {
102 api_file: ":last-released-public-api",
103 removed_api_file: "api/removed.txt",
104 baseline_file: ":public-api-incompatibilities-with-last-released",
105 },
106 api_lint: {
107 enabled: true,
108 new_since: ":last-released-public-api",
109 baseline_file: "api/lint-baseline.txt",
110 },
111 },
112 jdiff_enabled: true,
113}
114
Anton Hansson81969c22020-02-03 20:45:56 +0000115priv_apps = " " +
116 "--show-annotation android.annotation.SystemApi\\(" +
117 "client=android.annotation.SystemApi.Client.PRIVILEGED_APPS" +
118 "\\) "
119
120module_libs = " " +
121 " --show-annotation android.annotation.SystemApi\\(" +
122 "client=android.annotation.SystemApi.Client.MODULE_LIBRARIES" +
123 "\\) "
124
Jiyong Park7fb4b182019-12-20 14:35:43 +0900125droidstubs {
126 name: "system-api-stubs-docs",
Anton Hansson537564e2020-03-06 17:16:06 +0000127 defaults: ["metalava-full-api-stubs-default"],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900128 api_tag_name: "SYSTEM",
129 api_filename: "system-api.txt",
130 private_api_filename: "system-private.txt",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900131 removed_api_filename: "system-removed.txt",
132 arg_files: [
133 "core/res/AndroidManifest.xml",
134 ],
Anton Hansson81969c22020-02-03 20:45:56 +0000135 args: metalava_framework_docs_args + priv_apps,
Jiyong Park7fb4b182019-12-20 14:35:43 +0900136 check_api: {
137 current: {
138 api_file: "api/system-current.txt",
139 removed_api_file: "api/system-removed.txt",
140 },
141 last_released: {
142 api_file: ":last-released-system-api",
143 removed_api_file: "api/system-removed.txt",
144 baseline_file: ":system-api-incompatibilities-with-last-released"
145 },
146 api_lint: {
147 enabled: true,
148 new_since: ":last-released-system-api",
149 baseline_file: "api/system-lint-baseline.txt",
150 },
151 },
152 jdiff_enabled: true,
153}
154
155droidstubs {
156 name: "test-api-stubs-docs",
Anton Hansson537564e2020-03-06 17:16:06 +0000157 defaults: ["metalava-full-api-stubs-default"],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900158 api_tag_name: "TEST",
159 api_filename: "test-api.txt",
160 removed_api_filename: "test-removed.txt",
161 arg_files: [
162 "core/res/AndroidManifest.xml",
163 ],
164 args: metalava_framework_docs_args + " --show-annotation android.annotation.TestApi",
165 check_api: {
166 current: {
167 api_file: "api/test-current.txt",
168 removed_api_file: "api/test-removed.txt",
169 },
170 api_lint: {
171 enabled: true,
172 baseline_file: "api/test-lint-baseline.txt",
173 },
174 },
175}
176
177/////////////////////////////////////////////////////////////////////
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900178// Following droidstubs modules are for extra APIs for modules.
179// The framework currently have two more API surfaces for modules:
180// @SystemApi(client=MODULE_APPS) and @SystemApi(client=MODULE_LIBRARIES)
181/////////////////////////////////////////////////////////////////////
182
Anton Hansson81969c22020-02-03 20:45:56 +0000183// TODO(b/146727827) remove the *-api module when we can teach metalava
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900184// about the relationship among the API surfaces. Currently, these modules are only to generate
185// the API signature files and ensure that the APIs evolve in a backwards compatible manner.
186// They however are NOT used for building the API stub.
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900187
188droidstubs {
189 name: "module-lib-api",
Anton Hansson537564e2020-03-06 17:16:06 +0000190 defaults: ["metalava-full-api-stubs-default"],
Anton Hansson9a01e552020-03-19 15:09:44 +0000191 api_tag_name: "MODULE_LIB",
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900192 arg_files: ["core/res/AndroidManifest.xml"],
Anton Hansson81969c22020-02-03 20:45:56 +0000193 args: metalava_framework_docs_args + module_libs,
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900194 check_api: {
195 current: {
196 api_file: "api/module-lib-current.txt",
197 removed_api_file: "api/module-lib-removed.txt",
198 },
Anton Hansson626afea2020-02-11 14:36:40 +0000199 last_released: {
200 api_file: ":last-released-module-lib-api",
201 removed_api_file: "api/module-lib-removed.txt",
202 baseline_file: ":module-lib-api-incompatibilities-with-last-released"
203 },
204 api_lint: {
205 enabled: true,
206 new_since: ":last-released-module-lib-api",
207 baseline_file: "api/module-lib-lint-baseline.txt",
208 },
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900209 },
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900210}
211
Anton Hansson81969c22020-02-03 20:45:56 +0000212
213// The following droidstub module generates source files for the API stub library for
214// modules. Note that it not only includes its own APIs but also other APIs that have
215// narrower scope (all @SystemApis, not just the ones with 'client=MODULE_LIBRARIES').
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900216
217droidstubs {
218 name: "module-lib-api-stubs-docs",
Anton Hansson537564e2020-03-06 17:16:06 +0000219 defaults: ["metalava-non-updatable-api-stubs-default"],
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900220 arg_files: ["core/res/AndroidManifest.xml"],
Anton Hansson81969c22020-02-03 20:45:56 +0000221 args: metalava_framework_docs_args + priv_apps + module_libs,
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900222}
223
224/////////////////////////////////////////////////////////////////////
Jiyong Park7fb4b182019-12-20 14:35:43 +0900225// android_*_stubs_current modules are the stubs libraries compiled
226// from *-api-stubs-docs
227/////////////////////////////////////////////////////////////////////
228
229java_defaults {
230 name: "framework-stubs-default",
Anton Hansson42afd612020-02-08 20:43:19 +0000231 libs: [ "stub-annotations" ],
Paul Duffina281e922020-03-25 10:13:33 +0000232 static_libs: [
233 "private-stub-annotations-jar",
234
235 // License notices from art module
236 "art-notices-for-framework-stubs-jar",
237 ],
Anton Hansson42afd612020-02-08 20:43:19 +0000238 sdk_version: "core_current",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900239 errorprone: {
240 javacflags: [
241 "-XepDisableAllChecks",
242 ],
243 },
Jiyong Park7fb4b182019-12-20 14:35:43 +0900244 system_modules: "none",
245 java_version: "1.8",
246 compile_dex: true,
247}
248
249java_library_static {
250 name: "android_stubs_current",
Anton Hansson42afd612020-02-08 20:43:19 +0000251 srcs: [ ":api-stubs-docs" ],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900252 defaults: ["framework-stubs-default"],
253}
254
255java_library_static {
256 name: "android_system_stubs_current",
Anton Hansson42afd612020-02-08 20:43:19 +0000257 srcs: [ ":system-api-stubs-docs" ],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900258 defaults: ["framework-stubs-default"],
259}
260
261java_library_static {
262 name: "android_test_stubs_current",
Anton Hansson42afd612020-02-08 20:43:19 +0000263 srcs: [ ":test-api-stubs-docs" ],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900264 defaults: ["framework-stubs-default"],
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900265}
266
267java_library_static {
Anton Hansson9c4bbe92020-01-30 12:09:02 +0000268 name: "android_module_lib_stubs_current",
Anton Hansson42afd612020-02-08 20:43:19 +0000269 srcs: [ ":module-lib-api-stubs-docs" ],
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900270 defaults: ["framework-stubs-default"],
Anton Hansson537564e2020-03-06 17:16:06 +0000271 libs: ["android_system_stubs_current"],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900272}
273
Jiyong Park7fb4b182019-12-20 14:35:43 +0900274/////////////////////////////////////////////////////////////////////
275// hwbinder.stubs provides APIs required for building HIDL Java
276// libraries.
277/////////////////////////////////////////////////////////////////////
278
279droidstubs {
280 name: "hwbinder-stubs-docs",
281 srcs: [
282 "core/java/android/os/HidlSupport.java",
283 "core/java/android/annotation/IntDef.java",
284 "core/java/android/annotation/IntRange.java",
285 "core/java/android/annotation/NonNull.java",
286 "core/java/android/annotation/SystemApi.java",
287 "core/java/android/os/HidlMemory.java",
288 "core/java/android/os/HwBinder.java",
289 "core/java/android/os/HwBlob.java",
290 "core/java/android/os/HwParcel.java",
291 "core/java/android/os/IHwBinder.java",
292 "core/java/android/os/IHwInterface.java",
293 "core/java/android/os/DeadObjectException.java",
294 "core/java/android/os/DeadSystemException.java",
295 "core/java/android/os/NativeHandle.java",
296 "core/java/android/os/RemoteException.java",
297 "core/java/android/util/AndroidException.java",
298 ],
299 installable: false,
300 sdk_version: "core_platform",
301 annotations_enabled: true,
302 previous_api: ":last-released-public-api",
303 merge_annotations_dirs: [
304 "metalava-manual",
305 ],
Anton Hansson81969c22020-02-03 20:45:56 +0000306 args: priv_apps,
Jiyong Park7fb4b182019-12-20 14:35:43 +0900307}
308
309java_library_static {
310 name: "hwbinder.stubs",
311 sdk_version: "core_current",
312 srcs: [
313 ":hwbinder-stubs-docs",
314 ],
315}
316
317/////////////////////////////////////////////////////////////////////
318// Stubs for hiddenapi processing.
319/////////////////////////////////////////////////////////////////////
320
321droidstubs {
322 name: "hiddenapi-lists-docs",
Anton Hansson537564e2020-03-06 17:16:06 +0000323 defaults: ["metalava-full-api-stubs-default"],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900324 arg_files: [
325 "core/res/AndroidManifest.xml",
326 ],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900327 removed_dex_api_filename: "removed-dex.txt",
328 args: metalava_framework_docs_args +
329 " --show-unannotated " +
Anton Hansson81969c22020-02-03 20:45:56 +0000330 priv_apps +
Jiyong Park7fb4b182019-12-20 14:35:43 +0900331 " --show-annotation android.annotation.TestApi ",
332}
333
334droidstubs {
335 name: "hiddenapi-mappings",
Anton Hansson537564e2020-03-06 17:16:06 +0000336 defaults: ["metalava-full-api-stubs-default"],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900337 srcs: [
338 ":opt-telephony-common-srcs",
339 ],
340
341 arg_files: [
342 "core/res/AndroidManifest.xml",
343 ],
344 dex_mapping_filename: "dex-mapping.txt",
345 args: metalava_framework_docs_args +
346 " --hide ReferencesHidden " +
347 " --hide UnhiddenSystemApi " +
348 " --show-unannotated " +
Anton Hansson81969c22020-02-03 20:45:56 +0000349 priv_apps +
Jiyong Park7fb4b182019-12-20 14:35:43 +0900350 " --show-annotation android.annotation.TestApi ",
351}
352
353/////////////////////////////////////////////////////////////////////
354// api/*-current.txt files for use by modules in other directories
355// like the CTS test
356/////////////////////////////////////////////////////////////////////
357
358filegroup {
359 name: "frameworks-base-api-current.txt",
360 srcs: [
361 "api/current.txt",
362 ],
363}
364
365filegroup {
366 name: "frameworks-base-api-system-current.txt",
367 srcs: [
368 "api/system-current.txt",
369 ],
370}
371
372filegroup {
373 name: "frameworks-base-api-system-removed.txt",
374 srcs: [
375 "api/system-removed.txt",
376 ],
377}