blob: 3a63c80588cacdd7f0c2b03d1e4003f471e3d556 [file] [log] [blame]
Anton Hansson24c88f42019-12-13 16:17:27 +00001// 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
15mainline_stubs_args =
16 "--error UnhiddenSystemApi " +
17 "--hide BroadcastBehavior " +
18 "--hide DeprecationMismatch " +
19 "--hide HiddenSuperclass " +
20 "--hide HiddenTypedefConstant " +
21 "--hide HiddenTypeParameter " +
22 "--hide MissingPermission " +
23 "--hide RequiresPermission " +
24 "--hide SdkConstant " +
25 "--hide Todo " +
26 "--hide Typo " +
27 "--hide UnavailableSymbol "
28
Anton Hansson087646e2020-03-24 15:21:01 +000029// TODO: modularize this so not every module has the same whitelist
30framework_packages_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
Anton Hansson26e1ed62020-03-23 13:30:01 +000043// TODO: remove the hiding when server classes are cleaned up.
44mainline_framework_stubs_args =
45 mainline_stubs_args +
46 "--hide-package com.android.server "
Anton Hansson5036ab62019-12-17 10:03:52 +000047
Anton Hanssona12addc2020-02-03 14:44:47 +000048priv_apps = " " +
49 "--show-annotation android.annotation.SystemApi\\(" +
Jiyong Park7f1e9b22020-02-25 17:12:30 +090050 "client=android.annotation.SystemApi.Client.PRIVILEGED_APPS" +
Anton Hanssona12addc2020-02-03 14:44:47 +000051 "\\) "
52
53module_libs = " " +
54 " --show-annotation android.annotation.SystemApi\\(" +
Jiyong Park7f1e9b22020-02-25 17:12:30 +090055 "client=android.annotation.SystemApi.Client.MODULE_LIBRARIES" +
Anton Hanssona12addc2020-02-03 14:44:47 +000056 "\\) "
57
Anton Hansson26e1ed62020-03-23 13:30:01 +000058mainline_service_stubs_args =
59 mainline_stubs_args +
60 "--show-annotation android.annotation.SystemApi\\(" +
61 "client=android.annotation.SystemApi.Client.SYSTEM_SERVER" +
62 "\\) " +
63 "--hide-annotation android.annotation.Hide " +
64 "--hide InternalClasses " // com.android.* classes are okay in this interface
65
Paul Duffin13e67af2020-05-13 10:17:56 +010066// Defaults for mainline module provided java_sdk_library instances.
67java_defaults {
68 name: "framework-module-defaults",
69
70 // Additional annotations used for compiling both the implementation and the
71 // stubs libraries.
72 libs: ["framework-annotations-lib"],
73
74 // Enable api lint. This will eventually become the default for java_sdk_library
75 // but it cannot yet be turned on because some usages have not been cleaned up.
76 // TODO(b/156126315) - Remove when no longer needed.
77 api_lint: {
78 enabled: true,
79 },
80
81 // The API scope specific properties.
82 public: {
83 enabled: true,
84 sdk_version: "module_current",
85 },
86 system: {
87 enabled: true,
88 sdk_version: "module_current",
89 },
90 module_lib: {
91 enabled: true,
92 sdk_version: "module_current",
93 },
94
Paul Duffin067d80b2020-05-17 13:00:36 +010095 // Configure framework module specific metalava options.
96 droiddoc_options: [mainline_stubs_args],
97
Paul Duffin13e67af2020-05-13 10:17:56 +010098 // The stub libraries must be visible to frameworks/base so they can be combined
99 // into API specific libraries.
100 stubs_library_visibility: [
101 "//frameworks/base", // Framework
102 ],
103
104 // Set the visibility of the modules creating the stubs source.
105 stubs_source_visibility: [
106 // Ignore any visibility rules specified on the java_sdk_library when
107 // setting the visibility of the stubs source modules.
108 "//visibility:override",
109
110 // Currently, the stub source is not required for anything other than building
111 // the stubs library so is private to avoid misuse.
112 "//visibility:private",
113 ],
114
115 // Collates API usages from each module for further analysis.
116 plugins: ["java_api_finder"],
117
118 // Mainline modules should only rely on 'module_lib' APIs provided by other modules
119 // and the non updatable parts of the platform.
120 sdk_version: "module_current",
121}
122
Anton Hansson24c88f42019-12-13 16:17:27 +0000123stubs_defaults {
124 name: "framework-module-stubs-defaults-publicapi",
Anton Hansson26e1ed62020-03-23 13:30:01 +0000125 args: mainline_framework_stubs_args,
Anton Hansson24c88f42019-12-13 16:17:27 +0000126 installable: false,
Anton Hansson4d90a282020-03-09 19:14:28 +0000127 sdk_version: "current",
Anton Hansson087646e2020-03-24 15:21:01 +0000128 filter_packages: framework_packages_to_document,
Anton Hansson5d708e52020-01-17 19:03:34 +0000129 check_api: {
130 current: {
131 api_file: "api/current.txt",
132 removed_api_file: "api/removed.txt",
133 },
134 },
Anton Hansson24c88f42019-12-13 16:17:27 +0000135}
136
137stubs_defaults {
138 name: "framework-module-stubs-defaults-systemapi",
Anton Hansson26e1ed62020-03-23 13:30:01 +0000139 args: mainline_framework_stubs_args + priv_apps,
Anton Hansson397eb472020-03-13 16:28:21 +0000140 libs: ["framework-annotations-lib"],
Jiyong Park7be934f2020-01-06 16:22:32 +0900141 installable: false,
Anton Hansson4d90a282020-03-09 19:14:28 +0000142 sdk_version: "system_current",
Anton Hansson087646e2020-03-24 15:21:01 +0000143 filter_packages: framework_packages_to_document,
Anton Hansson5d708e52020-01-17 19:03:34 +0000144 check_api: {
145 current: {
146 api_file: "api/system-current.txt",
147 removed_api_file: "api/system-removed.txt",
148 },
149 },
Jiyong Park7be934f2020-01-06 16:22:32 +0900150}
151
Anton Hanssonc8cc1eb2020-03-24 17:03:15 +0000152java_defaults {
153 name: "framework-module-stubs-lib-defaults-publicapi",
154 installable: false,
155 sdk_version: "module_current",
156}
157
158java_defaults {
159 name: "framework-module-stubs-lib-defaults-systemapi",
160 installable: false,
161 sdk_version: "module_current",
162}
163
164java_defaults {
165 name: "framework-module-stubs-lib-defaults-module_libs_api",
166 installable: false,
167 sdk_version: "module_current",
168}
169
Anton Hanssona12addc2020-02-03 14:44:47 +0000170// The defaults for module_libs comes in two parts - defaults for API checks
171// and defaults for stub generation. This is because we want the API txt
172// files to *only* include the module_libs_api, but the stubs to include
173// module_libs_api as well as priv_apps.
174
Jiyong Park7be934f2020-01-06 16:22:32 +0900175stubs_defaults {
Anton Hanssona12addc2020-02-03 14:44:47 +0000176 name: "framework-module-api-defaults-module_libs_api",
Anton Hansson26e1ed62020-03-23 13:30:01 +0000177 args: mainline_framework_stubs_args + module_libs,
Anton Hansson397eb472020-03-13 16:28:21 +0000178 libs: ["framework-annotations-lib"],
Jiyong Park7be934f2020-01-06 16:22:32 +0900179 installable: false,
Anton Hansson4d90a282020-03-09 19:14:28 +0000180 sdk_version: "module_current",
Anton Hansson087646e2020-03-24 15:21:01 +0000181 filter_packages: framework_packages_to_document,
Paul Duffin4c5dc182020-04-08 18:28:15 +0100182
183 // Do not generate stubs as they are not needed
184 generate_stubs: false,
185
Anton Hansson5d708e52020-01-17 19:03:34 +0000186 check_api: {
187 current: {
188 api_file: "api/module-lib-current.txt",
189 removed_api_file: "api/module-lib-removed.txt",
190 },
191 },
Jiyong Park7be934f2020-01-06 16:22:32 +0900192}
193
194stubs_defaults {
195 name: "framework-module-stubs-defaults-module_libs_api",
Anton Hansson26e1ed62020-03-23 13:30:01 +0000196 args: mainline_framework_stubs_args + module_libs + priv_apps,
Anton Hansson397eb472020-03-13 16:28:21 +0000197 libs: ["framework-annotations-lib"],
Anton Hansson24c88f42019-12-13 16:17:27 +0000198 installable: false,
Anton Hansson4d90a282020-03-09 19:14:28 +0000199 sdk_version: "module_current",
Anton Hansson087646e2020-03-24 15:21:01 +0000200 filter_packages: framework_packages_to_document,
Anton Hansson24c88f42019-12-13 16:17:27 +0000201}
Anton Hansson26e1ed62020-03-23 13:30:01 +0000202
203stubs_defaults {
204 name: "service-module-stubs-srcs-defaults",
205 args: mainline_service_stubs_args,
206 installable: false,
Anton Hanssonf68ef062020-03-27 15:09:26 +0000207 filter_packages: ["com.android."],
Anton Hansson26e1ed62020-03-23 13:30:01 +0000208 check_api: {
209 current: {
210 api_file: "api/current.txt",
211 removed_api_file: "api/removed.txt",
212 },
213 },
214}
215
216// Empty for now, but a convenient place to add rules for all
217// module java_library system_server stub libs.
218java_defaults {
219 name: "service-module-stubs-defaults",
220}