blob: 7d1b3d069f5945fc119b314250e3f51355141076 [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",
Jiyong Park7fb4b182019-12-20 14:35:43 +090052 ],
53 libs: ["framework-internal-utils"],
54 installable: false,
55 annotations_enabled: true,
Anton Hanssonf68ddea2020-05-02 17:49:26 +010056 previous_api: ":android.api.public.latest",
Jiyong Park7fb4b182019-12-20 14:35:43 +090057 merge_annotations_dirs: [
58 "metalava-manual",
59 ],
Aurimas Liutikas94bac9c2020-03-12 17:06:12 -070060 api_levels_annotations_enabled: false,
Jiyong Park7fb4b182019-12-20 14:35:43 +090061 filter_packages: packages_to_document,
62}
63
Jiyong Park2e6cdcc2019-12-20 15:30:28 +090064stubs_defaults {
Anton Hansson537564e2020-03-06 17:16:06 +000065 name: "metalava-full-api-stubs-default",
66 defaults: ["metalava-base-api-stubs-default"],
Anton Hanssone01390c2020-05-07 12:06:00 +010067 srcs: [
Paul Duffine55d4e32020-05-14 17:55:46 +010068 ":conscrypt.module.public.api{.public.stubs.source}",
Anton Hanssone01390c2020-05-07 12:06:00 +010069 ":framework-updatable-sources",
70 ],
Jiyong Park2e6cdcc2019-12-20 15:30:28 +090071 sdk_version: "core_platform",
72}
73
Anton Hansson537564e2020-03-06 17:16:06 +000074stubs_defaults {
75 name: "metalava-non-updatable-api-stubs-default",
76 defaults: ["metalava-base-api-stubs-default"],
Anton Hanssone53bec02020-03-20 09:12:52 +000077 sdk_version: "core_platform",
78 libs: ["framework-all"],
Anton Hansson537564e2020-03-06 17:16:06 +000079}
80
Jiyong Park7fb4b182019-12-20 14:35:43 +090081/////////////////////////////////////////////////////////////////////
82// *-api-stubs-docs modules providing source files for the stub libraries
83/////////////////////////////////////////////////////////////////////
84
Jiyong Park2e6cdcc2019-12-20 15:30:28 +090085// api-stubs-docs, system-api-stubs-docs, and test-api-stubs-docs have APIs
86// from the non-updatable part of the platform as well as from the updatable
87// modules
Jiyong Park7fb4b182019-12-20 14:35:43 +090088droidstubs {
89 name: "api-stubs-docs",
Anton Hansson537564e2020-03-06 17:16:06 +000090 defaults: ["metalava-full-api-stubs-default"],
Artur Satayev0a97d5e2020-03-25 16:45:56 +000091 removed_dex_api_filename: "removed-dex.txt",
Jiyong Park7fb4b182019-12-20 14:35:43 +090092 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: {
Anton Hanssonf68ddea2020-05-02 17:49:26 +0100102 api_file: ":android.api.public.latest",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900103 removed_api_file: "api/removed.txt",
104 baseline_file: ":public-api-incompatibilities-with-last-released",
105 },
106 api_lint: {
107 enabled: true,
Anton Hanssonf68ddea2020-05-02 17:49:26 +0100108 new_since: ":android.api.public.latest",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900109 baseline_file: "api/lint-baseline.txt",
110 },
111 },
Anton Hanssonba367d32020-03-23 18:08:55 +0000112 dist: {
113 targets: ["sdk", "win_sdk"],
114 dir: "apistubs/android/public/api",
115 dest: "android.txt",
116 },
Jiyong Park7fb4b182019-12-20 14:35:43 +0900117 jdiff_enabled: true,
118}
119
Anton Hansson81969c22020-02-03 20:45:56 +0000120priv_apps = " " +
121 "--show-annotation android.annotation.SystemApi\\(" +
122 "client=android.annotation.SystemApi.Client.PRIVILEGED_APPS" +
123 "\\) "
124
125module_libs = " " +
126 " --show-annotation android.annotation.SystemApi\\(" +
127 "client=android.annotation.SystemApi.Client.MODULE_LIBRARIES" +
128 "\\) "
129
Jiyong Park7fb4b182019-12-20 14:35:43 +0900130droidstubs {
131 name: "system-api-stubs-docs",
Anton Hansson537564e2020-03-06 17:16:06 +0000132 defaults: ["metalava-full-api-stubs-default"],
Artur Satayev0a97d5e2020-03-25 16:45:56 +0000133 removed_dex_api_filename: "system-removed-dex.txt",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900134 arg_files: [
135 "core/res/AndroidManifest.xml",
136 ],
Anton Hansson81969c22020-02-03 20:45:56 +0000137 args: metalava_framework_docs_args + priv_apps,
Jiyong Park7fb4b182019-12-20 14:35:43 +0900138 check_api: {
139 current: {
140 api_file: "api/system-current.txt",
141 removed_api_file: "api/system-removed.txt",
142 },
143 last_released: {
Anton Hanssonf68ddea2020-05-02 17:49:26 +0100144 api_file: ":android.api.system.latest",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900145 removed_api_file: "api/system-removed.txt",
146 baseline_file: ":system-api-incompatibilities-with-last-released"
147 },
148 api_lint: {
149 enabled: true,
Anton Hanssonf68ddea2020-05-02 17:49:26 +0100150 new_since: ":android.api.system.latest",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900151 baseline_file: "api/system-lint-baseline.txt",
152 },
153 },
Anton Hanssonba367d32020-03-23 18:08:55 +0000154 dist: {
155 targets: ["sdk", "win_sdk"],
156 dir: "apistubs/android/system/api",
157 dest: "android.txt",
158 },
Jiyong Park7fb4b182019-12-20 14:35:43 +0900159 jdiff_enabled: true,
160}
161
162droidstubs {
163 name: "test-api-stubs-docs",
Anton Hansson537564e2020-03-06 17:16:06 +0000164 defaults: ["metalava-full-api-stubs-default"],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900165 arg_files: [
166 "core/res/AndroidManifest.xml",
167 ],
168 args: metalava_framework_docs_args + " --show-annotation android.annotation.TestApi",
169 check_api: {
170 current: {
171 api_file: "api/test-current.txt",
172 removed_api_file: "api/test-removed.txt",
173 },
174 api_lint: {
175 enabled: true,
176 baseline_file: "api/test-lint-baseline.txt",
177 },
178 },
Anton Hanssonba367d32020-03-23 18:08:55 +0000179 dist: {
180 targets: ["sdk", "win_sdk"],
181 dir: "apistubs/android/test/api",
182 dest: "android.txt",
183 },
Jiyong Park7fb4b182019-12-20 14:35:43 +0900184}
185
186/////////////////////////////////////////////////////////////////////
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900187// Following droidstubs modules are for extra APIs for modules.
188// The framework currently have two more API surfaces for modules:
189// @SystemApi(client=MODULE_APPS) and @SystemApi(client=MODULE_LIBRARIES)
190/////////////////////////////////////////////////////////////////////
191
Anton Hansson81969c22020-02-03 20:45:56 +0000192// TODO(b/146727827) remove the *-api module when we can teach metalava
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900193// about the relationship among the API surfaces. Currently, these modules are only to generate
194// the API signature files and ensure that the APIs evolve in a backwards compatible manner.
195// They however are NOT used for building the API stub.
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900196
197droidstubs {
198 name: "module-lib-api",
Anton Hansson537564e2020-03-06 17:16:06 +0000199 defaults: ["metalava-full-api-stubs-default"],
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900200 arg_files: ["core/res/AndroidManifest.xml"],
Anton Hansson81969c22020-02-03 20:45:56 +0000201 args: metalava_framework_docs_args + module_libs,
Paul Duffin4c5dc182020-04-08 18:28:15 +0100202
203 // Do not generate stubs as they are not needed
204 generate_stubs: false,
205
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900206 check_api: {
207 current: {
208 api_file: "api/module-lib-current.txt",
209 removed_api_file: "api/module-lib-removed.txt",
210 },
Anton Hansson626afea2020-02-11 14:36:40 +0000211 last_released: {
Anton Hanssonf68ddea2020-05-02 17:49:26 +0100212 api_file: ":android.api.module-lib.latest",
Anton Hansson626afea2020-02-11 14:36:40 +0000213 removed_api_file: "api/module-lib-removed.txt",
214 baseline_file: ":module-lib-api-incompatibilities-with-last-released"
215 },
216 api_lint: {
217 enabled: true,
Anton Hanssonf68ddea2020-05-02 17:49:26 +0100218 new_since: ":android.api.module-lib.latest",
Anton Hansson626afea2020-02-11 14:36:40 +0000219 baseline_file: "api/module-lib-lint-baseline.txt",
220 },
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900221 },
Anton Hanssonba367d32020-03-23 18:08:55 +0000222 dist: {
223 targets: ["sdk", "win_sdk"],
224 dir: "apistubs/android/module-lib/api",
225 dest: "android.txt",
226 },
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900227}
228
Anton Hansson81969c22020-02-03 20:45:56 +0000229
230// The following droidstub module generates source files for the API stub library for
231// modules. Note that it not only includes its own APIs but also other APIs that have
232// narrower scope (all @SystemApis, not just the ones with 'client=MODULE_LIBRARIES').
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900233
234droidstubs {
235 name: "module-lib-api-stubs-docs",
Anton Hansson537564e2020-03-06 17:16:06 +0000236 defaults: ["metalava-non-updatable-api-stubs-default"],
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900237 arg_files: ["core/res/AndroidManifest.xml"],
Anton Hansson81969c22020-02-03 20:45:56 +0000238 args: metalava_framework_docs_args + priv_apps + module_libs,
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900239}
240
241/////////////////////////////////////////////////////////////////////
Jiyong Park7fb4b182019-12-20 14:35:43 +0900242// android_*_stubs_current modules are the stubs libraries compiled
243// from *-api-stubs-docs
244/////////////////////////////////////////////////////////////////////
245
246java_defaults {
Anton Hanssonfbd32f32020-04-09 14:16:37 +0100247 name: "android_defaults_stubs_current",
Anton Hansson42afd612020-02-08 20:43:19 +0000248 libs: [ "stub-annotations" ],
Paul Duffina281e922020-03-25 10:13:33 +0000249 static_libs: [
250 "private-stub-annotations-jar",
251
252 // License notices from art module
253 "art-notices-for-framework-stubs-jar",
254 ],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900255 errorprone: {
256 javacflags: [
257 "-XepDisableAllChecks",
258 ],
259 },
Anton Hanssonfbd32f32020-04-09 14:16:37 +0100260 sdk_version: "none",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900261 system_modules: "none",
262 java_version: "1.8",
263 compile_dex: true,
264}
265
266java_library_static {
267 name: "android_stubs_current",
Anton Hansson42afd612020-02-08 20:43:19 +0000268 srcs: [ ":api-stubs-docs" ],
Anton Hanssonfbd32f32020-04-09 14:16:37 +0100269 defaults: ["android_defaults_stubs_current"],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900270}
271
272java_library_static {
273 name: "android_system_stubs_current",
Anton Hansson42afd612020-02-08 20:43:19 +0000274 srcs: [ ":system-api-stubs-docs" ],
Anton Hanssonfbd32f32020-04-09 14:16:37 +0100275 defaults: ["android_defaults_stubs_current"],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900276}
277
278java_library_static {
279 name: "android_test_stubs_current",
Anton Hansson42afd612020-02-08 20:43:19 +0000280 srcs: [ ":test-api-stubs-docs" ],
Anton Hanssonfbd32f32020-04-09 14:16:37 +0100281 defaults: ["android_defaults_stubs_current"],
Jiyong Park2e6cdcc2019-12-20 15:30:28 +0900282}
283
284java_library_static {
Anton Hansson9c4bbe92020-01-30 12:09:02 +0000285 name: "android_module_lib_stubs_current",
Anton Hansson42afd612020-02-08 20:43:19 +0000286 srcs: [ ":module-lib-api-stubs-docs" ],
Anton Hanssonfbd32f32020-04-09 14:16:37 +0100287 defaults: ["android_defaults_stubs_current"],
Anton Hansson537564e2020-03-06 17:16:06 +0000288 libs: ["android_system_stubs_current"],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900289}
290
Jiyong Park7fb4b182019-12-20 14:35:43 +0900291/////////////////////////////////////////////////////////////////////
292// hwbinder.stubs provides APIs required for building HIDL Java
293// libraries.
294/////////////////////////////////////////////////////////////////////
295
296droidstubs {
297 name: "hwbinder-stubs-docs",
298 srcs: [
299 "core/java/android/os/HidlSupport.java",
300 "core/java/android/annotation/IntDef.java",
301 "core/java/android/annotation/IntRange.java",
302 "core/java/android/annotation/NonNull.java",
303 "core/java/android/annotation/SystemApi.java",
304 "core/java/android/os/HidlMemory.java",
305 "core/java/android/os/HwBinder.java",
306 "core/java/android/os/HwBlob.java",
307 "core/java/android/os/HwParcel.java",
308 "core/java/android/os/IHwBinder.java",
309 "core/java/android/os/IHwInterface.java",
310 "core/java/android/os/DeadObjectException.java",
311 "core/java/android/os/DeadSystemException.java",
312 "core/java/android/os/NativeHandle.java",
313 "core/java/android/os/RemoteException.java",
314 "core/java/android/util/AndroidException.java",
315 ],
316 installable: false,
317 sdk_version: "core_platform",
318 annotations_enabled: true,
Anton Hanssonf68ddea2020-05-02 17:49:26 +0100319 previous_api: ":android.api.public.latest",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900320 merge_annotations_dirs: [
321 "metalava-manual",
322 ],
Anton Hansson81969c22020-02-03 20:45:56 +0000323 args: priv_apps,
Jiyong Park7fb4b182019-12-20 14:35:43 +0900324}
325
326java_library_static {
327 name: "hwbinder.stubs",
328 sdk_version: "core_current",
329 srcs: [
330 ":hwbinder-stubs-docs",
331 ],
332}
333
334/////////////////////////////////////////////////////////////////////
Jiyong Park7fb4b182019-12-20 14:35:43 +0900335// api/*-current.txt files for use by modules in other directories
336// like the CTS test
337/////////////////////////////////////////////////////////////////////
338
339filegroup {
340 name: "frameworks-base-api-current.txt",
341 srcs: [
342 "api/current.txt",
343 ],
344}
345
346filegroup {
347 name: "frameworks-base-api-system-current.txt",
348 srcs: [
349 "api/system-current.txt",
350 ],
351}
352
353filegroup {
354 name: "frameworks-base-api-system-removed.txt",
355 srcs: [
356 "api/system-removed.txt",
357 ],
358}