blob: 9a14ee6e47fc0b9465f786bd212dfce8b8f3bc3d [file] [log] [blame]
Anton Hanssonfcb91d42020-09-21 16:32:14 +01001// Copyright (C) 2020 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
15package {
16 default_visibility: ["//visibility:private"],
Bob Badour8a6a2bc2021-02-12 17:07:05 -080017 // See: http://go/android-license-faq
18 // A large-scale-change added 'default_applicable_licenses' to import
19 // all of the 'license_kinds' from "frameworks_base_license"
20 // to get the below license kinds:
21 // SPDX-license-identifier-Apache-2.0
22 // SPDX-license-identifier-MIT
23 // SPDX-license-identifier-Unicode-DFS
24 default_applicable_licenses: ["frameworks_base_license"],
Anton Hanssonfcb91d42020-09-21 16:32:14 +010025}
26
Anton Hansson0860aaf2021-10-08 16:48:03 +010027bootstrap_go_package {
28 name: "soong-api",
29 pkgPath: "android/soong/api",
30 deps: [
31 "blueprint",
32 "soong",
33 "soong-android",
34 "soong-genrule",
Anton Hanssoncb00f942022-01-13 09:45:12 +000035 "soong-java",
Anton Hansson0860aaf2021-10-08 16:48:03 +010036 ],
37 srcs: ["api.go"],
38 pluginFor: ["soong_build"],
39}
40
Anton Hanssone6737842021-09-27 12:18:20 +010041python_defaults {
42 name: "python3_version_defaults",
Pedro Loureirob91f45d2021-05-26 15:50:07 +000043 version: {
44 py2: {
45 enabled: false,
46 },
47 py3: {
48 enabled: true,
49 embedded_launcher: false,
50 },
51 },
52}
53
Anton Hanssone6737842021-09-27 12:18:20 +010054python_binary_host {
55 name: "api_versions_trimmer",
56 srcs: ["api_versions_trimmer.py"],
57 defaults: ["python3_version_defaults"],
58}
59
Pedro Loureirob91f45d2021-05-26 15:50:07 +000060python_test_host {
61 name: "api_versions_trimmer_unittests",
62 main: "api_versions_trimmer_unittests.py",
63 srcs: [
64 "api_versions_trimmer_unittests.py",
65 "api_versions_trimmer.py",
66 ],
Anton Hanssone6737842021-09-27 12:18:20 +010067 defaults: ["python3_version_defaults"],
Pedro Loureirob91f45d2021-05-26 15:50:07 +000068 test_options: {
69 unit_test: true,
70 },
Anton Hanssone6737842021-09-27 12:18:20 +010071}
72
73python_binary_host {
74 name: "merge_annotation_zips",
75 srcs: ["merge_annotation_zips.py"],
76 defaults: ["python3_version_defaults"],
77}
78
79python_test_host {
80 name: "merge_annotation_zips_test",
81 main: "merge_annotation_zips_test.py",
82 srcs: [
83 "merge_annotation_zips.py",
84 "merge_annotation_zips_test.py",
85 ],
86 defaults: ["python3_version_defaults"],
87 test_options: {
88 unit_test: true,
Pedro Loureirob91f45d2021-05-26 15:50:07 +000089 },
90}
91
Anton Hanssonaa26cc12021-02-15 10:52:33 +000092metalava_cmd = "$(location metalava)"
93// Silence reflection warnings. See b/168689341
94metalava_cmd += " -J--add-opens=java.base/java.util=ALL-UNNAMED "
Anton Hanssonb8ce0812021-08-24 12:08:39 +010095metalava_cmd += " --quiet --no-banner --format=v2 "
Anton Hanssonaa26cc12021-02-15 10:52:33 +000096
Sasha Smundak02cbff442019-08-15 08:27:51 -070097genrule {
98 name: "current-api-xml",
99 tools: ["metalava"],
Anton Hansson00febe22020-11-05 10:30:59 +0000100 srcs: [":frameworks-base-api-current.txt"],
Sasha Smundak02cbff442019-08-15 08:27:51 -0700101 out: ["current.api"],
Anton Hanssonaa26cc12021-02-15 10:52:33 +0000102 cmd: metalava_cmd + "-convert2xmlnostrip $(in) $(out)",
Anton Hanssonfcb91d42020-09-21 16:32:14 +0100103 visibility: ["//visibility:public"],
Sasha Smundak02cbff442019-08-15 08:27:51 -0700104}
Anton Hansson85359f62020-09-21 17:02:25 +0100105
Anton Hanssonec450c02022-01-11 16:37:05 +0000106combined_apis {
107 name: "frameworks-base-api",
108 bootclasspath: [
109 "android.net.ipsec.ike",
110 "art.module.public.api",
111 "conscrypt.module.public.api",
112 "framework-appsearch",
Roopa Sattiraju86058b62022-01-20 10:05:19 -0800113 "framework-bluetooth",
Anton Hanssonec450c02022-01-11 16:37:05 +0000114 "framework-connectivity",
paulhu2a8c2c32022-02-08 21:23:06 +0800115 "framework-connectivity-t",
Anton Hanssonec450c02022-01-11 16:37:05 +0000116 "framework-graphics",
117 "framework-media",
118 "framework-mediaprovider",
119 "framework-permission",
120 "framework-permission-s",
121 "framework-scheduling",
122 "framework-sdkextensions",
123 "framework-statsd",
124 "framework-tethering",
125 "framework-wifi",
126 "i18n.module.public.api",
Anton Hansson85359f62020-09-21 17:02:25 +0100127 ],
Anton Hanssonec450c02022-01-11 16:37:05 +0000128 system_server_classpath: [
129 "service-media-s",
130 "service-permission",
Anton Hanssona9ced802020-10-20 19:26:18 +0100131 ],
Anton Hansson85359f62020-09-21 17:02:25 +0100132}
133
134genrule {
Anton Hansson0d6eae62021-02-12 16:47:18 +0000135 name: "frameworks-base-api-current-compat",
136 srcs: [
137 ":android.api.public.latest",
138 ":android-incompatibilities.api.public.latest",
139 ":frameworks-base-api-current.txt",
140 ],
Anton Hanssonb8ce0812021-08-24 12:08:39 +0100141 out: ["updated-baseline.txt"],
Anton Hansson0d6eae62021-02-12 16:47:18 +0000142 tools: ["metalava"],
Anton Hanssonaa26cc12021-02-15 10:52:33 +0000143 cmd: metalava_cmd +
Anton Hansson0d6eae62021-02-12 16:47:18 +0000144 "--check-compatibility:api:released $(location :android.api.public.latest) " +
145 "--baseline:compatibility:released $(location :android-incompatibilities.api.public.latest) " +
Anton Hanssonb8ce0812021-08-24 12:08:39 +0100146 "--update-baseline:compatibility:released $(genDir)/updated-baseline.txt " +
147 "$(location :frameworks-base-api-current.txt)",
Anton Hansson0d6eae62021-02-12 16:47:18 +0000148}
149
150genrule {
Anton Hansson0d6eae62021-02-12 16:47:18 +0000151 name: "frameworks-base-api-system-current-compat",
152 srcs: [
153 ":android.api.system.latest",
154 ":android-incompatibilities.api.system.latest",
155 ":frameworks-base-api-current.txt",
156 ":frameworks-base-api-system-current.txt",
157 ],
Anton Hanssonb8ce0812021-08-24 12:08:39 +0100158 out: ["updated-baseline.txt"],
Anton Hansson0d6eae62021-02-12 16:47:18 +0000159 tools: ["metalava"],
Anton Hanssonaa26cc12021-02-15 10:52:33 +0000160 cmd: metalava_cmd +
Anton Hansson0d6eae62021-02-12 16:47:18 +0000161 "--check-compatibility:api:released $(location :android.api.system.latest) " +
162 "--check-compatibility:base $(location :frameworks-base-api-current.txt) " +
163 "--baseline:compatibility:released $(location :android-incompatibilities.api.system.latest) " +
Anton Hanssonb8ce0812021-08-24 12:08:39 +0100164 "--update-baseline:compatibility:released $(genDir)/updated-baseline.txt " +
165 "$(location :frameworks-base-api-system-current.txt)",
Anton Hansson0d6eae62021-02-12 16:47:18 +0000166}
167
168genrule {
Anton Hansson0d6eae62021-02-12 16:47:18 +0000169 name: "frameworks-base-api-module-lib-current-compat",
170 srcs: [
171 ":android.api.module-lib.latest",
172 ":android-incompatibilities.api.module-lib.latest",
173 ":frameworks-base-api-current.txt",
174 ":frameworks-base-api-module-lib-current.txt",
175 ],
Anton Hanssonb8ce0812021-08-24 12:08:39 +0100176 out: ["updated-baseline.txt"],
Anton Hansson0d6eae62021-02-12 16:47:18 +0000177 tools: ["metalava"],
Anton Hanssonaa26cc12021-02-15 10:52:33 +0000178 cmd: metalava_cmd +
Anton Hansson0d6eae62021-02-12 16:47:18 +0000179 "--check-compatibility:api:released $(location :android.api.module-lib.latest) " +
180 // Note: having "public" be the base of module-lib is not perfect -- it should
Anton Hansson9d34e312022-02-23 11:24:00 +0000181 // ideally be a merged public+system (which metalava is not currently able to generate).
182 // This "base" will help when migrating from MODULE_LIBS -> public, but not when
183 // migrating from MODULE_LIBS -> system (where it needs to instead be listed as
184 // an incompatibility).
Anton Hansson0d6eae62021-02-12 16:47:18 +0000185 "--check-compatibility:base $(location :frameworks-base-api-current.txt) " +
186 "--baseline:compatibility:released $(location :android-incompatibilities.api.module-lib.latest) " +
Anton Hanssonb8ce0812021-08-24 12:08:39 +0100187 "--update-baseline:compatibility:released $(genDir)/updated-baseline.txt " +
188 "$(location :frameworks-base-api-module-lib-current.txt)",
Anton Hansson0d6eae62021-02-12 16:47:18 +0000189}
190
Anton Hansson0c5d9ab2022-06-23 07:58:51 +0000191// This produces the same annotations.zip as framework-doc-stubs, but by using
192// outputs from individual modules instead of all the source code.
193genrule {
194 name: "sdk-annotations.zip",
195 srcs: [
196 ":android-non-updatable-doc-stubs{.annotations.zip}",
197 ":all-modules-public-annotations",
198 ],
199 out: ["annotations.zip"],
200 tools: [
201 "merge_annotation_zips",
202 "soong_zip",
203 ],
204 cmd: "$(location merge_annotation_zips) $(genDir)/out $(in) && " +
205 "$(location soong_zip) -o $(out) -C $(genDir)/out -D $(genDir)/out",
206}
207
Anton Hansson0d6eae62021-02-12 16:47:18 +0000208genrule {
Anton Hanssona15427a2020-10-02 18:21:14 +0100209 name: "combined-removed-dex",
Paul Duffin81af1f52021-04-08 19:22:50 +0100210 visibility: [
211 "//frameworks/base/boot",
212 ],
Anton Hanssona15427a2020-10-02 18:21:14 +0100213 srcs: [
Anton Hansson1c4fab42020-11-02 11:57:33 +0000214 ":frameworks-base-api-removed.txt",
215 ":frameworks-base-api-system-removed.txt",
Anton Hanssona15427a2020-10-02 18:21:14 +0100216 ":android.car-stubs-docs{.removed-api.txt}",
217 ":android.car-system-stubs-docs{.removed-api.txt}",
218 ],
219 tool_files: ["gen_combined_removed_dex.sh"],
220 tools: ["metalava"],
221 out: ["combined-removed-dex.txt"],
222 cmd: "$(location gen_combined_removed_dex.sh) $(location metalava) $(genDir) $(in) > $(out)",
223}