blob: 170cac43764a0f7c3beee2c00b3ca667732bd102 [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 Hansson822cdb32020-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 Duffin37c10f02020-03-26 15:33:48 +000050 ":art-module-public-api-stubs-source",
Paul Duffinf0255012020-04-09 10:04:14 +010051 ":conscrypt.module.public.api.stubs.source",
Paul Duffin37c10f02020-03-26 15:33:48 +000052 ":android_icu4j_public_api_files",
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 Park7fb4b182019-12-20 14:35:43 +090058 libs: ["framework-internal-utils"],
59 installable: false,
60 annotations_enabled: true,
Anton Hansson48ee95e2020-05-02 17:49:26 +010061 previous_api: ":android.api.public.latest",
Jiyong Park7fb4b182019-12-20 14:35:43 +090062 merge_annotations_dirs: [
63 "metalava-manual",
64 ],
Aurimas Liutikas6bb95ad2020-03-12 17:06:12 -070065 api_levels_annotations_enabled: false,
Jiyong Park7fb4b182019-12-20 14:35:43 +090066 filter_packages: packages_to_document,
67}
68
Jiyong Parke3095162019-12-20 15:30:28 +090069stubs_defaults {
Anton Hansson822cdb32020-03-06 17:16:06 +000070 name: "metalava-full-api-stubs-default",
71 defaults: ["metalava-base-api-stubs-default"],
Jiyong Parke3095162019-12-20 15:30:28 +090072 srcs: [":framework-updatable-sources"],
73 sdk_version: "core_platform",
74}
75
Anton Hansson822cdb32020-03-06 17:16:06 +000076stubs_defaults {
77 name: "metalava-non-updatable-api-stubs-default",
78 defaults: ["metalava-base-api-stubs-default"],
Anton Hansson92d79fd2020-03-20 09:12:52 +000079 sdk_version: "core_platform",
Anton Hansson394febc2020-04-14 16:35:36 +010080 // There are a few classes from modules used as type arguments that
81 // need to be resolved by metalava. For now, we can use a previously
82 // finalized stub library to resolve them. If a new class gets added,
83 // this may be need to be revisited to use a manually maintained stub
84 // library with empty classes in order to resolve those references.
85 libs: ["sdk_system_29_android"],
Anton Hansson92d79fd2020-03-20 09:12:52 +000086 aidl: {
Anton Hansson394febc2020-04-14 16:35:36 +010087 local_include_dirs: ["apex/media/aidl/stable"],
Anton Hansson92d79fd2020-03-20 09:12:52 +000088 },
Anton Hansson822cdb32020-03-06 17:16:06 +000089}
90
Jiyong Park7fb4b182019-12-20 14:35:43 +090091/////////////////////////////////////////////////////////////////////
92// *-api-stubs-docs modules providing source files for the stub libraries
93/////////////////////////////////////////////////////////////////////
94
Jiyong Parke3095162019-12-20 15:30:28 +090095// api-stubs-docs, system-api-stubs-docs, and test-api-stubs-docs have APIs
96// from the non-updatable part of the platform as well as from the updatable
97// modules
Jiyong Park7fb4b182019-12-20 14:35:43 +090098droidstubs {
99 name: "api-stubs-docs",
Anton Hansson822cdb32020-03-06 17:16:06 +0000100 defaults: ["metalava-full-api-stubs-default"],
Artur Satayev7e7fdde2020-03-25 16:45:56 +0000101 removed_dex_api_filename: "removed-dex.txt",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900102 arg_files: [
103 "core/res/AndroidManifest.xml",
104 ],
105 args: metalava_framework_docs_args,
106 check_api: {
107 current: {
108 api_file: "api/current.txt",
109 removed_api_file: "api/removed.txt",
110 },
111 last_released: {
Anton Hansson48ee95e2020-05-02 17:49:26 +0100112 api_file: ":android.api.public.latest",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900113 removed_api_file: "api/removed.txt",
114 baseline_file: ":public-api-incompatibilities-with-last-released",
115 },
116 api_lint: {
117 enabled: true,
Anton Hansson48ee95e2020-05-02 17:49:26 +0100118 new_since: ":android.api.public.latest",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900119 baseline_file: "api/lint-baseline.txt",
120 },
121 },
Anton Hanssond9a3fee2020-03-23 18:08:55 +0000122 dist: {
123 targets: ["sdk", "win_sdk"],
124 dir: "apistubs/android/public/api",
125 dest: "android.txt",
126 },
Jiyong Park7fb4b182019-12-20 14:35:43 +0900127 jdiff_enabled: true,
128}
129
Anton Hansson81969c22020-02-03 20:45:56 +0000130priv_apps = " " +
131 "--show-annotation android.annotation.SystemApi\\(" +
132 "client=android.annotation.SystemApi.Client.PRIVILEGED_APPS" +
133 "\\) "
134
135module_libs = " " +
136 " --show-annotation android.annotation.SystemApi\\(" +
137 "client=android.annotation.SystemApi.Client.MODULE_LIBRARIES" +
138 "\\) "
139
Jiyong Park7fb4b182019-12-20 14:35:43 +0900140droidstubs {
141 name: "system-api-stubs-docs",
Anton Hansson822cdb32020-03-06 17:16:06 +0000142 defaults: ["metalava-full-api-stubs-default"],
Artur Satayev7e7fdde2020-03-25 16:45:56 +0000143 removed_dex_api_filename: "system-removed-dex.txt",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900144 arg_files: [
145 "core/res/AndroidManifest.xml",
146 ],
Anton Hansson81969c22020-02-03 20:45:56 +0000147 args: metalava_framework_docs_args + priv_apps,
Jiyong Park7fb4b182019-12-20 14:35:43 +0900148 check_api: {
149 current: {
150 api_file: "api/system-current.txt",
151 removed_api_file: "api/system-removed.txt",
152 },
153 last_released: {
Anton Hansson48ee95e2020-05-02 17:49:26 +0100154 api_file: ":android.api.system.latest",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900155 removed_api_file: "api/system-removed.txt",
156 baseline_file: ":system-api-incompatibilities-with-last-released"
157 },
158 api_lint: {
159 enabled: true,
Anton Hansson48ee95e2020-05-02 17:49:26 +0100160 new_since: ":android.api.system.latest",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900161 baseline_file: "api/system-lint-baseline.txt",
162 },
163 },
Anton Hanssond9a3fee2020-03-23 18:08:55 +0000164 dist: {
165 targets: ["sdk", "win_sdk"],
166 dir: "apistubs/android/system/api",
167 dest: "android.txt",
168 },
Jiyong Park7fb4b182019-12-20 14:35:43 +0900169 jdiff_enabled: true,
170}
171
172droidstubs {
173 name: "test-api-stubs-docs",
Anton Hansson822cdb32020-03-06 17:16:06 +0000174 defaults: ["metalava-full-api-stubs-default"],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900175 arg_files: [
176 "core/res/AndroidManifest.xml",
177 ],
178 args: metalava_framework_docs_args + " --show-annotation android.annotation.TestApi",
179 check_api: {
180 current: {
181 api_file: "api/test-current.txt",
182 removed_api_file: "api/test-removed.txt",
183 },
184 api_lint: {
185 enabled: true,
186 baseline_file: "api/test-lint-baseline.txt",
187 },
188 },
Anton Hanssond9a3fee2020-03-23 18:08:55 +0000189 dist: {
190 targets: ["sdk", "win_sdk"],
191 dir: "apistubs/android/test/api",
192 dest: "android.txt",
193 },
Jiyong Park7fb4b182019-12-20 14:35:43 +0900194}
195
196/////////////////////////////////////////////////////////////////////
Jiyong Parke3095162019-12-20 15:30:28 +0900197// Following droidstubs modules are for extra APIs for modules.
198// The framework currently have two more API surfaces for modules:
199// @SystemApi(client=MODULE_APPS) and @SystemApi(client=MODULE_LIBRARIES)
200/////////////////////////////////////////////////////////////////////
201
Anton Hansson81969c22020-02-03 20:45:56 +0000202// TODO(b/146727827) remove the *-api module when we can teach metalava
Jiyong Parke3095162019-12-20 15:30:28 +0900203// about the relationship among the API surfaces. Currently, these modules are only to generate
204// the API signature files and ensure that the APIs evolve in a backwards compatible manner.
205// They however are NOT used for building the API stub.
Jiyong Parke3095162019-12-20 15:30:28 +0900206
207droidstubs {
208 name: "module-lib-api",
Anton Hansson822cdb32020-03-06 17:16:06 +0000209 defaults: ["metalava-full-api-stubs-default"],
Jiyong Parke3095162019-12-20 15:30:28 +0900210 arg_files: ["core/res/AndroidManifest.xml"],
Anton Hansson81969c22020-02-03 20:45:56 +0000211 args: metalava_framework_docs_args + module_libs,
Jiyong Parke3095162019-12-20 15:30:28 +0900212 check_api: {
213 current: {
214 api_file: "api/module-lib-current.txt",
215 removed_api_file: "api/module-lib-removed.txt",
216 },
Anton Hansson79e35c32020-02-11 14:36:40 +0000217 last_released: {
Anton Hansson48ee95e2020-05-02 17:49:26 +0100218 api_file: ":android.api.module-lib.latest",
Anton Hansson79e35c32020-02-11 14:36:40 +0000219 removed_api_file: "api/module-lib-removed.txt",
220 baseline_file: ":module-lib-api-incompatibilities-with-last-released"
221 },
222 api_lint: {
223 enabled: true,
Anton Hansson48ee95e2020-05-02 17:49:26 +0100224 new_since: ":android.api.module-lib.latest",
Anton Hansson79e35c32020-02-11 14:36:40 +0000225 baseline_file: "api/module-lib-lint-baseline.txt",
226 },
Jiyong Parke3095162019-12-20 15:30:28 +0900227 },
Anton Hanssond9a3fee2020-03-23 18:08:55 +0000228 dist: {
229 targets: ["sdk", "win_sdk"],
230 dir: "apistubs/android/module-lib/api",
231 dest: "android.txt",
232 },
Jiyong Parke3095162019-12-20 15:30:28 +0900233}
234
Anton Hansson81969c22020-02-03 20:45:56 +0000235
236// The following droidstub module generates source files for the API stub library for
237// modules. Note that it not only includes its own APIs but also other APIs that have
238// narrower scope (all @SystemApis, not just the ones with 'client=MODULE_LIBRARIES').
Jiyong Parke3095162019-12-20 15:30:28 +0900239
240droidstubs {
241 name: "module-lib-api-stubs-docs",
Anton Hansson822cdb32020-03-06 17:16:06 +0000242 defaults: ["metalava-non-updatable-api-stubs-default"],
Jiyong Parke3095162019-12-20 15:30:28 +0900243 arg_files: ["core/res/AndroidManifest.xml"],
Anton Hansson81969c22020-02-03 20:45:56 +0000244 args: metalava_framework_docs_args + priv_apps + module_libs,
Jiyong Parke3095162019-12-20 15:30:28 +0900245}
246
247/////////////////////////////////////////////////////////////////////
Jiyong Park7fb4b182019-12-20 14:35:43 +0900248// android_*_stubs_current modules are the stubs libraries compiled
249// from *-api-stubs-docs
250/////////////////////////////////////////////////////////////////////
251
252java_defaults {
Anton Hansson87c7d282020-04-09 14:16:37 +0100253 name: "android_defaults_stubs_current",
Anton Hansson08b48bb2020-02-08 20:43:19 +0000254 libs: [ "stub-annotations" ],
255 static_libs: [ "private-stub-annotations-jar" ],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900256 errorprone: {
257 javacflags: [
258 "-XepDisableAllChecks",
259 ],
260 },
Anton Hansson87c7d282020-04-09 14:16:37 +0100261 java_resources: [":notices-for-framework-stubs"],
262 sdk_version: "none",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900263 system_modules: "none",
264 java_version: "1.8",
265 compile_dex: true,
266}
267
268java_library_static {
269 name: "android_stubs_current",
Anton Hansson08b48bb2020-02-08 20:43:19 +0000270 srcs: [ ":api-stubs-docs" ],
Anton Hansson87c7d282020-04-09 14:16:37 +0100271 defaults: ["android_defaults_stubs_current"],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900272}
273
274java_library_static {
275 name: "android_system_stubs_current",
Anton Hansson08b48bb2020-02-08 20:43:19 +0000276 srcs: [ ":system-api-stubs-docs" ],
Anton Hansson87c7d282020-04-09 14:16:37 +0100277 defaults: ["android_defaults_stubs_current"],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900278}
279
280java_library_static {
281 name: "android_test_stubs_current",
Anton Hansson08b48bb2020-02-08 20:43:19 +0000282 srcs: [ ":test-api-stubs-docs" ],
Anton Hansson87c7d282020-04-09 14:16:37 +0100283 defaults: ["android_defaults_stubs_current"],
Jiyong Parke3095162019-12-20 15:30:28 +0900284}
285
286java_library_static {
Anton Hansson1b9cf092020-01-30 12:09:02 +0000287 name: "android_module_lib_stubs_current",
Anton Hansson08b48bb2020-02-08 20:43:19 +0000288 srcs: [ ":module-lib-api-stubs-docs" ],
Anton Hansson87c7d282020-04-09 14:16:37 +0100289 defaults: ["android_defaults_stubs_current"],
Anton Hansson394febc2020-04-14 16:35:36 +0100290 libs: ["sdk_system_29_android"],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900291}
292
Jiyong Park7fb4b182019-12-20 14:35:43 +0900293/////////////////////////////////////////////////////////////////////
294// hwbinder.stubs provides APIs required for building HIDL Java
295// libraries.
296/////////////////////////////////////////////////////////////////////
297
298droidstubs {
299 name: "hwbinder-stubs-docs",
300 srcs: [
301 "core/java/android/os/HidlSupport.java",
302 "core/java/android/annotation/IntDef.java",
303 "core/java/android/annotation/IntRange.java",
304 "core/java/android/annotation/NonNull.java",
305 "core/java/android/annotation/SystemApi.java",
306 "core/java/android/os/HidlMemory.java",
307 "core/java/android/os/HwBinder.java",
308 "core/java/android/os/HwBlob.java",
309 "core/java/android/os/HwParcel.java",
310 "core/java/android/os/IHwBinder.java",
311 "core/java/android/os/IHwInterface.java",
312 "core/java/android/os/DeadObjectException.java",
313 "core/java/android/os/DeadSystemException.java",
314 "core/java/android/os/NativeHandle.java",
315 "core/java/android/os/RemoteException.java",
316 "core/java/android/util/AndroidException.java",
317 ],
318 installable: false,
319 sdk_version: "core_platform",
320 annotations_enabled: true,
Anton Hansson48ee95e2020-05-02 17:49:26 +0100321 previous_api: ":android.api.public.latest",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900322 merge_annotations_dirs: [
323 "metalava-manual",
324 ],
Anton Hansson81969c22020-02-03 20:45:56 +0000325 args: priv_apps,
Jiyong Park7fb4b182019-12-20 14:35:43 +0900326}
327
328java_library_static {
329 name: "hwbinder.stubs",
330 sdk_version: "core_current",
331 srcs: [
332 ":hwbinder-stubs-docs",
333 ],
334}
335
336/////////////////////////////////////////////////////////////////////
Jiyong Park7fb4b182019-12-20 14:35:43 +0900337// api/*-current.txt files for use by modules in other directories
338// like the CTS test
339/////////////////////////////////////////////////////////////////////
340
341filegroup {
342 name: "frameworks-base-api-current.txt",
343 srcs: [
344 "api/current.txt",
345 ],
346}
347
348filegroup {
349 name: "frameworks-base-api-system-current.txt",
350 srcs: [
351 "api/system-current.txt",
352 ],
353}
354
355filegroup {
356 name: "frameworks-base-api-system-removed.txt",
357 srcs: [
358 "api/system-removed.txt",
359 ],
360}