blob: 5ee8a638f540391b9e581ae649480c8be4dfad75 [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" +
Makoto Onukia13287f2020-07-10 12:05:21 -070056 "\\)" +
57 " --show-for-stub-purposes-annotation android.annotation.SystemApi\\(" +
58 "client=android.annotation.SystemApi.Client.PRIVILEGED_APPS" +
Anton Hanssona12addc2020-02-03 14:44:47 +000059 "\\) "
60
Anton Hansson26e1ed62020-03-23 13:30:01 +000061mainline_service_stubs_args =
62 mainline_stubs_args +
63 "--show-annotation android.annotation.SystemApi\\(" +
64 "client=android.annotation.SystemApi.Client.SYSTEM_SERVER" +
65 "\\) " +
66 "--hide-annotation android.annotation.Hide " +
67 "--hide InternalClasses " // com.android.* classes are okay in this interface
68
Paul Duffin13e67af2020-05-13 10:17:56 +010069// Defaults for mainline module provided java_sdk_library instances.
70java_defaults {
71 name: "framework-module-defaults",
72
73 // Additional annotations used for compiling both the implementation and the
74 // stubs libraries.
75 libs: ["framework-annotations-lib"],
76
Paul Duffin077b4df2020-05-22 17:12:12 +010077 // Framework modules are not generally shared libraries, i.e. they are not
78 // intended, and must not be allowed, to be used in a <uses-library> manifest
79 // entry.
80 shared_library: false,
81
Paul Duffin1a0ba1e2020-05-29 09:50:20 +010082 // Prevent dependencies that do not specify an sdk_version from accessing the
83 // implementation library by default and force them to use stubs instead.
84 default_to_stubs: true,
85
Paul Duffin13e67af2020-05-13 10:17:56 +010086 // Enable api lint. This will eventually become the default for java_sdk_library
87 // but it cannot yet be turned on because some usages have not been cleaned up.
88 // TODO(b/156126315) - Remove when no longer needed.
89 api_lint: {
90 enabled: true,
91 },
92
93 // The API scope specific properties.
94 public: {
95 enabled: true,
96 sdk_version: "module_current",
97 },
98 system: {
99 enabled: true,
100 sdk_version: "module_current",
101 },
102 module_lib: {
103 enabled: true,
104 sdk_version: "module_current",
105 },
106
Paul Duffin067d80b2020-05-17 13:00:36 +0100107 // Configure framework module specific metalava options.
108 droiddoc_options: [mainline_stubs_args],
109
Anton Hansson7d74e592020-05-27 11:26:16 +0100110 annotations_enabled: true,
111
Paul Duffin13e67af2020-05-13 10:17:56 +0100112 // The stub libraries must be visible to frameworks/base so they can be combined
113 // into API specific libraries.
114 stubs_library_visibility: [
115 "//frameworks/base", // Framework
116 ],
117
118 // Set the visibility of the modules creating the stubs source.
119 stubs_source_visibility: [
120 // Ignore any visibility rules specified on the java_sdk_library when
121 // setting the visibility of the stubs source modules.
122 "//visibility:override",
123
124 // Currently, the stub source is not required for anything other than building
125 // the stubs library so is private to avoid misuse.
126 "//visibility:private",
127 ],
128
129 // Collates API usages from each module for further analysis.
130 plugins: ["java_api_finder"],
131
132 // Mainline modules should only rely on 'module_lib' APIs provided by other modules
133 // and the non updatable parts of the platform.
134 sdk_version: "module_current",
135}
136
Anton Hansson24c88f42019-12-13 16:17:27 +0000137stubs_defaults {
138 name: "framework-module-stubs-defaults-publicapi",
Anton Hansson26e1ed62020-03-23 13:30:01 +0000139 args: mainline_framework_stubs_args,
Anton Hansson24c88f42019-12-13 16:17:27 +0000140 installable: false,
Anton Hansson4d90a282020-03-09 19:14:28 +0000141 sdk_version: "current",
Anton Hansson087646e2020-03-24 15:21:01 +0000142 filter_packages: framework_packages_to_document,
Anton Hansson5d708e52020-01-17 19:03:34 +0000143 check_api: {
144 current: {
145 api_file: "api/current.txt",
146 removed_api_file: "api/removed.txt",
147 },
148 },
Anton Hansson24c88f42019-12-13 16:17:27 +0000149}
150
151stubs_defaults {
152 name: "framework-module-stubs-defaults-systemapi",
Anton Hansson26e1ed62020-03-23 13:30:01 +0000153 args: mainline_framework_stubs_args + priv_apps,
Anton Hansson397eb472020-03-13 16:28:21 +0000154 libs: ["framework-annotations-lib"],
Jiyong Park7be934f2020-01-06 16:22:32 +0900155 installable: false,
Anton Hansson4d90a282020-03-09 19:14:28 +0000156 sdk_version: "system_current",
Anton Hansson087646e2020-03-24 15:21:01 +0000157 filter_packages: framework_packages_to_document,
Anton Hansson5d708e52020-01-17 19:03:34 +0000158 check_api: {
159 current: {
160 api_file: "api/system-current.txt",
161 removed_api_file: "api/system-removed.txt",
162 },
163 },
Jiyong Park7be934f2020-01-06 16:22:32 +0900164}
165
Anton Hanssonc8cc1eb2020-03-24 17:03:15 +0000166java_defaults {
167 name: "framework-module-stubs-lib-defaults-publicapi",
168 installable: false,
169 sdk_version: "module_current",
170}
171
172java_defaults {
173 name: "framework-module-stubs-lib-defaults-systemapi",
174 installable: false,
175 sdk_version: "module_current",
176}
177
178java_defaults {
179 name: "framework-module-stubs-lib-defaults-module_libs_api",
180 installable: false,
181 sdk_version: "module_current",
182}
183
Anton Hanssona12addc2020-02-03 14:44:47 +0000184// The defaults for module_libs comes in two parts - defaults for API checks
185// and defaults for stub generation. This is because we want the API txt
186// files to *only* include the module_libs_api, but the stubs to include
187// module_libs_api as well as priv_apps.
188
Jiyong Park7be934f2020-01-06 16:22:32 +0900189stubs_defaults {
Anton Hanssona12addc2020-02-03 14:44:47 +0000190 name: "framework-module-api-defaults-module_libs_api",
Anton Hansson26e1ed62020-03-23 13:30:01 +0000191 args: mainline_framework_stubs_args + module_libs,
Anton Hansson397eb472020-03-13 16:28:21 +0000192 libs: ["framework-annotations-lib"],
Jiyong Park7be934f2020-01-06 16:22:32 +0900193 installable: false,
Anton Hansson4d90a282020-03-09 19:14:28 +0000194 sdk_version: "module_current",
Anton Hansson087646e2020-03-24 15:21:01 +0000195 filter_packages: framework_packages_to_document,
Paul Duffin4c5dc182020-04-08 18:28:15 +0100196
197 // Do not generate stubs as they are not needed
198 generate_stubs: false,
199
Anton Hansson5d708e52020-01-17 19:03:34 +0000200 check_api: {
201 current: {
202 api_file: "api/module-lib-current.txt",
203 removed_api_file: "api/module-lib-removed.txt",
204 },
205 },
Jiyong Park7be934f2020-01-06 16:22:32 +0900206}
207
208stubs_defaults {
209 name: "framework-module-stubs-defaults-module_libs_api",
Anton Hansson26e1ed62020-03-23 13:30:01 +0000210 args: mainline_framework_stubs_args + module_libs + priv_apps,
Anton Hansson397eb472020-03-13 16:28:21 +0000211 libs: ["framework-annotations-lib"],
Anton Hansson24c88f42019-12-13 16:17:27 +0000212 installable: false,
Anton Hansson4d90a282020-03-09 19:14:28 +0000213 sdk_version: "module_current",
Anton Hansson087646e2020-03-24 15:21:01 +0000214 filter_packages: framework_packages_to_document,
Anton Hansson24c88f42019-12-13 16:17:27 +0000215}
Anton Hansson26e1ed62020-03-23 13:30:01 +0000216
217stubs_defaults {
218 name: "service-module-stubs-srcs-defaults",
219 args: mainline_service_stubs_args,
220 installable: false,
Anton Hanssonf68ef062020-03-27 15:09:26 +0000221 filter_packages: ["com.android."],
Anton Hansson26e1ed62020-03-23 13:30:01 +0000222 check_api: {
223 current: {
224 api_file: "api/current.txt",
225 removed_api_file: "api/removed.txt",
226 },
227 },
228}
229
230// Empty for now, but a convenient place to add rules for all
231// module java_library system_server stub libs.
232java_defaults {
233 name: "service-module-stubs-defaults",
234}