blob: 270c160dc5e93647679f115a4a80abb7b7577942 [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",
50 ":core-current-stubs-source",
51 ":core_public_api_files",
Jiyong Park7fb4b182019-12-20 14:35:43 +090052 ],
Chen Xu546ce5e2020-01-10 08:38:31 -080053 // TODO(b/147699819): remove below aidl includes.
54 aidl: {
55 local_include_dirs: ["telephony/java"],
56 },
Jiyong Park7fb4b182019-12-20 14:35:43 +090057 libs: ["framework-internal-utils"],
58 installable: false,
59 annotations_enabled: true,
60 previous_api: ":last-released-public-api",
61 merge_annotations_dirs: [
62 "metalava-manual",
63 ],
Aurimas Liutikas6bb95ad2020-03-12 17:06:12 -070064 api_levels_annotations_enabled: false,
Jiyong Park7fb4b182019-12-20 14:35:43 +090065 filter_packages: packages_to_document,
66}
67
Jiyong Parke3095162019-12-20 15:30:28 +090068stubs_defaults {
Anton Hansson822cdb32020-03-06 17:16:06 +000069 name: "metalava-full-api-stubs-default",
70 defaults: ["metalava-base-api-stubs-default"],
Jiyong Parke3095162019-12-20 15:30:28 +090071 srcs: [":framework-updatable-sources"],
72 sdk_version: "core_platform",
73}
74
Anton Hansson822cdb32020-03-06 17:16:06 +000075stubs_defaults {
76 name: "metalava-non-updatable-api-stubs-default",
77 defaults: ["metalava-base-api-stubs-default"],
Anton Hansson92d79fd2020-03-20 09:12:52 +000078 sdk_version: "core_platform",
Anton Hansson394febc2020-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"],
Anton Hansson92d79fd2020-03-20 09:12:52 +000085 aidl: {
Anton Hansson394febc2020-04-14 16:35:36 +010086 local_include_dirs: ["apex/media/aidl/stable"],
Anton Hansson92d79fd2020-03-20 09:12:52 +000087 },
Anton Hansson822cdb32020-03-06 17:16:06 +000088}
89
Jiyong Park7fb4b182019-12-20 14:35:43 +090090/////////////////////////////////////////////////////////////////////
91// *-api-stubs-docs modules providing source files for the stub libraries
92/////////////////////////////////////////////////////////////////////
93
Jiyong Parke3095162019-12-20 15:30:28 +090094// api-stubs-docs, system-api-stubs-docs, and test-api-stubs-docs have APIs
95// from the non-updatable part of the platform as well as from the updatable
96// modules
Jiyong Park7fb4b182019-12-20 14:35:43 +090097droidstubs {
98 name: "api-stubs-docs",
Anton Hansson822cdb32020-03-06 17:16:06 +000099 defaults: ["metalava-full-api-stubs-default"],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900100 api_filename: "public_api.txt",
101 private_api_filename: "private.txt",
102 removed_api_filename: "removed.txt",
Artur Satayev7e7fdde2020-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: {
114 api_file: ":last-released-public-api",
115 removed_api_file: "api/removed.txt",
116 baseline_file: ":public-api-incompatibilities-with-last-released",
117 },
118 api_lint: {
119 enabled: true,
120 new_since: ":last-released-public-api",
121 baseline_file: "api/lint-baseline.txt",
122 },
123 },
Anton Hanssond9a3fee2020-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 Hansson81969c22020-02-03 20:45:56 +0000132priv_apps = " " +
133 "--show-annotation android.annotation.SystemApi\\(" +
134 "client=android.annotation.SystemApi.Client.PRIVILEGED_APPS" +
135 "\\) "
136
137module_libs = " " +
138 " --show-annotation android.annotation.SystemApi\\(" +
139 "client=android.annotation.SystemApi.Client.MODULE_LIBRARIES" +
140 "\\) "
141
Jiyong Park7fb4b182019-12-20 14:35:43 +0900142droidstubs {
143 name: "system-api-stubs-docs",
Anton Hansson822cdb32020-03-06 17:16:06 +0000144 defaults: ["metalava-full-api-stubs-default"],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900145 api_tag_name: "SYSTEM",
146 api_filename: "system-api.txt",
147 private_api_filename: "system-private.txt",
148 private_dex_api_filename: "system-private-dex.txt",
149 removed_api_filename: "system-removed.txt",
Artur Satayev7e7fdde2020-03-25 16:45:56 +0000150 removed_dex_api_filename: "system-removed-dex.txt",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900151 arg_files: [
152 "core/res/AndroidManifest.xml",
153 ],
Anton Hansson81969c22020-02-03 20:45:56 +0000154 args: metalava_framework_docs_args + priv_apps,
Jiyong Park7fb4b182019-12-20 14:35:43 +0900155 check_api: {
156 current: {
157 api_file: "api/system-current.txt",
158 removed_api_file: "api/system-removed.txt",
159 },
160 last_released: {
161 api_file: ":last-released-system-api",
162 removed_api_file: "api/system-removed.txt",
163 baseline_file: ":system-api-incompatibilities-with-last-released"
164 },
165 api_lint: {
166 enabled: true,
167 new_since: ":last-released-system-api",
168 baseline_file: "api/system-lint-baseline.txt",
169 },
170 },
Anton Hanssond9a3fee2020-03-23 18:08:55 +0000171 dist: {
172 targets: ["sdk", "win_sdk"],
173 dir: "apistubs/android/system/api",
174 dest: "android.txt",
175 },
Jiyong Park7fb4b182019-12-20 14:35:43 +0900176 jdiff_enabled: true,
177}
178
179droidstubs {
180 name: "test-api-stubs-docs",
Anton Hansson822cdb32020-03-06 17:16:06 +0000181 defaults: ["metalava-full-api-stubs-default"],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900182 api_tag_name: "TEST",
183 api_filename: "test-api.txt",
184 removed_api_filename: "test-removed.txt",
185 arg_files: [
186 "core/res/AndroidManifest.xml",
187 ],
188 args: metalava_framework_docs_args + " --show-annotation android.annotation.TestApi",
189 check_api: {
190 current: {
191 api_file: "api/test-current.txt",
192 removed_api_file: "api/test-removed.txt",
193 },
194 api_lint: {
195 enabled: true,
196 baseline_file: "api/test-lint-baseline.txt",
197 },
198 },
Anton Hanssond9a3fee2020-03-23 18:08:55 +0000199 dist: {
200 targets: ["sdk", "win_sdk"],
201 dir: "apistubs/android/test/api",
202 dest: "android.txt",
203 },
Jiyong Park7fb4b182019-12-20 14:35:43 +0900204}
205
206/////////////////////////////////////////////////////////////////////
Jiyong Parke3095162019-12-20 15:30:28 +0900207// Following droidstubs modules are for extra APIs for modules.
208// The framework currently have two more API surfaces for modules:
209// @SystemApi(client=MODULE_APPS) and @SystemApi(client=MODULE_LIBRARIES)
210/////////////////////////////////////////////////////////////////////
211
Anton Hansson81969c22020-02-03 20:45:56 +0000212// TODO(b/146727827) remove the *-api module when we can teach metalava
Jiyong Parke3095162019-12-20 15:30:28 +0900213// about the relationship among the API surfaces. Currently, these modules are only to generate
214// the API signature files and ensure that the APIs evolve in a backwards compatible manner.
215// They however are NOT used for building the API stub.
Jiyong Parke3095162019-12-20 15:30:28 +0900216
217droidstubs {
218 name: "module-lib-api",
Anton Hansson822cdb32020-03-06 17:16:06 +0000219 defaults: ["metalava-full-api-stubs-default"],
Anton Hansson7b0414b2020-03-19 15:09:44 +0000220 api_tag_name: "MODULE_LIB",
Jiyong Parke3095162019-12-20 15:30:28 +0900221 arg_files: ["core/res/AndroidManifest.xml"],
Anton Hansson81969c22020-02-03 20:45:56 +0000222 args: metalava_framework_docs_args + module_libs,
Jiyong Parke3095162019-12-20 15:30:28 +0900223 check_api: {
224 current: {
225 api_file: "api/module-lib-current.txt",
226 removed_api_file: "api/module-lib-removed.txt",
227 },
Anton Hansson79e35c32020-02-11 14:36:40 +0000228 last_released: {
229 api_file: ":last-released-module-lib-api",
230 removed_api_file: "api/module-lib-removed.txt",
231 baseline_file: ":module-lib-api-incompatibilities-with-last-released"
232 },
233 api_lint: {
234 enabled: true,
235 new_since: ":last-released-module-lib-api",
236 baseline_file: "api/module-lib-lint-baseline.txt",
237 },
Jiyong Parke3095162019-12-20 15:30:28 +0900238 },
Anton Hanssond9a3fee2020-03-23 18:08:55 +0000239 dist: {
240 targets: ["sdk", "win_sdk"],
241 dir: "apistubs/android/module-lib/api",
242 dest: "android.txt",
243 },
Jiyong Parke3095162019-12-20 15:30:28 +0900244}
245
Anton Hansson81969c22020-02-03 20:45:56 +0000246
247// The following droidstub module generates source files for the API stub library for
248// modules. Note that it not only includes its own APIs but also other APIs that have
249// narrower scope (all @SystemApis, not just the ones with 'client=MODULE_LIBRARIES').
Jiyong Parke3095162019-12-20 15:30:28 +0900250
251droidstubs {
252 name: "module-lib-api-stubs-docs",
Anton Hansson822cdb32020-03-06 17:16:06 +0000253 defaults: ["metalava-non-updatable-api-stubs-default"],
Jiyong Parke3095162019-12-20 15:30:28 +0900254 arg_files: ["core/res/AndroidManifest.xml"],
Anton Hansson81969c22020-02-03 20:45:56 +0000255 args: metalava_framework_docs_args + priv_apps + module_libs,
Jiyong Parke3095162019-12-20 15:30:28 +0900256}
257
258/////////////////////////////////////////////////////////////////////
Jiyong Park7fb4b182019-12-20 14:35:43 +0900259// android_*_stubs_current modules are the stubs libraries compiled
260// from *-api-stubs-docs
261/////////////////////////////////////////////////////////////////////
262
263java_defaults {
Anton Hansson87c7d282020-04-09 14:16:37 +0100264 name: "android_defaults_stubs_current",
Anton Hansson08b48bb2020-02-08 20:43:19 +0000265 libs: [ "stub-annotations" ],
266 static_libs: [ "private-stub-annotations-jar" ],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900267 errorprone: {
268 javacflags: [
269 "-XepDisableAllChecks",
270 ],
271 },
Anton Hansson87c7d282020-04-09 14:16:37 +0100272 java_resources: [":notices-for-framework-stubs"],
273 sdk_version: "none",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900274 system_modules: "none",
275 java_version: "1.8",
276 compile_dex: true,
277}
278
279java_library_static {
280 name: "android_stubs_current",
Anton Hansson08b48bb2020-02-08 20:43:19 +0000281 srcs: [ ":api-stubs-docs" ],
Anton Hansson87c7d282020-04-09 14:16:37 +0100282 defaults: ["android_defaults_stubs_current"],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900283}
284
285java_library_static {
286 name: "android_system_stubs_current",
Anton Hansson08b48bb2020-02-08 20:43:19 +0000287 srcs: [ ":system-api-stubs-docs" ],
Anton Hansson87c7d282020-04-09 14:16:37 +0100288 defaults: ["android_defaults_stubs_current"],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900289}
290
291java_library_static {
292 name: "android_test_stubs_current",
Anton Hansson08b48bb2020-02-08 20:43:19 +0000293 srcs: [ ":test-api-stubs-docs" ],
Anton Hansson87c7d282020-04-09 14:16:37 +0100294 defaults: ["android_defaults_stubs_current"],
Jiyong Parke3095162019-12-20 15:30:28 +0900295}
296
297java_library_static {
Anton Hansson1b9cf092020-01-30 12:09:02 +0000298 name: "android_module_lib_stubs_current",
Anton Hansson08b48bb2020-02-08 20:43:19 +0000299 srcs: [ ":module-lib-api-stubs-docs" ],
Anton Hansson87c7d282020-04-09 14:16:37 +0100300 defaults: ["android_defaults_stubs_current"],
Anton Hansson394febc2020-04-14 16:35:36 +0100301 libs: ["sdk_system_29_android"],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900302}
303
Jiyong Park7fb4b182019-12-20 14:35:43 +0900304/////////////////////////////////////////////////////////////////////
305// hwbinder.stubs provides APIs required for building HIDL Java
306// libraries.
307/////////////////////////////////////////////////////////////////////
308
309droidstubs {
310 name: "hwbinder-stubs-docs",
311 srcs: [
312 "core/java/android/os/HidlSupport.java",
313 "core/java/android/annotation/IntDef.java",
314 "core/java/android/annotation/IntRange.java",
315 "core/java/android/annotation/NonNull.java",
316 "core/java/android/annotation/SystemApi.java",
317 "core/java/android/os/HidlMemory.java",
318 "core/java/android/os/HwBinder.java",
319 "core/java/android/os/HwBlob.java",
320 "core/java/android/os/HwParcel.java",
321 "core/java/android/os/IHwBinder.java",
322 "core/java/android/os/IHwInterface.java",
323 "core/java/android/os/DeadObjectException.java",
324 "core/java/android/os/DeadSystemException.java",
325 "core/java/android/os/NativeHandle.java",
326 "core/java/android/os/RemoteException.java",
327 "core/java/android/util/AndroidException.java",
328 ],
329 installable: false,
330 sdk_version: "core_platform",
331 annotations_enabled: true,
332 previous_api: ":last-released-public-api",
333 merge_annotations_dirs: [
334 "metalava-manual",
335 ],
Anton Hansson81969c22020-02-03 20:45:56 +0000336 args: priv_apps,
Jiyong Park7fb4b182019-12-20 14:35:43 +0900337}
338
339java_library_static {
340 name: "hwbinder.stubs",
341 sdk_version: "core_current",
342 srcs: [
343 ":hwbinder-stubs-docs",
344 ],
345}
346
347/////////////////////////////////////////////////////////////////////
Jiyong Park7fb4b182019-12-20 14:35:43 +0900348// api/*-current.txt files for use by modules in other directories
349// like the CTS test
350/////////////////////////////////////////////////////////////////////
351
352filegroup {
353 name: "frameworks-base-api-current.txt",
354 srcs: [
355 "api/current.txt",
356 ],
357}
358
359filegroup {
360 name: "frameworks-base-api-system-current.txt",
361 srcs: [
362 "api/system-current.txt",
363 ],
364}
365
366filegroup {
367 name: "frameworks-base-api-system-removed.txt",
368 srcs: [
369 "api/system-removed.txt",
370 ],
371}