blob: aa39824e86148d1801e51285419f4254494f6dc9 [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 Duffin404b26a2020-09-16 14:26:47 +010050 ":art.module.public.api{.public.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 ],
Chen Xu546ce5e2020-01-10 08:38:31 -080054 // TODO(b/147699819): remove below aidl includes.
55 aidl: {
56 local_include_dirs: ["telephony/java"],
57 },
Jiyong Parkc0f8a282020-09-29 13:43:00 +090058 // These are libs from framework-internal-utils that are required (i.e. being referenced)
59 // from framework-non-updatable-sources. Add more here when there's a need.
60 // DO NOT add the entire framework-internal-utils. It might cause unnecessary circular
61 // dependencies gets bigger.
62 libs: [
63 "android.hardware.cas-V1.2-java",
64 "android.hardware.health-V1.0-java-constants",
65 "android.hardware.radio-V1.5-java",
66 "android.hardware.thermal-V1.0-java-constants",
67 "android.hardware.thermal-V2.0-java",
68 "android.hardware.tv.input-V1.0-java-constants",
69 "android.hardware.tv.tuner-V1.0-java-constants",
70 "android.hardware.usb-V1.0-java-constants",
71 "android.hardware.usb-V1.1-java-constants",
72 "android.hardware.usb.gadget-V1.0-java",
73 "android.hardware.vibrator-V1.3-java",
74 "framework-protos",
75 ],
Anton Hansson35146892020-10-26 10:27:57 +000076 high_mem: true, // Lots of sources => high memory use, see b/170701554
Jiyong Park7fb4b182019-12-20 14:35:43 +090077 installable: false,
78 annotations_enabled: true,
Anton Hanssonf68ddea2020-05-02 17:49:26 +010079 previous_api: ":android.api.public.latest",
Jiyong Park7fb4b182019-12-20 14:35:43 +090080 merge_annotations_dirs: [
81 "metalava-manual",
82 ],
Aurimas Liutikas94bac9c2020-03-12 17:06:12 -070083 api_levels_annotations_enabled: false,
Jiyong Park7fb4b182019-12-20 14:35:43 +090084 filter_packages: packages_to_document,
85}
86
Jiyong Park2e6cdcc2019-12-20 15:30:28 +090087stubs_defaults {
Anton Hansson537564e2020-03-06 17:16:06 +000088 name: "metalava-full-api-stubs-default",
89 defaults: ["metalava-base-api-stubs-default"],
Anton Hanssone01390c2020-05-07 12:06:00 +010090 srcs: [
Paul Duffine55d4e32020-05-14 17:55:46 +010091 ":conscrypt.module.public.api{.public.stubs.source}",
Anton Hanssone01390c2020-05-07 12:06:00 +010092 ":framework-updatable-sources",
93 ],
Jiyong Park2e6cdcc2019-12-20 15:30:28 +090094 sdk_version: "core_platform",
95}
96
Anton Hansson537564e2020-03-06 17:16:06 +000097stubs_defaults {
98 name: "metalava-non-updatable-api-stubs-default",
99 defaults: ["metalava-base-api-stubs-default"],
Anton Hanssone53bec02020-03-20 09:12:52 +0000100 sdk_version: "core_platform",
Anton Hanssonebb26a32020-04-14 16:35:36 +0100101 // There are a few classes from modules used as type arguments that
102 // need to be resolved by metalava. For now, we can use a previously
103 // finalized stub library to resolve them. If a new class gets added,
104 // this may be need to be revisited to use a manually maintained stub
105 // library with empty classes in order to resolve those references.
Anton Hansson33ea9992020-04-09 14:16:37 +0100106 libs: ["sdk_system_30_android"],
Anton Hanssonebb26a32020-04-14 16:35:36 +0100107 aidl: {
Anton Hansson394febc2020-04-14 16:35:36 +0100108 local_include_dirs: ["apex/media/aidl/stable"],
Anton Hanssonebb26a32020-04-14 16:35:36 +0100109 },
Anton Hansson537564e2020-03-06 17:16:06 +0000110}
111
Jiyong Park7fb4b182019-12-20 14:35:43 +0900112/////////////////////////////////////////////////////////////////////
113// *-api-stubs-docs modules providing source files for the stub libraries
114/////////////////////////////////////////////////////////////////////
115
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900116// api-stubs-docs, system-api-stubs-docs, and test-api-stubs-docs have APIs
117// from the non-updatable part of the platform as well as from the updatable
118// modules
Jiyong Park7fb4b182019-12-20 14:35:43 +0900119droidstubs {
120 name: "api-stubs-docs",
Anton Hansson537564e2020-03-06 17:16:06 +0000121 defaults: ["metalava-full-api-stubs-default"],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900122 arg_files: [
123 "core/res/AndroidManifest.xml",
124 ],
125 args: metalava_framework_docs_args,
126 check_api: {
127 current: {
128 api_file: "api/current.txt",
129 removed_api_file: "api/removed.txt",
130 },
131 last_released: {
Anton Hanssonf68ddea2020-05-02 17:49:26 +0100132 api_file: ":android.api.public.latest",
Anton Hansson960c6752020-05-02 18:00:30 +0100133 removed_api_file: ":removed.api.public.latest",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900134 baseline_file: ":public-api-incompatibilities-with-last-released",
135 },
136 api_lint: {
137 enabled: true,
Anton Hanssonf68ddea2020-05-02 17:49:26 +0100138 new_since: ":android.api.public.latest",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900139 baseline_file: "api/lint-baseline.txt",
140 },
141 },
Jiyong Park7fb4b182019-12-20 14:35:43 +0900142}
143
Anton Hansson7f6823e2020-06-04 15:09:36 +0100144droidstubs {
145 name: "api-stubs-docs-non-updatable",
146 defaults: ["metalava-non-updatable-api-stubs-default"],
147 arg_files: ["core/res/AndroidManifest.xml"],
148 args: metalava_framework_docs_args,
149 check_api: {
150 current: {
Anton Hansson7bfceb82020-10-29 18:59:10 +0000151 api_file: "core/api/current.txt",
152 removed_api_file: "core/api/removed.txt",
Anton Hansson7f6823e2020-06-04 15:09:36 +0100153 },
Anton Hansson3258a472020-10-05 16:23:27 +0100154 last_released: {
155 api_file: ":android-non-updatable.api.public.latest",
156 removed_api_file: ":android-non-updatable-removed.api.public.latest",
157 baseline_file: ":public-api-incompatibilities-with-last-released",
158 },
Anton Hansson33ea9992020-04-09 14:16:37 +0100159 api_lint: {
160 enabled: true,
161 new_since: ":android-non-updatable.api.public.latest",
162 },
Anton Hansson7f6823e2020-06-04 15:09:36 +0100163 },
164}
165
Anton Hansson81969c22020-02-03 20:45:56 +0000166priv_apps = " " +
167 "--show-annotation android.annotation.SystemApi\\(" +
168 "client=android.annotation.SystemApi.Client.PRIVILEGED_APPS" +
169 "\\) "
170
171module_libs = " " +
172 " --show-annotation android.annotation.SystemApi\\(" +
173 "client=android.annotation.SystemApi.Client.MODULE_LIBRARIES" +
Makoto Onukia13287f2020-07-10 12:05:21 -0700174 "\\)" +
175 " --show-for-stub-purposes-annotation android.annotation.SystemApi\\(" +
176 "client=android.annotation.SystemApi.Client.PRIVILEGED_APPS" +
Anton Hansson81969c22020-02-03 20:45:56 +0000177 "\\) "
178
Jiyong Park7fb4b182019-12-20 14:35:43 +0900179droidstubs {
Anton Hansson7f6823e2020-06-04 15:09:36 +0100180 name: "system-api-stubs-docs-non-updatable",
181 defaults: ["metalava-non-updatable-api-stubs-default"],
182 arg_files: ["core/res/AndroidManifest.xml"],
183 args: metalava_framework_docs_args + priv_apps,
184 check_api: {
185 current: {
Anton Hansson7bfceb82020-10-29 18:59:10 +0000186 api_file: "core/api/system-current.txt",
187 removed_api_file: "core/api/system-removed.txt",
Anton Hansson7f6823e2020-06-04 15:09:36 +0100188 },
Anton Hansson3258a472020-10-05 16:23:27 +0100189 last_released: {
190 api_file: ":android-non-updatable.api.system.latest",
191 removed_api_file: ":android-non-updatable-removed.api.system.latest",
192 baseline_file: ":system-api-incompatibilities-with-last-released"
193 },
Anton Hansson33ea9992020-04-09 14:16:37 +0100194 api_lint: {
195 enabled: true,
196 new_since: ":android-non-updatable.api.system.latest",
Anton Hansson7bfceb82020-10-29 18:59:10 +0000197 baseline_file: "core/api/system-lint-baseline.txt",
Anton Hansson33ea9992020-04-09 14:16:37 +0100198 },
Anton Hansson7f6823e2020-06-04 15:09:36 +0100199 },
200}
201
202droidstubs {
Anton Hansson552ba2c2020-11-05 10:45:13 +0000203 name: "test-api-stubs-docs-non-updatable",
Anton Hansson7110ae72020-10-15 17:23:35 +0100204 defaults: ["metalava-non-updatable-api-stubs-default"],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900205 arg_files: [
206 "core/res/AndroidManifest.xml",
207 ],
Anton Hansson84ffba22020-10-09 10:13:51 +0100208 args: metalava_framework_docs_args
209 + " --show-annotation android.annotation.TestApi"
210 + " --show-for-stub-purposes-annotation android.annotation.SystemApi\\("
211 + "client=android.annotation.SystemApi.Client.PRIVILEGED_APPS"
212 + "\\)",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900213 check_api: {
214 current: {
Anton Hansson552ba2c2020-11-05 10:45:13 +0000215 api_file: "core/api/test-current.txt",
216 removed_api_file: "core/api/test-removed.txt",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900217 },
218 api_lint: {
219 enabled: true,
Anton Hansson552ba2c2020-11-05 10:45:13 +0000220 baseline_file: "core/api/test-lint-baseline.txt",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900221 },
222 },
Anton Hanssonba367d32020-03-23 18:08:55 +0000223 dist: {
224 targets: ["sdk", "win_sdk"],
225 dir: "apistubs/android/test/api",
226 dest: "android.txt",
227 },
Jiyong Park7fb4b182019-12-20 14:35:43 +0900228}
229
230/////////////////////////////////////////////////////////////////////
Anton Hansson43cc8bf2020-10-29 18:56:10 +0000231// Following droidstub module for extra APIs for modules,
Makoto Onukia13287f2020-07-10 12:05:21 -0700232// namely @SystemApi(client=MODULE_LIBRARIES) APIs.
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900233/////////////////////////////////////////////////////////////////////
234
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900235droidstubs {
Anton Hansson7f6823e2020-06-04 15:09:36 +0100236 name: "module-lib-api-stubs-docs-non-updatable",
237 defaults: ["metalava-non-updatable-api-stubs-default"],
238 arg_files: ["core/res/AndroidManifest.xml"],
Makoto Onuki8c61de62020-07-15 10:38:04 -0700239 args: metalava_framework_docs_args + priv_apps + module_libs,
Anton Hansson7f6823e2020-06-04 15:09:36 +0100240 check_api: {
241 current: {
Anton Hansson7bfceb82020-10-29 18:59:10 +0000242 api_file: "core/api/module-lib-current.txt",
243 removed_api_file: "core/api/module-lib-removed.txt",
Anton Hansson7f6823e2020-06-04 15:09:36 +0100244 },
Anton Hanssonc3ef1f562020-10-07 14:55:36 +0100245 last_released: {
246 api_file: ":android-non-updatable.api.module-lib.latest",
247 removed_api_file: ":android-non-updatable-removed.api.module-lib.latest",
248 },
Anton Hansson33ea9992020-04-09 14:16:37 +0100249 api_lint: {
250 enabled: true,
251 new_since: ":android-non-updatable.api.module-lib.latest",
252 },
Anton Hansson7f6823e2020-06-04 15:09:36 +0100253 },
254}
Anton Hansson81969c22020-02-03 20:45:56 +0000255
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900256/////////////////////////////////////////////////////////////////////
Jiyong Park7fb4b182019-12-20 14:35:43 +0900257// android_*_stubs_current modules are the stubs libraries compiled
258// from *-api-stubs-docs
259/////////////////////////////////////////////////////////////////////
260
261java_defaults {
Anton Hanssonfbd32f32020-04-09 14:16:37 +0100262 name: "android_defaults_stubs_current",
Anton Hansson42afd612020-02-08 20:43:19 +0000263 libs: [ "stub-annotations" ],
Paul Duffina281e922020-03-25 10:13:33 +0000264 static_libs: [
Paul Duffina281e922020-03-25 10:13:33 +0000265 // License notices from art module
266 "art-notices-for-framework-stubs-jar",
Anton Hanssoncf42e982020-08-13 19:40:13 +0100267 "framework-res-package-jar", // Export package of framework-res
Paul Duffina281e922020-03-25 10:13:33 +0000268 ],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900269 errorprone: {
270 javacflags: [
271 "-XepDisableAllChecks",
272 ],
273 },
Anton Hanssonfbd32f32020-04-09 14:16:37 +0100274 sdk_version: "none",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900275 system_modules: "none",
276 java_version: "1.8",
277 compile_dex: true,
278}
279
Anton Hanssona9205502020-07-15 13:36:34 +0100280java_defaults {
281 name: "android_stubs_dists_default",
282 dist: {
283 targets: ["sdk", "win_sdk"],
284 tag: ".jar",
285 dest: "android.jar",
286 },
287}
288
Jiyong Park7fb4b182019-12-20 14:35:43 +0900289java_library_static {
Anton Hansson3a8e0362020-11-03 19:35:56 +0000290 name: "android_stubs_current",
Anton Hansson912622f2020-04-09 14:16:37 +0100291 srcs: [ ":api-stubs-docs-non-updatable" ],
292 static_libs: [
293 "conscrypt.module.public.api.stubs",
Paul Duffinabebc6a2020-05-31 11:35:50 +0100294 "framework-media.stubs",
295 "framework-mediaprovider.stubs",
296 "framework-permission.stubs",
Anton Hansson912622f2020-04-09 14:16:37 +0100297 "framework-sdkextensions.stubs",
Paul Duffinabebc6a2020-05-31 11:35:50 +0100298 "framework-statsd.stubs",
Anton Hansson912622f2020-04-09 14:16:37 +0100299 "framework-tethering.stubs",
Paul Duffinabebc6a2020-05-31 11:35:50 +0100300 "framework-wifi.stubs",
Anton Hansson33ea9992020-04-09 14:16:37 +0100301 "private-stub-annotations-jar",
Anton Hansson912622f2020-04-09 14:16:37 +0100302 ],
Anton Hanssona9205502020-07-15 13:36:34 +0100303 defaults: [
304 "android_defaults_stubs_current",
305 "android_stubs_dists_default",
306 ],
307 dist: {
308 dir: "apistubs/android/system",
309 },
310 dists: [
311 {
312 // Legacy dist path
313 targets: ["sdk", "win_sdk"],
314 tag: ".jar",
315 dest: "android_system.jar",
316 },
317 ],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900318}
319
320java_library_static {
Anton Hansson3a8e0362020-11-03 19:35:56 +0000321 name: "android_system_stubs_current",
Anton Hansson912622f2020-04-09 14:16:37 +0100322 srcs: [ ":system-api-stubs-docs-non-updatable" ],
323 static_libs: [
324 "conscrypt.module.public.api.stubs",
Paul Duffinabebc6a2020-05-31 11:35:50 +0100325 "framework-media.stubs.system",
326 "framework-mediaprovider.stubs.system",
327 "framework-permission.stubs.system",
Anton Hansson912622f2020-04-09 14:16:37 +0100328 "framework-sdkextensions.stubs.system",
Paul Duffinabebc6a2020-05-31 11:35:50 +0100329 "framework-statsd.stubs.system",
Anton Hansson912622f2020-04-09 14:16:37 +0100330 "framework-tethering.stubs.system",
Paul Duffinabebc6a2020-05-31 11:35:50 +0100331 "framework-wifi.stubs.system",
Anton Hansson33ea9992020-04-09 14:16:37 +0100332 "private-stub-annotations-jar",
Anton Hansson912622f2020-04-09 14:16:37 +0100333 ],
334 defaults: ["android_defaults_stubs_current"],
335}
336
337java_library_static {
Jiyong Park7fb4b182019-12-20 14:35:43 +0900338 name: "android_test_stubs_current",
Anton Hansson552ba2c2020-11-05 10:45:13 +0000339 srcs: [ ":test-api-stubs-docs-non-updatable" ],
Anton Hansson7110ae72020-10-15 17:23:35 +0100340 static_libs: [
341 // Modules do not have test APIs, but we want to include their SystemApis, like we include
342 // the SystemApi of framework-non-updatable-sources.
343 "conscrypt.module.public.api.stubs",
344 "framework-media.stubs.system",
345 "framework-mediaprovider.stubs.system",
346 "framework-permission.stubs.system",
347 "framework-sdkextensions.stubs.system",
348 "framework-statsd.stubs.system",
349 "framework-tethering.stubs.system",
350 "framework-wifi.stubs.system",
351 "private-stub-annotations-jar",
352 ],
Anton Hanssona9205502020-07-15 13:36:34 +0100353 defaults: [
354 "android_defaults_stubs_current",
355 "android_stubs_dists_default",
356 ],
357 dist: {
358 dir: "apistubs/android/test",
359 },
360 dists: [
361 {
362 // Legacy dist path
363 targets: ["sdk", "win_sdk"],
364 tag: ".jar",
365 dest: "android_test.jar",
366 },
367 ],
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900368}
369
370java_library_static {
Anton Hansson9c4bbe92020-01-30 12:09:02 +0000371 name: "android_module_lib_stubs_current",
Makoto Onuki8c61de62020-07-15 10:38:04 -0700372 srcs: [ ":module-lib-api-stubs-docs-non-updatable" ],
Anton Hanssona9205502020-07-15 13:36:34 +0100373 defaults: [
374 "android_defaults_stubs_current",
375 "android_stubs_dists_default",
376 ],
Anton Hanssonebb26a32020-04-14 16:35:36 +0100377 libs: ["sdk_system_29_android"],
Anton Hanssona9205502020-07-15 13:36:34 +0100378 dist: {
379 dir: "apistubs/android/module-lib",
380 },
Jiyong Park7fb4b182019-12-20 14:35:43 +0900381}
382
Anton Hansson7f6823e2020-06-04 15:09:36 +0100383java_library_static {
384 name: "android_non_updatable_stubs_current",
385 srcs: [":api-stubs-docs-non-updatable"],
386 defaults: ["android_defaults_stubs_current"],
387 libs: ["sdk_system_29_android"],
388}
389
390java_library_static {
391 name: "android_system_non_updatable_stubs_current",
392 srcs: [":system-api-stubs-docs-non-updatable"],
393 defaults: ["android_defaults_stubs_current"],
394 libs: ["sdk_system_29_android"],
395}
396
Jiyong Park7fb4b182019-12-20 14:35:43 +0900397/////////////////////////////////////////////////////////////////////
398// hwbinder.stubs provides APIs required for building HIDL Java
399// libraries.
400/////////////////////////////////////////////////////////////////////
401
402droidstubs {
403 name: "hwbinder-stubs-docs",
404 srcs: [
405 "core/java/android/os/HidlSupport.java",
406 "core/java/android/annotation/IntDef.java",
407 "core/java/android/annotation/IntRange.java",
408 "core/java/android/annotation/NonNull.java",
409 "core/java/android/annotation/SystemApi.java",
410 "core/java/android/os/HidlMemory.java",
411 "core/java/android/os/HwBinder.java",
412 "core/java/android/os/HwBlob.java",
413 "core/java/android/os/HwParcel.java",
414 "core/java/android/os/IHwBinder.java",
415 "core/java/android/os/IHwInterface.java",
416 "core/java/android/os/DeadObjectException.java",
417 "core/java/android/os/DeadSystemException.java",
418 "core/java/android/os/NativeHandle.java",
419 "core/java/android/os/RemoteException.java",
420 "core/java/android/util/AndroidException.java",
421 ],
422 installable: false,
423 sdk_version: "core_platform",
424 annotations_enabled: true,
Anton Hanssonf68ddea2020-05-02 17:49:26 +0100425 previous_api: ":android.api.public.latest",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900426 merge_annotations_dirs: [
427 "metalava-manual",
428 ],
Anton Hansson81969c22020-02-03 20:45:56 +0000429 args: priv_apps,
Jiyong Park7fb4b182019-12-20 14:35:43 +0900430}
431
432java_library_static {
433 name: "hwbinder.stubs",
434 sdk_version: "core_current",
435 srcs: [
436 ":hwbinder-stubs-docs",
437 ],
438}