blob: a58d1ef6853919a060257e6113467b22321ba9e7 [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 Duffin5c89e702020-03-26 15:33:48 +000050 ":art-module-public-api-stubs-source",
51 ":conscrypt-module-public-api-stubs-source",
52 ":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,
61 previous_api: ":last-released-public-api",
62 merge_annotations_dirs: [
63 "metalava-manual",
64 ],
Aurimas Liutikas94bac9c2020-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",
80 libs: ["framework-all"],
81 aidl: {
82 local_include_dirs: ["apex/media/framework/java"],
83 },
Anton Hansson822cdb32020-03-06 17:16:06 +000084}
85
Jiyong Park7fb4b182019-12-20 14:35:43 +090086/////////////////////////////////////////////////////////////////////
87// *-api-stubs-docs modules providing source files for the stub libraries
88/////////////////////////////////////////////////////////////////////
89
Jiyong Parke3095162019-12-20 15:30:28 +090090// api-stubs-docs, system-api-stubs-docs, and test-api-stubs-docs have APIs
91// from the non-updatable part of the platform as well as from the updatable
92// modules
Jiyong Park7fb4b182019-12-20 14:35:43 +090093droidstubs {
94 name: "api-stubs-docs",
Anton Hansson822cdb32020-03-06 17:16:06 +000095 defaults: ["metalava-full-api-stubs-default"],
Jiyong Park7fb4b182019-12-20 14:35:43 +090096 api_filename: "public_api.txt",
97 private_api_filename: "private.txt",
98 removed_api_filename: "removed.txt",
99 arg_files: [
100 "core/res/AndroidManifest.xml",
101 ],
102 args: metalava_framework_docs_args,
103 check_api: {
104 current: {
105 api_file: "api/current.txt",
106 removed_api_file: "api/removed.txt",
107 },
108 last_released: {
109 api_file: ":last-released-public-api",
110 removed_api_file: "api/removed.txt",
111 baseline_file: ":public-api-incompatibilities-with-last-released",
112 },
113 api_lint: {
114 enabled: true,
115 new_since: ":last-released-public-api",
116 baseline_file: "api/lint-baseline.txt",
117 },
118 },
Anton Hanssond9a3fee2020-03-23 18:08:55 +0000119 dist: {
120 targets: ["sdk", "win_sdk"],
121 dir: "apistubs/android/public/api",
122 dest: "android.txt",
123 },
Jiyong Park7fb4b182019-12-20 14:35:43 +0900124 jdiff_enabled: true,
125}
126
Anton Hansson81969c22020-02-03 20:45:56 +0000127priv_apps = " " +
128 "--show-annotation android.annotation.SystemApi\\(" +
129 "client=android.annotation.SystemApi.Client.PRIVILEGED_APPS" +
130 "\\) "
131
132module_libs = " " +
133 " --show-annotation android.annotation.SystemApi\\(" +
134 "client=android.annotation.SystemApi.Client.MODULE_LIBRARIES" +
135 "\\) "
136
Jiyong Park7fb4b182019-12-20 14:35:43 +0900137droidstubs {
138 name: "system-api-stubs-docs",
Anton Hansson822cdb32020-03-06 17:16:06 +0000139 defaults: ["metalava-full-api-stubs-default"],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900140 api_tag_name: "SYSTEM",
141 api_filename: "system-api.txt",
142 private_api_filename: "system-private.txt",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900143 removed_api_filename: "system-removed.txt",
144 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: {
154 api_file: ":last-released-system-api",
155 removed_api_file: "api/system-removed.txt",
156 baseline_file: ":system-api-incompatibilities-with-last-released"
157 },
158 api_lint: {
159 enabled: true,
160 new_since: ":last-released-system-api",
161 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 api_tag_name: "TEST",
176 api_filename: "test-api.txt",
177 removed_api_filename: "test-removed.txt",
178 arg_files: [
179 "core/res/AndroidManifest.xml",
180 ],
181 args: metalava_framework_docs_args + " --show-annotation android.annotation.TestApi",
182 check_api: {
183 current: {
184 api_file: "api/test-current.txt",
185 removed_api_file: "api/test-removed.txt",
186 },
187 api_lint: {
188 enabled: true,
189 baseline_file: "api/test-lint-baseline.txt",
190 },
191 },
Anton Hanssond9a3fee2020-03-23 18:08:55 +0000192 dist: {
193 targets: ["sdk", "win_sdk"],
194 dir: "apistubs/android/test/api",
195 dest: "android.txt",
196 },
Jiyong Park7fb4b182019-12-20 14:35:43 +0900197}
198
199/////////////////////////////////////////////////////////////////////
Jiyong Parke3095162019-12-20 15:30:28 +0900200// Following droidstubs modules are for extra APIs for modules.
201// The framework currently have two more API surfaces for modules:
202// @SystemApi(client=MODULE_APPS) and @SystemApi(client=MODULE_LIBRARIES)
203/////////////////////////////////////////////////////////////////////
204
Anton Hansson81969c22020-02-03 20:45:56 +0000205// TODO(b/146727827) remove the *-api module when we can teach metalava
Jiyong Parke3095162019-12-20 15:30:28 +0900206// about the relationship among the API surfaces. Currently, these modules are only to generate
207// the API signature files and ensure that the APIs evolve in a backwards compatible manner.
208// They however are NOT used for building the API stub.
Jiyong Parke3095162019-12-20 15:30:28 +0900209
210droidstubs {
211 name: "module-lib-api",
Anton Hansson822cdb32020-03-06 17:16:06 +0000212 defaults: ["metalava-full-api-stubs-default"],
Anton Hansson7b0414b2020-03-19 15:09:44 +0000213 api_tag_name: "MODULE_LIB",
Jiyong Parke3095162019-12-20 15:30:28 +0900214 arg_files: ["core/res/AndroidManifest.xml"],
Anton Hansson81969c22020-02-03 20:45:56 +0000215 args: metalava_framework_docs_args + module_libs,
Jiyong Parke3095162019-12-20 15:30:28 +0900216 check_api: {
217 current: {
218 api_file: "api/module-lib-current.txt",
219 removed_api_file: "api/module-lib-removed.txt",
220 },
Anton Hansson79e35c32020-02-11 14:36:40 +0000221 last_released: {
222 api_file: ":last-released-module-lib-api",
223 removed_api_file: "api/module-lib-removed.txt",
224 baseline_file: ":module-lib-api-incompatibilities-with-last-released"
225 },
226 api_lint: {
227 enabled: true,
228 new_since: ":last-released-module-lib-api",
229 baseline_file: "api/module-lib-lint-baseline.txt",
230 },
Jiyong Parke3095162019-12-20 15:30:28 +0900231 },
Anton Hanssond9a3fee2020-03-23 18:08:55 +0000232 dist: {
233 targets: ["sdk", "win_sdk"],
234 dir: "apistubs/android/module-lib/api",
235 dest: "android.txt",
236 },
Jiyong Parke3095162019-12-20 15:30:28 +0900237}
238
Anton Hansson81969c22020-02-03 20:45:56 +0000239
240// The following droidstub module generates source files for the API stub library for
241// modules. Note that it not only includes its own APIs but also other APIs that have
242// narrower scope (all @SystemApis, not just the ones with 'client=MODULE_LIBRARIES').
Jiyong Parke3095162019-12-20 15:30:28 +0900243
244droidstubs {
245 name: "module-lib-api-stubs-docs",
Anton Hansson822cdb32020-03-06 17:16:06 +0000246 defaults: ["metalava-non-updatable-api-stubs-default"],
Jiyong Parke3095162019-12-20 15:30:28 +0900247 arg_files: ["core/res/AndroidManifest.xml"],
Anton Hansson81969c22020-02-03 20:45:56 +0000248 args: metalava_framework_docs_args + priv_apps + module_libs,
Jiyong Parke3095162019-12-20 15:30:28 +0900249}
250
251/////////////////////////////////////////////////////////////////////
Jiyong Park7fb4b182019-12-20 14:35:43 +0900252// android_*_stubs_current modules are the stubs libraries compiled
253// from *-api-stubs-docs
254/////////////////////////////////////////////////////////////////////
255
256java_defaults {
257 name: "framework-stubs-default",
Anton Hansson08b48bb2020-02-08 20:43:19 +0000258 libs: [ "stub-annotations" ],
Paul Duffina281e922020-03-25 10:13:33 +0000259 static_libs: [
260 "private-stub-annotations-jar",
261
262 // License notices from art module
263 "art-notices-for-framework-stubs-jar",
264 ],
Anton Hansson08b48bb2020-02-08 20:43:19 +0000265 sdk_version: "core_current",
Jiyong Park7fb4b182019-12-20 14:35:43 +0900266 errorprone: {
267 javacflags: [
268 "-XepDisableAllChecks",
269 ],
270 },
Jiyong Park7fb4b182019-12-20 14:35:43 +0900271 system_modules: "none",
272 java_version: "1.8",
273 compile_dex: true,
274}
275
276java_library_static {
277 name: "android_stubs_current",
Anton Hansson08b48bb2020-02-08 20:43:19 +0000278 srcs: [ ":api-stubs-docs" ],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900279 defaults: ["framework-stubs-default"],
280}
281
282java_library_static {
283 name: "android_system_stubs_current",
Anton Hansson08b48bb2020-02-08 20:43:19 +0000284 srcs: [ ":system-api-stubs-docs" ],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900285 defaults: ["framework-stubs-default"],
286}
287
288java_library_static {
289 name: "android_test_stubs_current",
Anton Hansson08b48bb2020-02-08 20:43:19 +0000290 srcs: [ ":test-api-stubs-docs" ],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900291 defaults: ["framework-stubs-default"],
Jiyong Parke3095162019-12-20 15:30:28 +0900292}
293
294java_library_static {
Anton Hansson1b9cf092020-01-30 12:09:02 +0000295 name: "android_module_lib_stubs_current",
Anton Hansson08b48bb2020-02-08 20:43:19 +0000296 srcs: [ ":module-lib-api-stubs-docs" ],
Jiyong Parke3095162019-12-20 15:30:28 +0900297 defaults: ["framework-stubs-default"],
Anton Hansson822cdb32020-03-06 17:16:06 +0000298 libs: ["android_system_stubs_current"],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900299}
300
Jiyong Park7fb4b182019-12-20 14:35:43 +0900301/////////////////////////////////////////////////////////////////////
302// hwbinder.stubs provides APIs required for building HIDL Java
303// libraries.
304/////////////////////////////////////////////////////////////////////
305
306droidstubs {
307 name: "hwbinder-stubs-docs",
308 srcs: [
309 "core/java/android/os/HidlSupport.java",
310 "core/java/android/annotation/IntDef.java",
311 "core/java/android/annotation/IntRange.java",
312 "core/java/android/annotation/NonNull.java",
313 "core/java/android/annotation/SystemApi.java",
314 "core/java/android/os/HidlMemory.java",
315 "core/java/android/os/HwBinder.java",
316 "core/java/android/os/HwBlob.java",
317 "core/java/android/os/HwParcel.java",
318 "core/java/android/os/IHwBinder.java",
319 "core/java/android/os/IHwInterface.java",
320 "core/java/android/os/DeadObjectException.java",
321 "core/java/android/os/DeadSystemException.java",
322 "core/java/android/os/NativeHandle.java",
323 "core/java/android/os/RemoteException.java",
324 "core/java/android/util/AndroidException.java",
325 ],
326 installable: false,
327 sdk_version: "core_platform",
328 annotations_enabled: true,
329 previous_api: ":last-released-public-api",
330 merge_annotations_dirs: [
331 "metalava-manual",
332 ],
Anton Hansson81969c22020-02-03 20:45:56 +0000333 args: priv_apps,
Jiyong Park7fb4b182019-12-20 14:35:43 +0900334}
335
336java_library_static {
337 name: "hwbinder.stubs",
338 sdk_version: "core_current",
339 srcs: [
340 ":hwbinder-stubs-docs",
341 ],
342}
343
344/////////////////////////////////////////////////////////////////////
345// Stubs for hiddenapi processing.
346/////////////////////////////////////////////////////////////////////
347
348droidstubs {
349 name: "hiddenapi-lists-docs",
Anton Hansson822cdb32020-03-06 17:16:06 +0000350 defaults: ["metalava-full-api-stubs-default"],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900351 arg_files: [
352 "core/res/AndroidManifest.xml",
353 ],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900354 removed_dex_api_filename: "removed-dex.txt",
355 args: metalava_framework_docs_args +
356 " --show-unannotated " +
Anton Hansson81969c22020-02-03 20:45:56 +0000357 priv_apps +
Jiyong Park7fb4b182019-12-20 14:35:43 +0900358 " --show-annotation android.annotation.TestApi ",
359}
360
361droidstubs {
362 name: "hiddenapi-mappings",
Anton Hansson822cdb32020-03-06 17:16:06 +0000363 defaults: ["metalava-full-api-stubs-default"],
Jiyong Park7fb4b182019-12-20 14:35:43 +0900364 srcs: [
365 ":opt-telephony-common-srcs",
366 ],
367
368 arg_files: [
369 "core/res/AndroidManifest.xml",
370 ],
371 dex_mapping_filename: "dex-mapping.txt",
372 args: metalava_framework_docs_args +
373 " --hide ReferencesHidden " +
374 " --hide UnhiddenSystemApi " +
375 " --show-unannotated " +
Anton Hansson81969c22020-02-03 20:45:56 +0000376 priv_apps +
Jiyong Park7fb4b182019-12-20 14:35:43 +0900377 " --show-annotation android.annotation.TestApi ",
378}
379
380/////////////////////////////////////////////////////////////////////
381// api/*-current.txt files for use by modules in other directories
382// like the CTS test
383/////////////////////////////////////////////////////////////////////
384
385filegroup {
386 name: "frameworks-base-api-current.txt",
387 srcs: [
388 "api/current.txt",
389 ],
390}
391
392filegroup {
393 name: "frameworks-base-api-system-current.txt",
394 srcs: [
395 "api/system-current.txt",
396 ],
397}
398
399filegroup {
400 name: "frameworks-base-api-system-removed.txt",
401 srcs: [
402 "api/system-removed.txt",
403 ],
404}