blob: b999a10d0a3f21054040474f83babcc23ce7bf20 [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",
Paul Duffin5c89e702020-03-26 15:33:48 +000051 ":android_icu4j_public_api_files",
Ramy Medhataaa83862020-05-04 05:54:30 -040052 "**/package.html",
Jiyong Park7fb4b182019-12-20 14:35:43 +090053 ],
54 libs: ["framework-internal-utils"],
55 installable: false,
56 annotations_enabled: true,
Anton Hanssonf68ddea2020-05-02 17:49:26 +010057 previous_api: ":android.api.public.latest",
Jiyong Park7fb4b182019-12-20 14:35:43 +090058 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"],
Anton Hanssone01390c2020-05-07 12:06:00 +010068 srcs: [
Paul Duffine55d4e32020-05-14 17:55:46 +010069 ":conscrypt.module.public.api{.public.stubs.source}",
Anton Hanssone01390c2020-05-07 12:06:00 +010070 ":framework-updatable-sources",
71 ],
Jiyong Park2e6cdcc2019-12-20 15:30:28 +090072 sdk_version: "core_platform",
73}
74
Anton Hansson537564e2020-03-06 17:16:06 +000075stubs_defaults {
76 name: "metalava-non-updatable-api-stubs-default",
77 defaults: ["metalava-base-api-stubs-default"],
Anton Hanssone53bec02020-03-20 09:12:52 +000078 sdk_version: "core_platform",
Anton Hanssonebb26a32020-04-14 16:35:36 +010079 // There are a few classes from modules used as type arguments that
80 // need to be resolved by metalava. For now, we can use a previously
81 // finalized stub library to resolve them. If a new class gets added,
82 // this may be need to be revisited to use a manually maintained stub
83 // library with empty classes in order to resolve those references.
84 libs: ["sdk_system_29_android"],
85 aidl: {
86 local_include_dirs: [
87 "media/apex/java",
88 "wifi/aidl-export",
89 ],
90 },
Anton Hansson537564e2020-03-06 17:16:06 +000091}
92
Jiyong Park7fb4b182019-12-20 14:35:43 +090093/////////////////////////////////////////////////////////////////////
94// *-api-stubs-docs modules providing source files for the stub libraries
95/////////////////////////////////////////////////////////////////////
96
Jiyong Park2e6cdcc2019-12-20 15:30:28 +090097// api-stubs-docs, system-api-stubs-docs, and test-api-stubs-docs have APIs
98// from the non-updatable part of the platform as well as from the updatable
99// modules
Jiyong Park7fb4b182019-12-20 14:35:43 +0900100droidstubs {
101 name: "api-stubs-docs",
Anton Hansson537564e2020-03-06 17:16:06 +0000102 defaults: ["metalava-full-api-stubs-default"],
Artur Satayev0a97d5e2020-03-25 16:45:56 +0000103 removed_dex_api_filename: "removed-dex.txt",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900104 arg_files: [
105 "core/res/AndroidManifest.xml",
106 ],
107 args: metalava_framework_docs_args,
108 check_api: {
109 current: {
110 api_file: "api/current.txt",
111 removed_api_file: "api/removed.txt",
112 },
113 last_released: {
Anton Hanssonf68ddea2020-05-02 17:49:26 +0100114 api_file: ":android.api.public.latest",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900115 removed_api_file: "api/removed.txt",
116 baseline_file: ":public-api-incompatibilities-with-last-released",
117 },
118 api_lint: {
119 enabled: true,
Anton Hanssonf68ddea2020-05-02 17:49:26 +0100120 new_since: ":android.api.public.latest",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900121 baseline_file: "api/lint-baseline.txt",
122 },
123 },
Anton Hanssonba367d32020-03-23 18:08:55 +0000124 dist: {
125 targets: ["sdk", "win_sdk"],
126 dir: "apistubs/android/public/api",
127 dest: "android.txt",
128 },
Jiyong Park7fb4b182019-12-20 14:35:43 +0900129 jdiff_enabled: true,
130}
131
Anton Hansson7f6823e2020-06-04 15:09:36 +0100132droidstubs {
133 name: "api-stubs-docs-non-updatable",
134 defaults: ["metalava-non-updatable-api-stubs-default"],
135 arg_files: ["core/res/AndroidManifest.xml"],
136 args: metalava_framework_docs_args,
137 check_api: {
138 current: {
139 api_file: "non-updatable-api/current.txt",
140 removed_api_file: "non-updatable-api/removed.txt",
141 },
142 },
143}
144
Anton Hansson81969c22020-02-03 20:45:56 +0000145priv_apps = " " +
146 "--show-annotation android.annotation.SystemApi\\(" +
147 "client=android.annotation.SystemApi.Client.PRIVILEGED_APPS" +
148 "\\) "
149
150module_libs = " " +
151 " --show-annotation android.annotation.SystemApi\\(" +
152 "client=android.annotation.SystemApi.Client.MODULE_LIBRARIES" +
Makoto Onukia13287f2020-07-10 12:05:21 -0700153 "\\)" +
154 " --show-for-stub-purposes-annotation android.annotation.SystemApi\\(" +
155 "client=android.annotation.SystemApi.Client.PRIVILEGED_APPS" +
Anton Hansson81969c22020-02-03 20:45:56 +0000156 "\\) "
157
Jiyong Park7fb4b182019-12-20 14:35:43 +0900158droidstubs {
159 name: "system-api-stubs-docs",
Anton Hansson537564e2020-03-06 17:16:06 +0000160 defaults: ["metalava-full-api-stubs-default"],
Artur Satayev0a97d5e2020-03-25 16:45:56 +0000161 removed_dex_api_filename: "system-removed-dex.txt",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900162 arg_files: [
163 "core/res/AndroidManifest.xml",
164 ],
Anton Hansson81969c22020-02-03 20:45:56 +0000165 args: metalava_framework_docs_args + priv_apps,
Jiyong Park7fb4b182019-12-20 14:35:43 +0900166 check_api: {
167 current: {
168 api_file: "api/system-current.txt",
169 removed_api_file: "api/system-removed.txt",
170 },
171 last_released: {
Anton Hanssonf68ddea2020-05-02 17:49:26 +0100172 api_file: ":android.api.system.latest",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900173 removed_api_file: "api/system-removed.txt",
174 baseline_file: ":system-api-incompatibilities-with-last-released"
175 },
176 api_lint: {
177 enabled: true,
Anton Hanssonf68ddea2020-05-02 17:49:26 +0100178 new_since: ":android.api.system.latest",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900179 baseline_file: "api/system-lint-baseline.txt",
180 },
181 },
Anton Hanssonba367d32020-03-23 18:08:55 +0000182 dist: {
183 targets: ["sdk", "win_sdk"],
184 dir: "apistubs/android/system/api",
185 dest: "android.txt",
186 },
Jiyong Park7fb4b182019-12-20 14:35:43 +0900187 jdiff_enabled: true,
188}
189
190droidstubs {
Anton Hansson7f6823e2020-06-04 15:09:36 +0100191 name: "system-api-stubs-docs-non-updatable",
192 defaults: ["metalava-non-updatable-api-stubs-default"],
193 arg_files: ["core/res/AndroidManifest.xml"],
194 args: metalava_framework_docs_args + priv_apps,
195 check_api: {
196 current: {
197 api_file: "non-updatable-api/system-current.txt",
198 removed_api_file: "non-updatable-api/system-removed.txt",
199 },
200 },
201}
202
203droidstubs {
Jiyong Park7fb4b182019-12-20 14:35:43 +0900204 name: "test-api-stubs-docs",
Anton Hansson537564e2020-03-06 17:16:06 +0000205 defaults: ["metalava-full-api-stubs-default"],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900206 arg_files: [
207 "core/res/AndroidManifest.xml",
208 ],
209 args: metalava_framework_docs_args + " --show-annotation android.annotation.TestApi",
210 check_api: {
211 current: {
212 api_file: "api/test-current.txt",
213 removed_api_file: "api/test-removed.txt",
214 },
215 api_lint: {
216 enabled: true,
217 baseline_file: "api/test-lint-baseline.txt",
218 },
219 },
Anton Hanssonba367d32020-03-23 18:08:55 +0000220 dist: {
221 targets: ["sdk", "win_sdk"],
222 dir: "apistubs/android/test/api",
223 dest: "android.txt",
224 },
Jiyong Park7fb4b182019-12-20 14:35:43 +0900225}
226
227/////////////////////////////////////////////////////////////////////
Makoto Onukia13287f2020-07-10 12:05:21 -0700228// Following droidstubs modules are for extra APIs for modules,
229// namely @SystemApi(client=MODULE_LIBRARIES) APIs.
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900230/////////////////////////////////////////////////////////////////////
231
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900232droidstubs {
233 name: "module-lib-api",
Anton Hansson537564e2020-03-06 17:16:06 +0000234 defaults: ["metalava-full-api-stubs-default"],
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900235 arg_files: ["core/res/AndroidManifest.xml"],
Anton Hansson81969c22020-02-03 20:45:56 +0000236 args: metalava_framework_docs_args + module_libs,
Paul Duffin4c5dc182020-04-08 18:28:15 +0100237
238 // Do not generate stubs as they are not needed
239 generate_stubs: false,
240
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900241 check_api: {
242 current: {
243 api_file: "api/module-lib-current.txt",
244 removed_api_file: "api/module-lib-removed.txt",
245 },
Anton Hansson626afea2020-02-11 14:36:40 +0000246 last_released: {
Anton Hanssonf68ddea2020-05-02 17:49:26 +0100247 api_file: ":android.api.module-lib.latest",
Anton Hansson626afea2020-02-11 14:36:40 +0000248 removed_api_file: "api/module-lib-removed.txt",
249 baseline_file: ":module-lib-api-incompatibilities-with-last-released"
250 },
251 api_lint: {
252 enabled: true,
Anton Hanssonf68ddea2020-05-02 17:49:26 +0100253 new_since: ":android.api.module-lib.latest",
Anton Hansson626afea2020-02-11 14:36:40 +0000254 baseline_file: "api/module-lib-lint-baseline.txt",
255 },
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900256 },
Anton Hanssonba367d32020-03-23 18:08:55 +0000257 dist: {
258 targets: ["sdk", "win_sdk"],
259 dir: "apistubs/android/module-lib/api",
260 dest: "android.txt",
261 },
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900262}
263
Anton Hansson7f6823e2020-06-04 15:09:36 +0100264droidstubs {
265 name: "module-lib-api-stubs-docs-non-updatable",
266 defaults: ["metalava-non-updatable-api-stubs-default"],
267 arg_files: ["core/res/AndroidManifest.xml"],
Makoto Onuki8c61de62020-07-15 10:38:04 -0700268 args: metalava_framework_docs_args + priv_apps + module_libs,
Anton Hansson7f6823e2020-06-04 15:09:36 +0100269 check_api: {
270 current: {
271 api_file: "non-updatable-api/module-lib-current.txt",
272 removed_api_file: "non-updatable-api/module-lib-removed.txt",
273 },
274 },
275}
Anton Hansson81969c22020-02-03 20:45:56 +0000276
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900277/////////////////////////////////////////////////////////////////////
Jiyong Park7fb4b182019-12-20 14:35:43 +0900278// android_*_stubs_current modules are the stubs libraries compiled
279// from *-api-stubs-docs
280/////////////////////////////////////////////////////////////////////
281
282java_defaults {
Anton Hanssonfbd32f32020-04-09 14:16:37 +0100283 name: "android_defaults_stubs_current",
Anton Hansson42afd612020-02-08 20:43:19 +0000284 libs: [ "stub-annotations" ],
Paul Duffina281e922020-03-25 10:13:33 +0000285 static_libs: [
286 "private-stub-annotations-jar",
287
288 // License notices from art module
289 "art-notices-for-framework-stubs-jar",
290 ],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900291 errorprone: {
292 javacflags: [
293 "-XepDisableAllChecks",
294 ],
295 },
Anton Hanssonfbd32f32020-04-09 14:16:37 +0100296 sdk_version: "none",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900297 system_modules: "none",
298 java_version: "1.8",
299 compile_dex: true,
300}
301
Anton Hanssona9205502020-07-15 13:36:34 +0100302java_defaults {
303 name: "android_stubs_dists_default",
304 dist: {
305 targets: ["sdk", "win_sdk"],
306 tag: ".jar",
307 dest: "android.jar",
308 },
309}
310
Jiyong Park7fb4b182019-12-20 14:35:43 +0900311java_library_static {
312 name: "android_stubs_current",
Anton Hansson42afd612020-02-08 20:43:19 +0000313 srcs: [ ":api-stubs-docs" ],
Anton Hanssonfbd32f32020-04-09 14:16:37 +0100314 defaults: ["android_defaults_stubs_current"],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900315}
316
317java_library_static {
318 name: "android_system_stubs_current",
Anton Hansson42afd612020-02-08 20:43:19 +0000319 srcs: [ ":system-api-stubs-docs" ],
Anton Hanssona9205502020-07-15 13:36:34 +0100320 defaults: [
321 "android_defaults_stubs_current",
322 "android_stubs_dists_default",
323 ],
324 dist: {
325 dir: "apistubs/android/system",
326 },
327 dists: [
328 {
329 // Legacy dist path
330 targets: ["sdk", "win_sdk"],
331 tag: ".jar",
332 dest: "android_system.jar",
333 },
334 ],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900335}
336
337java_library_static {
338 name: "android_test_stubs_current",
Anton Hansson42afd612020-02-08 20:43:19 +0000339 srcs: [ ":test-api-stubs-docs" ],
Anton Hanssona9205502020-07-15 13:36:34 +0100340 defaults: [
341 "android_defaults_stubs_current",
342 "android_stubs_dists_default",
343 ],
344 dist: {
345 dir: "apistubs/android/test",
346 },
347 dists: [
348 {
349 // Legacy dist path
350 targets: ["sdk", "win_sdk"],
351 tag: ".jar",
352 dest: "android_test.jar",
353 },
354 ],
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900355}
356
357java_library_static {
Anton Hansson9c4bbe92020-01-30 12:09:02 +0000358 name: "android_module_lib_stubs_current",
Makoto Onuki8c61de62020-07-15 10:38:04 -0700359 srcs: [ ":module-lib-api-stubs-docs-non-updatable" ],
Anton Hanssona9205502020-07-15 13:36:34 +0100360 defaults: [
361 "android_defaults_stubs_current",
362 "android_stubs_dists_default",
363 ],
Anton Hanssonebb26a32020-04-14 16:35:36 +0100364 libs: ["sdk_system_29_android"],
Anton Hanssona9205502020-07-15 13:36:34 +0100365 dist: {
366 dir: "apistubs/android/module-lib",
367 },
Jiyong Park7fb4b182019-12-20 14:35:43 +0900368}
369
Anton Hansson7f6823e2020-06-04 15:09:36 +0100370java_library_static {
371 name: "android_non_updatable_stubs_current",
372 srcs: [":api-stubs-docs-non-updatable"],
373 defaults: ["android_defaults_stubs_current"],
374 libs: ["sdk_system_29_android"],
375}
376
377java_library_static {
378 name: "android_system_non_updatable_stubs_current",
379 srcs: [":system-api-stubs-docs-non-updatable"],
380 defaults: ["android_defaults_stubs_current"],
381 libs: ["sdk_system_29_android"],
382}
383
Jiyong Park7fb4b182019-12-20 14:35:43 +0900384/////////////////////////////////////////////////////////////////////
385// hwbinder.stubs provides APIs required for building HIDL Java
386// libraries.
387/////////////////////////////////////////////////////////////////////
388
389droidstubs {
390 name: "hwbinder-stubs-docs",
391 srcs: [
392 "core/java/android/os/HidlSupport.java",
393 "core/java/android/annotation/IntDef.java",
394 "core/java/android/annotation/IntRange.java",
395 "core/java/android/annotation/NonNull.java",
396 "core/java/android/annotation/SystemApi.java",
397 "core/java/android/os/HidlMemory.java",
398 "core/java/android/os/HwBinder.java",
399 "core/java/android/os/HwBlob.java",
400 "core/java/android/os/HwParcel.java",
401 "core/java/android/os/IHwBinder.java",
402 "core/java/android/os/IHwInterface.java",
403 "core/java/android/os/DeadObjectException.java",
404 "core/java/android/os/DeadSystemException.java",
405 "core/java/android/os/NativeHandle.java",
406 "core/java/android/os/RemoteException.java",
407 "core/java/android/util/AndroidException.java",
408 ],
409 installable: false,
410 sdk_version: "core_platform",
411 annotations_enabled: true,
Anton Hanssonf68ddea2020-05-02 17:49:26 +0100412 previous_api: ":android.api.public.latest",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900413 merge_annotations_dirs: [
414 "metalava-manual",
415 ],
Anton Hansson81969c22020-02-03 20:45:56 +0000416 args: priv_apps,
Jiyong Park7fb4b182019-12-20 14:35:43 +0900417}
418
419java_library_static {
420 name: "hwbinder.stubs",
421 sdk_version: "core_current",
422 srcs: [
423 ":hwbinder-stubs-docs",
424 ],
425}
426
427/////////////////////////////////////////////////////////////////////
Jiyong Park7fb4b182019-12-20 14:35:43 +0900428// api/*-current.txt files for use by modules in other directories
429// like the CTS test
430/////////////////////////////////////////////////////////////////////
431
432filegroup {
433 name: "frameworks-base-api-current.txt",
434 srcs: [
435 "api/current.txt",
436 ],
437}
438
439filegroup {
440 name: "frameworks-base-api-system-current.txt",
441 srcs: [
442 "api/system-current.txt",
443 ],
444}
445
446filegroup {
447 name: "frameworks-base-api-system-removed.txt",
448 srcs: [
449 "api/system-removed.txt",
450 ],
451}