blob: c3f3029b6ed506b4a134f67cca5d56ebc86b2466 [file] [log] [blame]
Liz Kammerea6666f2021-02-17 10:17:28 -05001// Copyright 2021 Google Inc. All rights reserved.
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 android
16
Liz Kammerba3ea162021-02-17 13:22:03 -050017import (
Wei Libafb6d62021-12-10 03:14:59 -080018 "bufio"
19 "errors"
Liz Kammerba3ea162021-02-17 13:22:03 -050020 "fmt"
21 "io/ioutil"
22 "path/filepath"
23 "strings"
24
Liz Kammerbdc60992021-02-24 16:55:11 -050025 "github.com/google/blueprint"
Liz Kammerba3ea162021-02-17 13:22:03 -050026 "github.com/google/blueprint/proptools"
27)
28
Jingwen Chen01812022021-11-19 14:29:43 +000029type bazelModuleProperties struct {
30 // The label of the Bazel target replacing this Soong module. When run in conversion mode, this
31 // will import the handcrafted build target into the autogenerated file. Note: this may result in
32 // a conflict due to duplicate targets if bp2build_available is also set.
33 Label *string
34
35 // If true, bp2build will generate the converted Bazel target for this module. Note: this may
36 // cause a conflict due to the duplicate targets if label is also set.
37 //
38 // This is a bool pointer to support tristates: true, false, not set.
39 //
40 // To opt-in a module, set bazel_module: { bp2build_available: true }
41 // To opt-out a module, set bazel_module: { bp2build_available: false }
42 // To defer the default setting for the directory, do not set the value.
43 Bp2build_available *bool
Liz Kammerbe46fcc2021-11-01 15:32:43 -040044
45 // CanConvertToBazel is set via InitBazelModule to indicate that a module type can be converted to
46 // Bazel with Bp2build.
47 CanConvertToBazel bool `blueprint:"mutated"`
Jingwen Chen01812022021-11-19 14:29:43 +000048}
49
Liz Kammerba3ea162021-02-17 13:22:03 -050050// Properties contains common module properties for Bazel migration purposes.
51type properties struct {
52 // In USE_BAZEL_ANALYSIS=1 mode, this represents the Bazel target replacing
53 // this Soong module.
Jingwen Chen01812022021-11-19 14:29:43 +000054 Bazel_module bazelModuleProperties
Liz Kammerba3ea162021-02-17 13:22:03 -050055}
Liz Kammerea6666f2021-02-17 10:17:28 -050056
Jingwen Chen25825ca2021-11-15 12:28:43 +000057// namespacedVariableProperties is a map from a string representing a Soong
Jingwen Chen84817de2021-11-17 10:57:35 +000058// config variable namespace, like "android" or "vendor_name" to a slice of
59// pointer to a struct containing a single field called Soong_config_variables
60// whose value mirrors the structure in the Blueprint file.
61type namespacedVariableProperties map[string][]interface{}
Jingwen Chena47f28d2021-11-02 16:43:57 +000062
Liz Kammerea6666f2021-02-17 10:17:28 -050063// BazelModuleBase contains the property structs with metadata for modules which can be converted to
64// Bazel.
65type BazelModuleBase struct {
Liz Kammerba3ea162021-02-17 13:22:03 -050066 bazelProperties properties
Jingwen Chena47f28d2021-11-02 16:43:57 +000067
68 // namespacedVariableProperties is used for soong_config_module_type support
69 // in bp2build. Soong config modules allow users to set module properties
70 // based on custom product variables defined in Android.bp files. These
71 // variables are namespaced to prevent clobbering, especially when set from
72 // Makefiles.
73 namespacedVariableProperties namespacedVariableProperties
74
75 // baseModuleType is set when this module was created from a module type
76 // defined by a soong_config_module_type. Every soong_config_module_type
77 // "wraps" another module type, e.g. a soong_config_module_type can wrap a
78 // cc_defaults to a custom_cc_defaults, or cc_binary to a custom_cc_binary.
79 // This baseModuleType is set to the wrapped module type.
80 baseModuleType string
Liz Kammerea6666f2021-02-17 10:17:28 -050081}
82
83// Bazelable is specifies the interface for modules that can be converted to Bazel.
84type Bazelable interface {
Liz Kammerba3ea162021-02-17 13:22:03 -050085 bazelProps() *properties
86 HasHandcraftedLabel() bool
Liz Kammerbdc60992021-02-24 16:55:11 -050087 HandcraftedLabel() string
88 GetBazelLabel(ctx BazelConversionPathContext, module blueprint.Module) string
Liz Kammerbe46fcc2021-11-01 15:32:43 -040089 ShouldConvertWithBp2build(ctx BazelConversionContext) bool
90 shouldConvertWithBp2build(ctx BazelConversionContext, module blueprint.Module) bool
Liz Kammerba3ea162021-02-17 13:22:03 -050091 GetBazelBuildFileContents(c Config, path, name string) (string, error)
Liz Kammerbe46fcc2021-11-01 15:32:43 -040092 ConvertWithBp2build(ctx TopDownMutatorContext)
Jingwen Chena47f28d2021-11-02 16:43:57 +000093
Jingwen Chen84817de2021-11-17 10:57:35 +000094 // namespacedVariableProps is a map from a soong config variable namespace
95 // (e.g. acme, android) to a map of interfaces{}, which are really
96 // reflect.Struct pointers, representing the value of the
97 // soong_config_variables property of a module. The struct pointer is the
98 // one with the single member called Soong_config_variables, which itself is
99 // a struct containing fields for each supported feature in that namespace.
100 //
101 // The reason for using an slice of interface{} is to support defaults
102 // propagation of the struct pointers.
Jingwen Chena47f28d2021-11-02 16:43:57 +0000103 namespacedVariableProps() namespacedVariableProperties
104 setNamespacedVariableProps(props namespacedVariableProperties)
105 BaseModuleType() string
Jingwen Chen84817de2021-11-17 10:57:35 +0000106 SetBaseModuleType(baseModuleType string)
Liz Kammerea6666f2021-02-17 10:17:28 -0500107}
108
109// BazelModule is a lightweight wrapper interface around Module for Bazel-convertible modules.
110type BazelModule interface {
111 Module
112 Bazelable
113}
114
115// InitBazelModule is a wrapper function that decorates a BazelModule with Bazel-conversion
116// properties.
117func InitBazelModule(module BazelModule) {
118 module.AddProperties(module.bazelProps())
Liz Kammerbe46fcc2021-11-01 15:32:43 -0400119 module.bazelProps().Bazel_module.CanConvertToBazel = true
Liz Kammerea6666f2021-02-17 10:17:28 -0500120}
121
122// bazelProps returns the Bazel properties for the given BazelModuleBase.
Liz Kammerba3ea162021-02-17 13:22:03 -0500123func (b *BazelModuleBase) bazelProps() *properties {
Liz Kammerea6666f2021-02-17 10:17:28 -0500124 return &b.bazelProperties
125}
126
Jingwen Chena47f28d2021-11-02 16:43:57 +0000127func (b *BazelModuleBase) namespacedVariableProps() namespacedVariableProperties {
128 return b.namespacedVariableProperties
129}
130
131func (b *BazelModuleBase) setNamespacedVariableProps(props namespacedVariableProperties) {
132 b.namespacedVariableProperties = props
133}
134
135func (b *BazelModuleBase) BaseModuleType() string {
136 return b.baseModuleType
137}
138
139func (b *BazelModuleBase) SetBaseModuleType(baseModuleType string) {
140 b.baseModuleType = baseModuleType
141}
142
Liz Kammerba3ea162021-02-17 13:22:03 -0500143// HasHandcraftedLabel returns whether this module has a handcrafted Bazel label.
144func (b *BazelModuleBase) HasHandcraftedLabel() bool {
145 return b.bazelProperties.Bazel_module.Label != nil
146}
147
148// HandcraftedLabel returns the handcrafted label for this module, or empty string if there is none
149func (b *BazelModuleBase) HandcraftedLabel() string {
150 return proptools.String(b.bazelProperties.Bazel_module.Label)
151}
152
Liz Kammerea6666f2021-02-17 10:17:28 -0500153// GetBazelLabel returns the Bazel label for the given BazelModuleBase.
Liz Kammerbdc60992021-02-24 16:55:11 -0500154func (b *BazelModuleBase) GetBazelLabel(ctx BazelConversionPathContext, module blueprint.Module) string {
155 if b.HasHandcraftedLabel() {
156 return b.HandcraftedLabel()
157 }
Liz Kammerbe46fcc2021-11-01 15:32:43 -0400158 if b.ShouldConvertWithBp2build(ctx) {
Liz Kammerbdc60992021-02-24 16:55:11 -0500159 return bp2buildModuleLabel(ctx, module)
160 }
161 return "" // no label for unconverted module
Liz Kammerea6666f2021-02-17 10:17:28 -0500162}
163
Jingwen Chen12b4c272021-03-10 02:05:59 -0500164// Configuration to decide if modules in a directory should default to true/false for bp2build_available
165type Bp2BuildConfig map[string]BazelConversionConfigEntry
166type BazelConversionConfigEntry int
167
168const (
Jingwen Chen91220d72021-03-24 02:18:33 -0400169 // A sentinel value to be used as a key in Bp2BuildConfig for modules with
170 // no package path. This is also the module dir for top level Android.bp
171 // modules.
172 BP2BUILD_TOPLEVEL = "."
173
Jingwen Chen12b4c272021-03-10 02:05:59 -0500174 // iota + 1 ensures that the int value is not 0 when used in the Bp2buildAllowlist map,
175 // which can also mean that the key doesn't exist in a lookup.
176
177 // all modules in this package and subpackages default to bp2build_available: true.
178 // allows modules to opt-out.
179 Bp2BuildDefaultTrueRecursively BazelConversionConfigEntry = iota + 1
180
Jingwen Chen294e7742021-08-31 05:58:01 +0000181 // all modules in this package (not recursively) default to bp2build_available: true.
182 // allows modules to opt-out.
183 Bp2BuildDefaultTrue
184
Jingwen Chen12b4c272021-03-10 02:05:59 -0500185 // all modules in this package (not recursively) default to bp2build_available: false.
186 // allows modules to opt-in.
187 Bp2BuildDefaultFalse
188)
189
190var (
Rupert Shuttleworth00960792021-05-12 21:20:13 -0400191 // Keep any existing BUILD files (and do not generate new BUILD files) for these directories
Jingwen Chenb643c7a2021-07-26 04:45:48 +0000192 // in the synthetic Bazel workspace.
Rupert Shuttleworth00960792021-05-12 21:20:13 -0400193 bp2buildKeepExistingBuildFile = map[string]bool{
194 // This is actually build/bazel/build.BAZEL symlinked to ./BUILD
Jingwen Chenf59a8e12021-07-16 09:28:53 +0000195 ".":/*recursive = */ false,
Rupert Shuttleworth00960792021-05-12 21:20:13 -0400196
Jingwen Chenb643c7a2021-07-26 04:45:48 +0000197 // build/bazel/examples/apex/... BUILD files should be generated, so
198 // build/bazel is not recursive. Instead list each subdirectory under
199 // build/bazel explicitly.
200 "build/bazel":/* recursive = */ false,
Jingwen Chen941f0ab2022-02-09 13:25:30 +0000201 "build/bazel/ci/dist":/* recursive = */ false,
Jingwen Chenb643c7a2021-07-26 04:45:48 +0000202 "build/bazel/examples/android_app":/* recursive = */ true,
Romain Jobredeaux5cc9c9d2021-08-26 15:07:48 +0000203 "build/bazel/examples/java":/* recursive = */ true,
Jingwen Chenb643c7a2021-07-26 04:45:48 +0000204 "build/bazel/bazel_skylib":/* recursive = */ true,
205 "build/bazel/rules":/* recursive = */ true,
206 "build/bazel/rules_cc":/* recursive = */ true,
Jingwen Chen294e7742021-08-31 05:58:01 +0000207 "build/bazel/scripts":/* recursive = */ true,
Jingwen Chenb643c7a2021-07-26 04:45:48 +0000208 "build/bazel/tests":/* recursive = */ true,
209 "build/bazel/platforms":/* recursive = */ true,
210 "build/bazel/product_variables":/* recursive = */ true,
Wei Li17141042022-02-22 12:36:33 -0800211 "build/bazel/vendor/google":/* recursive = */ true,
Jingwen Chen5e49b822021-08-24 05:14:22 +0000212 "build/bazel_common_rules":/* recursive = */ true,
Wei Libafb6d62021-12-10 03:14:59 -0800213 // build/make/tools/signapk BUILD file is generated, so build/make/tools is not recursive.
214 "build/make/tools":/* recursive = */ false,
Rupert Shuttleworth00960792021-05-12 21:20:13 -0400215 "build/pesto":/* recursive = */ true,
216
217 // external/bazelbuild-rules_android/... is needed by mixed builds, otherwise mixed builds analysis fails
218 // e.g. ERROR: Analysis of target '@soong_injection//mixed_builds:buildroot' failed
219 "external/bazelbuild-rules_android":/* recursive = */ true,
Jingwen Chen91632252021-08-10 13:00:33 +0000220 "external/bazel-skylib":/* recursive = */ true,
Romain Jobredeaux9e09bba2021-09-08 18:09:02 +0000221 "external/guava":/* recursive = */ true,
Romain Jobredeaux9e09bba2021-09-08 18:09:02 +0000222 "external/jsr305":/* recursive = */ true,
223 "frameworks/ex/common":/* recursive = */ true,
Rupert Shuttleworth00960792021-05-12 21:20:13 -0400224
Romain Jobredeauxf1b0ac82021-08-12 14:39:00 +0000225 "packages/apps/Music":/* recursive = */ true,
Romain Jobredeaux9e09bba2021-09-08 18:09:02 +0000226 "packages/apps/QuickSearchBox":/* recursive = */ true,
Romain Jobredeauxa2c08142021-09-22 14:43:43 -0400227 "packages/apps/WallpaperPicker":/* recursive = */ false,
228
Wei Li17141042022-02-22 12:36:33 -0800229 "prebuilts/bundletool":/* recursive = */ true,
Chris Parsons494eef32021-11-09 10:29:52 -0500230 "prebuilts/gcc":/* recursive = */ true,
Jingwen Chen0ee88a62022-01-07 14:55:29 +0000231 "prebuilts/build-tools":/* recursive = */ false,
Sam Delmerico9dfb1392022-02-10 21:11:59 +0000232 "prebuilts/jdk/jdk11":/* recursive = */ false,
Romain Jobredeauxa2c08142021-09-22 14:43:43 -0400233 "prebuilts/sdk":/* recursive = */ false,
234 "prebuilts/sdk/current/extras/app-toolkit":/* recursive = */ false,
235 "prebuilts/sdk/current/support":/* recursive = */ false,
236 "prebuilts/sdk/tools":/* recursive = */ false,
237 "prebuilts/r8":/* recursive = */ false,
Rupert Shuttleworth2a4fc3e2021-04-21 07:10:09 -0400238 }
239
Jingwen Chen12b4c272021-03-10 02:05:59 -0500240 // Configure modules in these directories to enable bp2build_available: true or false by default.
241 bp2buildDefaultConfig = Bp2BuildConfig{
Liz Kammer35ca77e2021-12-22 15:31:40 -0500242 "art/libartpalette": Bp2BuildDefaultTrueRecursively,
Romain Jobredeaux1282c422021-10-29 10:52:59 -0400243 "art/libdexfile": Bp2BuildDefaultTrueRecursively,
Liz Kammerdaa09ef2021-12-15 15:35:38 -0500244 "art/runtime": Bp2BuildDefaultTrueRecursively,
245 "art/tools": Bp2BuildDefaultTrue,
Romain Jobredeaux1282c422021-10-29 10:52:59 -0400246 "bionic": Bp2BuildDefaultTrueRecursively,
247 "bootable/recovery/tools/recovery_l10n": Bp2BuildDefaultTrue,
Jingwen Chen0a9d09f2021-11-24 07:00:11 +0000248 "build/bazel/examples/soong_config_variables": Bp2BuildDefaultTrueRecursively,
Chris Parsonsa37e1952021-09-28 16:47:36 -0400249 "build/bazel/examples/apex/minimal": Bp2BuildDefaultTrueRecursively,
Wei Libafb6d62021-12-10 03:14:59 -0800250 "build/make/tools/signapk": Bp2BuildDefaultTrue,
Sam Delmerico9dfb1392022-02-10 21:11:59 +0000251 "build/make/target/product/security": Bp2BuildDefaultTrue,
Chris Parsons8a498162021-11-18 17:19:12 -0500252 "build/soong": Bp2BuildDefaultTrue,
Rupert Shuttleworth2ac9c482021-11-10 10:37:05 -0500253 "build/soong/cc/libbuildversion": Bp2BuildDefaultTrue, // Skip tests subdir
Jingwen Chen89e21882021-11-30 11:16:06 +0000254 "build/soong/cc/ndkstubgen": Bp2BuildDefaultTrue,
255 "build/soong/cc/symbolfile": Bp2BuildDefaultTrue,
Liz Kammerdaa09ef2021-12-15 15:35:38 -0500256 "build/soong/linkerconfig": Bp2BuildDefaultTrueRecursively,
Liz Kammer5c313582021-12-03 15:23:26 -0500257 "build/soong/scripts": Bp2BuildDefaultTrueRecursively,
Chris Parsons8a498162021-11-18 17:19:12 -0500258 "cts/common/device-side/nativetesthelper/jni": Bp2BuildDefaultTrueRecursively,
Romain Jobredeaux1282c422021-10-29 10:52:59 -0400259 "development/apps/DevelopmentSettings": Bp2BuildDefaultTrue,
260 "development/apps/Fallback": Bp2BuildDefaultTrue,
261 "development/apps/WidgetPreview": Bp2BuildDefaultTrue,
262 "development/samples/BasicGLSurfaceView": Bp2BuildDefaultTrue,
263 "development/samples/BluetoothChat": Bp2BuildDefaultTrue,
264 "development/samples/BrokenKeyDerivation": Bp2BuildDefaultTrue,
265 "development/samples/Compass": Bp2BuildDefaultTrue,
266 "development/samples/ContactManager": Bp2BuildDefaultTrue,
267 "development/samples/FixedGridLayout": Bp2BuildDefaultTrue,
268 "development/samples/HelloEffects": Bp2BuildDefaultTrue,
269 "development/samples/Home": Bp2BuildDefaultTrue,
270 "development/samples/HoneycombGallery": Bp2BuildDefaultTrue,
271 "development/samples/JetBoy": Bp2BuildDefaultTrue,
272 "development/samples/KeyChainDemo": Bp2BuildDefaultTrue,
273 "development/samples/LceDemo": Bp2BuildDefaultTrue,
274 "development/samples/LunarLander": Bp2BuildDefaultTrue,
275 "development/samples/MultiResolution": Bp2BuildDefaultTrue,
276 "development/samples/MultiWindow": Bp2BuildDefaultTrue,
277 "development/samples/NotePad": Bp2BuildDefaultTrue,
278 "development/samples/Obb": Bp2BuildDefaultTrue,
279 "development/samples/RSSReader": Bp2BuildDefaultTrue,
280 "development/samples/ReceiveShareDemo": Bp2BuildDefaultTrue,
281 "development/samples/SearchableDictionary": Bp2BuildDefaultTrue,
282 "development/samples/SipDemo": Bp2BuildDefaultTrue,
283 "development/samples/SkeletonApp": Bp2BuildDefaultTrue,
284 "development/samples/Snake": Bp2BuildDefaultTrue,
285 "development/samples/SpellChecker/": Bp2BuildDefaultTrueRecursively,
286 "development/samples/ThemedNavBarKeyboard": Bp2BuildDefaultTrue,
287 "development/samples/ToyVpn": Bp2BuildDefaultTrue,
288 "development/samples/TtsEngine": Bp2BuildDefaultTrue,
289 "development/samples/USB/AdbTest": Bp2BuildDefaultTrue,
290 "development/samples/USB/MissileLauncher": Bp2BuildDefaultTrue,
291 "development/samples/VoiceRecognitionService": Bp2BuildDefaultTrue,
292 "development/samples/VoicemailProviderDemo": Bp2BuildDefaultTrue,
Romain Jobredeaux355851b2022-01-13 17:07:01 +0000293 "development/samples/WiFiDirectDemo": Bp2BuildDefaultTrue,
Chris Parsonsa37e1952021-09-28 16:47:36 -0400294 "development/sdk": Bp2BuildDefaultTrueRecursively,
295 "external/arm-optimized-routines": Bp2BuildDefaultTrueRecursively,
Jingwen Chen398a32d2022-03-08 08:03:28 +0000296 "external/auto/android-annotation-stubs": Bp2BuildDefaultTrueRecursively,
Sam Delmerico4c7069f2022-02-03 17:50:03 +0000297 "external/auto/common": Bp2BuildDefaultTrueRecursively,
298 "external/auto/service": Bp2BuildDefaultTrueRecursively,
Chris Parsonsa37e1952021-09-28 16:47:36 -0400299 "external/boringssl": Bp2BuildDefaultTrueRecursively,
Wei Libafb6d62021-12-10 03:14:59 -0800300 "external/bouncycastle": Bp2BuildDefaultTrue,
Chris Parsonsa37e1952021-09-28 16:47:36 -0400301 "external/brotli": Bp2BuildDefaultTrue,
Wei Libafb6d62021-12-10 03:14:59 -0800302 "external/conscrypt": Bp2BuildDefaultTrue,
Jingwen Chenf2504b62022-03-17 14:51:38 +0000303 "external/e2fsprogs": Bp2BuildDefaultTrueRecursively,
Sam Delmericofde9fb52022-01-28 20:53:38 +0000304 "external/error_prone": Bp2BuildDefaultTrueRecursively,
Chris Parsonsa37e1952021-09-28 16:47:36 -0400305 "external/fmtlib": Bp2BuildDefaultTrueRecursively,
Chris Parsonsb97a8172021-10-04 12:48:29 -0400306 "external/google-benchmark": Bp2BuildDefaultTrueRecursively,
Chris Parsons8a498162021-11-18 17:19:12 -0500307 "external/googletest": Bp2BuildDefaultTrueRecursively,
Chris Parsonsa37e1952021-09-28 16:47:36 -0400308 "external/gwp_asan": Bp2BuildDefaultTrueRecursively,
Liz Kammer35ca77e2021-12-22 15:31:40 -0500309 "external/icu": Bp2BuildDefaultTrueRecursively,
310 "external/icu/android_icu4j": Bp2BuildDefaultFalse, // java rules incomplete
311 "external/icu/icu4j": Bp2BuildDefaultFalse, // java rules incomplete
Sam Delmerico4c7069f2022-02-03 17:50:03 +0000312 "external/javapoet": Bp2BuildDefaultTrueRecursively,
Chris Parsonsa37e1952021-09-28 16:47:36 -0400313 "external/jemalloc_new": Bp2BuildDefaultTrueRecursively,
Chris Parsonsb97a8172021-10-04 12:48:29 -0400314 "external/jsoncpp": Bp2BuildDefaultTrueRecursively,
Chris Parsonsa37e1952021-09-28 16:47:36 -0400315 "external/libcap": Bp2BuildDefaultTrueRecursively,
316 "external/libcxx": Bp2BuildDefaultTrueRecursively,
317 "external/libcxxabi": Bp2BuildDefaultTrueRecursively,
Chris Parsons8a498162021-11-18 17:19:12 -0500318 "external/libevent": Bp2BuildDefaultTrueRecursively,
Liz Kammerb5b478d2021-12-15 13:00:21 -0500319 "external/libpng": Bp2BuildDefaultTrueRecursively,
Chris Parsonsa37e1952021-09-28 16:47:36 -0400320 "external/lz4/lib": Bp2BuildDefaultTrue,
Chris Parsons8a498162021-11-18 17:19:12 -0500321 "external/lzma/C": Bp2BuildDefaultTrueRecursively,
Liz Kammer2fc34892021-10-11 12:56:48 -0400322 "external/mdnsresponder": Bp2BuildDefaultTrueRecursively,
323 "external/minijail": Bp2BuildDefaultTrueRecursively,
324 "external/pcre": Bp2BuildDefaultTrueRecursively,
Chris Parsonsa37e1952021-09-28 16:47:36 -0400325 "external/protobuf": Bp2BuildDefaultTrueRecursively,
326 "external/python/six": Bp2BuildDefaultTrueRecursively,
327 "external/scudo": Bp2BuildDefaultTrueRecursively,
Liz Kammer2fc34892021-10-11 12:56:48 -0400328 "external/selinux/libselinux": Bp2BuildDefaultTrueRecursively,
Liz Kammerb5b478d2021-12-15 13:00:21 -0500329 "external/selinux/libsepol": Bp2BuildDefaultTrueRecursively,
Chris Parsonsa37e1952021-09-28 16:47:36 -0400330 "external/zlib": Bp2BuildDefaultTrueRecursively,
Liz Kammer2fc34892021-10-11 12:56:48 -0400331 "external/zstd": Bp2BuildDefaultTrueRecursively,
Romain Jobredeaux1282c422021-10-29 10:52:59 -0400332 "frameworks/base/media/tests/MediaDump": Bp2BuildDefaultTrue,
333 "frameworks/base/startop/apps/test": Bp2BuildDefaultTrue,
Sam Delmerico9dfb1392022-02-10 21:11:59 +0000334 "frameworks/base/tests/appwidgets/AppWidgetHostTest": Bp2BuildDefaultTrueRecursively,
Chris Parsonsa37e1952021-09-28 16:47:36 -0400335 "frameworks/native/libs/adbd_auth": Bp2BuildDefaultTrueRecursively,
Romain Jobredeaux1282c422021-10-29 10:52:59 -0400336 "frameworks/native/opengl/tests/gl2_cameraeye": Bp2BuildDefaultTrue,
337 "frameworks/native/opengl/tests/gl2_java": Bp2BuildDefaultTrue,
338 "frameworks/native/opengl/tests/testLatency": Bp2BuildDefaultTrue,
339 "frameworks/native/opengl/tests/testPauseResume": Bp2BuildDefaultTrue,
340 "frameworks/native/opengl/tests/testViewport": Bp2BuildDefaultTrue,
Chris Parsons8a498162021-11-18 17:19:12 -0500341 "frameworks/proto_logging/stats/stats_log_api_gen": Bp2BuildDefaultTrueRecursively,
342 "libnativehelper": Bp2BuildDefaultTrueRecursively,
Romain Jobredeaux1282c422021-10-29 10:52:59 -0400343 "packages/apps/DevCamera": Bp2BuildDefaultTrue,
344 "packages/apps/HTMLViewer": Bp2BuildDefaultTrue,
345 "packages/apps/Protips": Bp2BuildDefaultTrue,
Liz Kammerdaa09ef2021-12-15 15:35:38 -0500346 "packages/modules/StatsD/lib/libstatssocket": Bp2BuildDefaultTrueRecursively,
Chris Parsonsa37e1952021-09-28 16:47:36 -0400347 "packages/modules/adb": Bp2BuildDefaultTrue,
Jingwen Chend109bd92021-12-14 07:50:18 +0000348 "packages/modules/adb/apex": Bp2BuildDefaultTrue,
Chris Parsonsa37e1952021-09-28 16:47:36 -0400349 "packages/modules/adb/crypto": Bp2BuildDefaultTrueRecursively,
350 "packages/modules/adb/libs": Bp2BuildDefaultTrueRecursively,
351 "packages/modules/adb/pairing_auth": Bp2BuildDefaultTrueRecursively,
352 "packages/modules/adb/pairing_connection": Bp2BuildDefaultTrueRecursively,
353 "packages/modules/adb/proto": Bp2BuildDefaultTrueRecursively,
354 "packages/modules/adb/tls": Bp2BuildDefaultTrueRecursively,
Romain Jobredeaux1282c422021-10-29 10:52:59 -0400355 "packages/providers/MediaProvider/tools/dialogs": Bp2BuildDefaultTrue,
356 "packages/screensavers/Basic": Bp2BuildDefaultTrue,
357 "packages/services/Car/tests/SampleRearViewCamera": Bp2BuildDefaultTrue,
Chris Parsonsa37e1952021-09-28 16:47:36 -0400358 "prebuilts/clang/host/linux-x86": Bp2BuildDefaultTrueRecursively,
Romain Jobredeaux428a3662022-01-28 11:12:52 -0500359 "prebuilts/tools/common/m2": Bp2BuildDefaultTrue,
Jingwen Chend43d4a42021-11-23 12:40:11 +0000360 "system/apex": Bp2BuildDefaultFalse, // TODO(b/207466993): flaky failures
Liz Kammerdaa09ef2021-12-15 15:35:38 -0500361 "system/apex/proto": Bp2BuildDefaultTrueRecursively,
362 "system/apex/libs": Bp2BuildDefaultTrueRecursively,
Liz Kammeraabfb5d2021-12-08 15:25:06 -0500363 "system/core/debuggerd": Bp2BuildDefaultTrueRecursively,
Chris Parsonsa37e1952021-09-28 16:47:36 -0400364 "system/core/diagnose_usb": Bp2BuildDefaultTrueRecursively,
365 "system/core/libasyncio": Bp2BuildDefaultTrue,
366 "system/core/libcrypto_utils": Bp2BuildDefaultTrueRecursively,
367 "system/core/libcutils": Bp2BuildDefaultTrueRecursively,
Liz Kammer2fc34892021-10-11 12:56:48 -0400368 "system/core/libpackagelistparser": Bp2BuildDefaultTrueRecursively,
Chris Parsonsa37e1952021-09-28 16:47:36 -0400369 "system/core/libprocessgroup": Bp2BuildDefaultTrue,
Chris Parsonsb97a8172021-10-04 12:48:29 -0400370 "system/core/libprocessgroup/cgrouprc": Bp2BuildDefaultTrue,
371 "system/core/libprocessgroup/cgrouprc_format": Bp2BuildDefaultTrue,
Chris Parsons8a498162021-11-18 17:19:12 -0500372 "system/core/libsystem": Bp2BuildDefaultTrueRecursively,
373 "system/core/libutils": Bp2BuildDefaultTrueRecursively,
374 "system/core/libvndksupport": Bp2BuildDefaultTrueRecursively,
Lukacs T. Berki497f17d2021-04-26 12:15:57 +0200375 "system/core/property_service/libpropertyinfoparser": Bp2BuildDefaultTrueRecursively,
Chris Parsonsa37e1952021-09-28 16:47:36 -0400376 "system/libbase": Bp2BuildDefaultTrueRecursively,
Chris Parsons8a498162021-11-18 17:19:12 -0500377 "system/libprocinfo": Bp2BuildDefaultTrue,
Chris Parsonsc39f6332021-10-01 18:00:31 -0400378 "system/libziparchive": Bp2BuildDefaultTrueRecursively,
Chris Parsonsa37e1952021-09-28 16:47:36 -0400379 "system/logging/liblog": Bp2BuildDefaultTrueRecursively,
380 "system/sepolicy/apex": Bp2BuildDefaultTrueRecursively,
381 "system/timezone/apex": Bp2BuildDefaultTrueRecursively,
382 "system/timezone/output_data": Bp2BuildDefaultTrueRecursively,
Chris Parsons8a498162021-11-18 17:19:12 -0500383 "system/unwinding/libbacktrace": Bp2BuildDefaultTrueRecursively,
384 "system/unwinding/libunwindstack": Bp2BuildDefaultTrueRecursively,
Wei Libafb6d62021-12-10 03:14:59 -0800385 "tools/apksig": Bp2BuildDefaultTrue,
386 "tools/platform-compat/java/android/compat": Bp2BuildDefaultTrueRecursively,
Jingwen Chen12b4c272021-03-10 02:05:59 -0500387 }
Jingwen Chen5d72cba2021-03-25 09:28:38 +0000388
Sam Delmericofa1831c2022-02-22 18:07:55 +0000389 // Per-module allowlist to always opt modules in of both bp2build and mixed builds.
Jingwen Chen7edadab2022-03-04 07:01:29 +0000390 // These modules are usually in directories with many other modules that are not ready for
391 // conversion.
392 //
393 // A module can either be in this list or its directory allowlisted entirely
394 // in bp2buildDefaultConfig, but not both at the same time.
Sam Delmericofa1831c2022-02-22 18:07:55 +0000395 bp2buildModuleAlwaysConvertList = []string{
Jingwen Chen7edadab2022-03-04 07:01:29 +0000396 //external/avb
397 "avbtool",
398 "libavb",
399 "avb_headers",
400
401 //external/fec
402 "libfec_rs",
403
404 //system/core/libsparse
405 "libsparse",
406
407 //system/extras/ext4_utils
408 "libext4_utils",
409
410 //system/extras/libfec
411 "libfec",
412
413 //system/extras/squashfs_utils
414 "libsquashfs_utils",
415
416 //system/extras/verity/fec
417 "fec",
Sam Delmericofa1831c2022-02-22 18:07:55 +0000418 }
419
Sam Delmericoa9b047a2022-02-22 19:21:28 +0000420 // Per-module-type allowlist to always opt modules in to both bp2build and mixed builds
Sam Delmerico85d831a2022-03-07 19:12:42 +0000421 // when they have the same type as one listed.
Sam Delmericoa9b047a2022-02-22 19:21:28 +0000422 bp2buildModuleTypeAlwaysConvertList = []string{
423 "java_import",
424 }
Sam Delmerico85d831a2022-03-07 19:12:42 +0000425
Chris Parsonsbab4d7e2021-04-15 17:27:08 -0400426 // Per-module denylist to always opt modules out of both bp2build and mixed builds.
Rupert Shuttleworth4f43fe92021-03-30 14:13:16 +0000427 bp2buildModuleDoNotConvertList = []string{
Liz Kammerdaa09ef2021-12-15 15:35:38 -0500428 "libnativehelper_compat_libc", // Broken compile: implicit declaration of function 'strerror_r' is invalid in C99
429
430 "libart", // depends on unconverted modules: art_operator_srcs, libodrstatslog, libelffile, art_cmdlineparser_headers, cpp-define-generator-definitions, libcpu_features, libdexfile, libartpalette, libbacktrace, libnativebridge, libnativeloader, libsigchain, libunwindstack, libartbase, libprofile, cpp-define-generator-asm-support, apex-info-list-tinyxml, libtinyxml2, libnativeloader-headers, libstatssocket, heapprofd_client_api
431 "libart-runtime-gtest", // depends on unconverted modules: libgtest_isolated, libart-compiler, libdexfile, libprofile, libartbase, libbacktrace, libartbase-art-gtest
432 "libart_headers", // depends on unconverted modules: art_libartbase_headers
433 "libartd", // depends on unconverted modules: apex-info-list-tinyxml, libtinyxml2, libnativeloader-headers, libstatssocket, heapprofd_client_api, art_operator_srcs, libodrstatslog, libelffiled, art_cmdlineparser_headers, cpp-define-generator-definitions, libcpu_features, libdexfiled, libartpalette, libbacktrace, libnativebridge, libnativeloader, libsigchain, libunwindstack, libartbased, libprofiled, cpp-define-generator-asm-support
434 "libartd-runtime-gtest", // depends on unconverted modules: libgtest_isolated, libartd-compiler, libdexfiled, libprofiled, libartbased, libbacktrace, libartbased-art-gtest
435 "libstatslog_art", // depends on unconverted modules: statslog_art.cpp, statslog_art.h
436 "statslog_art.h", "statslog_art.cpp", // depends on unconverted modules: stats-log-api-gen
437
Chris Parsons8a498162021-11-18 17:19:12 -0500438 "libandroid_runtime_lazy", // depends on unconverted modules: libbinder_headers
439 "libcmd", // depends on unconverted modules: libbinder
440
Chris Parsons58852a02021-12-09 18:10:18 -0500441 "libdexfile_support_static", // Depends on unconverted module: libdexfile_external_headers
442 "libunwindstack_local", "libunwindstack_utils", "libc_malloc_debug", "libfdtrack", // Depends on unconverted module: libunwindstack
443
444 "libdexfile_support", // TODO(b/210546943): Enabled based on product variables.
445 "libdexfile_external_headers", // TODO(b/210546943): Enabled based on product variables.
446
447 "libunwindstack", // Depends on unconverted module libdexfile_support.
448 "libnativehelper_compat_libc++", // Broken compile: implicit declaration of function 'strerror_r' is invalid in C99
449
Chris Parsons8a498162021-11-18 17:19:12 -0500450 "chkcon", "sefcontext_compile", // depends on unconverted modules: libsepol
451
452 "libsepol", // TODO(b/207408632): Unsupported case of .l sources in cc library rules
453
Liz Kammer5c313582021-12-03 15:23:26 -0500454 "gen-kotlin-build-file.py", // module has same name as source
Chris Parsons8a498162021-11-18 17:19:12 -0500455
Chris Parsons8a498162021-11-18 17:19:12 -0500456 "libactivitymanager_aidl", // TODO(b/207426160): Depends on activity_manager_procstate_aidl, which is an aidl filegroup.
457
Liz Kammer5c313582021-12-03 15:23:26 -0500458 "libnativehelper_lazy_mts_jni", "libnativehelper_mts_jni", // depends on unconverted modules: libgmock_ndk
459 "libnativetesthelper_jni", "libgmock_main_ndk", "libgmock_ndk", // depends on unconverted module: libgtest_ndk_c++
Chris Parsons8a498162021-11-18 17:19:12 -0500460
461 "statslog-framework-java-gen", "statslog.cpp", "statslog.h", "statslog.rs", "statslog_header.rs", // depends on unconverted modules: stats-log-api-gen
462
463 "stats-log-api-gen", // depends on unconverted modules: libstats_proto_host, libprotobuf-cpp-full
464
465 "libstatslog", // depends on unconverted modules: statslog.cpp, statslog.h, ...
466
Chris Parsons8a498162021-11-18 17:19:12 -0500467 "cmd", // depends on unconverted module packagemanager_aidl-cpp, of unsupported type aidl_interface
468 "servicedispatcher", // depends on unconverted module android.debug_aidl, of unsupported type aidl_interface
469 "libutilscallstack", // depends on unconverted module libbacktrace
470 "libbacktrace", // depends on unconverted module libunwindstack
471 "libdebuggerd_handler", // depends on unconverted module libdebuggerd_handler_core
472 "libdebuggerd_handler_core", "libdebuggerd_handler_fallback", // depends on unconverted module libdebuggerd
Liz Kammeraabfb5d2021-12-08 15:25:06 -0500473 "unwind_for_offline", // depends on unconverted module libunwindstack_utils
474 "libdebuggerd", // depends on unconverted modules libdexfile_support, libunwindstack, gwp_asan_crash_handler, libtombstone_proto, libprotobuf-cpp-lite
475 "libdexfile_static", // depends on libartpalette, libartbase, libdexfile, which are of unsupported type: art_cc_library.
476
Liz Kammerdaa09ef2021-12-15 15:35:38 -0500477 "static_crasher", // depends on unconverted modules: libdebuggerd_handler
Chris Parsons8a498162021-11-18 17:19:12 -0500478
Liz Kammer5c313582021-12-03 15:23:26 -0500479 "pbtombstone", "crash_dump", // depends on libdebuggerd, libunwindstack
Rupert Shuttleworth47aa5842021-04-30 04:04:15 -0400480
Chris Parsonsc39f6332021-10-01 18:00:31 -0400481 "libbase_ndk", // http://b/186826477, fails to link libctscamera2_jni for device (required for CtsCameraTestCases)
Alex Márquez Pérez Muñíz Díaz Púras Thaureauxac5097f2021-09-01 21:22:09 +0000482
Wei Libafb6d62021-12-10 03:14:59 -0800483 "libprotobuf-internal-protos", // b/210751803, we don't handle path property for filegroups
484 "libprotobuf-internal-python-srcs", // b/210751803, we don't handle path property for filegroups
485 "libprotobuf-java-full", // b/210751803, we don't handle path property for filegroups
Sam Delmericofde9fb52022-01-28 20:53:38 +0000486 "host-libprotobuf-java-full", // b/210751803, we don't handle path property for filegroups
Wei Libafb6d62021-12-10 03:14:59 -0800487 "libprotobuf-java-util-full", // b/210751803, we don't handle path property for filegroups
Sam Delmericoc0161432022-02-25 21:34:51 +0000488 "apex_manifest_proto_java", // b/210751803, depends on libprotobuf-java-full
489 "conscrypt", // b/210751803, we don't handle path property for filegroups
490 "conscrypt-for-host", // b/210751803, we don't handle path property for filegroups
Sam Delmericofde9fb52022-01-28 20:53:38 +0000491
Sam Delmericoc0161432022-02-25 21:34:51 +0000492 "libprotobuf-java-nano", // b/220869005, depends on non-public_current SDK
493 "host-libprotobuf-java-nano", // b/220869005, depends on libprotobuf-java-nano
Liz Kammer0f3b7d22021-09-28 13:48:21 -0400494
Jingwen Chenf6b4cd42022-02-08 03:23:10 +0000495 "libc_musl_sysroot_bionic_arch_headers", // b/218405924, depends on soong_zip
496 "libc_musl_sysroot_bionic_headers", // b/218405924, depends on soong_zip and generates duplicate srcs
497
Liz Kammerdaa09ef2021-12-15 15:35:38 -0500498 // python protos
499 "libprotobuf-python", // contains .proto sources
500 "conv_linker_config", // depends on linker_config_proto, a python lib with proto sources
501 "apex_build_info_proto", "apex_manifest_proto", // a python lib with proto sources
502 "linker_config_proto", // contains .proto sources
Rupert Shuttleworth00960792021-05-12 21:20:13 -0400503
Chris Parsonsb97a8172021-10-04 12:48:29 -0400504 "brotli-fuzzer-corpus", // b/202015218: outputs are in location incompatible with bazel genrule handling.
Jingwen Chen294e7742021-08-31 05:58:01 +0000505
Jingwen Chendf27b7a2021-10-18 06:33:16 +0000506 // b/203369847: multiple genrules in the same package creating the same file
507 // //development/sdk/...
508 "platform_tools_properties",
509 "build_tools_source_properties",
510
Rupert Shuttleworth6e4950a2021-07-27 01:34:59 -0400511 // APEX support
Liz Kammer5c313582021-12-03 15:23:26 -0500512 "com.android.runtime", // depends on unconverted modules: bionic-linker-config, linkerconfig
Chris Parsonsa37e1952021-09-28 16:47:36 -0400513
Chris Parsonsc39f6332021-10-01 18:00:31 -0400514 "libgtest_ndk_c++", // b/201816222: Requires sdk_version support.
515 "libgtest_main_ndk_c++", // b/201816222: Requires sdk_version support.
Liz Kammer2b8004b2021-10-04 13:55:44 -0400516
Liz Kammer1263d9b2021-12-10 14:28:20 -0500517 "abb", // depends on unconverted modules: libcmd, libbinder
518 "adb", // depends on unconverted modules: AdbWinApi, libadb_host, libandroidfw, libapp_processes_protos_full, libfastdeploy_host, libopenscreen-discovery, libopenscreen-platform-impl, libusb, bin2c_fastdeployagent, AdbWinUsbApi
Liz Kammer3d3b35c2022-01-11 16:02:50 +0000519 "libadb_host", // depends on unconverted modules: libopenscreen-discovery, libopenscreen-platform-impl, libusb, AdbWinApi
520 "libfastdeploy_host", // depends on unconverted modules: libandroidfw, libusb, AdbWinApi
Chris Parsons8a498162021-11-18 17:19:12 -0500521 "linker", // depends on unconverted modules: libdebuggerd_handler_fallback
Liz Kammer2b8004b2021-10-04 13:55:44 -0400522 "linker_reloc_bench_main", // depends on unconverted modules: liblinker_reloc_bench_*
Chris Parsons8a498162021-11-18 17:19:12 -0500523 "versioner", // depends on unconverted modules: libclang_cxx_host, libLLVM_host, of unsupported type llvm_host_prebuilt_library_shared
Liz Kammer2b8004b2021-10-04 13:55:44 -0400524
525 "linkerconfig", // http://b/202876379 has arch-variant static_executable
526 "mdnsd", // http://b/202876379 has arch-variant static_executable
527
Chris Parsons58852a02021-12-09 18:10:18 -0500528 "CarHTMLViewer", // depends on unconverted modules android.car-stubs, car-ui-lib
Liz Kammerbe46fcc2021-11-01 15:32:43 -0400529
530 "libdexfile", // depends on unconverted modules: dexfile_operator_srcs, libartbase, libartpalette,
531 "libdexfiled", // depends on unconverted modules: dexfile_operator_srcs, libartbased, libartpalette
Liz Kammerdaa09ef2021-12-15 15:35:38 -0500532
533 // go deps:
Liz Kammer35ca77e2021-12-22 15:31:40 -0500534 "apex-protos", // depends on soong_zip, a go binary
535 "generated_android_icu4j_src_files", "generated_android_icu4j_test_files", "icu4c_test_data", // depends on unconverted modules: soong_zip
Liz Kammer878a7f12022-03-01 08:35:51 -0500536 "host_bionic_linker_asm", // depends on extract_linker, a go binary.
537 "host_bionic_linker_script", // depends on extract_linker, a go binary.
538 "robolectric-sqlite4java-native", // depends on soong_zip, a go binary
539 "robolectric_tzdata", // depends on soong_zip, a go binary
540 "libc_musl_sysroot_libc++_headers", "libc_musl_sysroot_libc++abi_headers", // depends on soong_zip, zip2zip
Liz Kammer35ca77e2021-12-22 15:31:40 -0500541
542 "android_icu4j_srcgen_binary", // Bazel build error: deps not allowed without srcs; move to runtime_deps
543 "core-icu4j-for-host", // Bazel build error: deps not allowed without srcs; move to runtime_deps
Sam Delmericocd1b80f2022-01-11 21:55:46 +0000544
545 // java deps
Liz Kammer35ca77e2021-12-22 15:31:40 -0500546 "android_icu4j_srcgen", // depends on unconverted modules: currysrc
Liz Kammera20b7a72022-02-04 12:59:36 -0500547 "bin2c_fastdeployagent", // depends on deployagent, a java binary
Liz Kammer35ca77e2021-12-22 15:31:40 -0500548 "currysrc", // depends on unconverted modules: currysrc_org.eclipse, guavalib, jopt-simple-4.9
Liz Kammer35ca77e2021-12-22 15:31:40 -0500549 "robolectric-sqlite4java-0.282", // depends on unconverted modules: robolectric-sqlite4java-import, robolectric-sqlite4java-native
Liz Kammera20b7a72022-02-04 12:59:36 -0500550 "timezone-host", // depends on unconverted modules: art.module.api.annotations
Liz Kammer35ca77e2021-12-22 15:31:40 -0500551 "truth-host-prebuilt", // depends on unconverted modules: truth-prebuilt
Liz Kammera20b7a72022-02-04 12:59:36 -0500552 "truth-prebuilt", // depends on unconverted modules: asm-7.0, guava
Liz Kammer35ca77e2021-12-22 15:31:40 -0500553
554 "generated_android_icu4j_resources", // depends on unconverted modules: android_icu4j_srcgen_binary, soong_zip
555 "generated_android_icu4j_test_resources", // depends on unconverted modules: android_icu4j_srcgen_binary, soong_zip
Liz Kammera20b7a72022-02-04 12:59:36 -0500556
557 "art-script", // depends on unconverted modules: dalvikvm, dex2oat
558 "dex2oat-script", // depends on unconverted modules: dex2oat
Sam Delmericoa9b047a2022-02-22 19:21:28 +0000559
560 // TODO(b/221082840) convert java_imports in //packages/apps/Car/libs/car-ui-lib/...
561 "prebuilt_car-ui-androidx-annotation",
562 "prebuilt_car-ui-androidx-annotation-nodeps",
563 "prebuilt_car-ui-androidx-collection",
564 "prebuilt_car-ui-androidx-collection-nodeps",
565 "prebuilt_car-ui-androidx-core-common",
566 "prebuilt_car-ui-androidx-core-common-nodeps",
567 "prebuilt_car-ui-androidx-lifecycle-common",
568 "prebuilt_car-ui-androidx-lifecycle-common-nodeps",
569 "prebuilt_car-ui-androidx-constraintlayout-solver",
570 "prebuilt_car-ui-androidx-constraintlayout-solver-nodeps",
571
572 "prebuilt_art-module-host-exports_okhttp-norepackage@current", // aosp/1999250, needs Jars (arch variant)
573 "prebuilt_conscrypt-unbundled", // aosp/1999250, needs Jars (arch variant)
574 "prebuilt_conscrypt-module-host-exports_conscrypt-unbundled@current", // aosp/1999250, needs Jars (arch variant)
575 "prebuilt_platform-robolectric-4.4-prebuilt", // aosp/1999250, needs .aar support in Jars
576 "prebuilt_platform-robolectric-4.5.1-prebuilt", // aosp/1999250, needs .aar support in Jars
Chris Parsonsbab4d7e2021-04-15 17:27:08 -0400577 }
Rupert Shuttleworthc143cc52021-04-13 13:08:04 -0400578
Jingwen Chen179856a2021-05-03 09:15:48 +0000579 // Per-module denylist of cc_library modules to only generate the static
580 // variant if their shared variant isn't ready or buildable by Bazel.
Chris Parsons58852a02021-12-09 18:10:18 -0500581 bp2buildCcLibraryStaticOnlyList = []string{}
Jingwen Chen179856a2021-05-03 09:15:48 +0000582
Chris Parsonsbab4d7e2021-04-15 17:27:08 -0400583 // Per-module denylist to opt modules out of mixed builds. Such modules will
584 // still be generated via bp2build.
Chris Parsons2c788392021-08-10 11:58:07 -0400585 mixedBuildsDisabledList = []string{
Liz Kammer5c313582021-12-03 15:23:26 -0500586 "art_libdexfile_dex_instruction_list_header", // breaks libart_mterp.armng, header not found
587
Wei Li455ba832021-11-04 22:58:12 +0000588 "libbrotli", // http://b/198585397, ld.lld: error: bionic/libc/arch-arm64/generic/bionic/memmove.S:95:(.text+0x10): relocation R_AARCH64_CONDBR19 out of range: -1404176 is not in [-1048576, 1048575]; references __memcpy
589 "minijail_constants_json", // http://b/200899432, bazel-built cc_genrule does not work in mixed build when it is a dependency of another soong module.
Liz Kammerc3192992021-11-16 17:01:11 -0500590
Jingwen Chend4808592021-11-26 05:39:07 +0000591 "cap_names.h", // TODO(b/204913827) runfiles need to be handled in mixed builds
592 "libcap", // TODO(b/204913827) runfiles need to be handled in mixed builds
593 "libprotobuf-cpp-full", "libprotobuf-cpp-lite", // Unsupported product&vendor suffix. b/204811222 and b/204810610.
Liz Kammer12615db2021-09-28 09:19:17 -0400594
595 // Depends on libprotobuf-cpp-*
Liz Kammereb2d6d12021-12-06 14:56:25 -0500596 "libadb_pairing_connection",
Liz Kammer12615db2021-09-28 09:19:17 -0400597 "libadb_pairing_connection_static",
598 "libadb_pairing_server", "libadb_pairing_server_static",
Yu Liu7f3605f2022-02-08 14:15:12 -0800599
600 // TODO(b/204811222) support suffix in cc_binary
601 "acvp_modulewrapper",
602 "android.hardware.media.c2@1.0-service-v4l2",
603 "app_process",
604 "bar_test",
605 "bench_cxa_atexit",
606 "bench_noop",
607 "bench_noop_nostl",
608 "bench_noop_static",
609 "boringssl_self_test",
610 "boringssl_self_test_vendor",
611 "bssl",
612 "cavp",
613 "crash_dump",
614 "crasher",
615 "libcxx_test_template",
616 "linker",
617 "memory_replay",
618 "native_bridge_guest_linker",
619 "native_bridge_stub_library_defaults",
620 "noop",
621 "simpleperf_ndk",
622 "toybox-static",
623 "zlib_bench",
Chris Parsons2c788392021-08-10 11:58:07 -0400624 }
Rupert Shuttleworth4f43fe92021-03-30 14:13:16 +0000625
626 // Used for quicker lookups
Sam Delmerico85d831a2022-03-07 19:12:42 +0000627 bp2buildModuleDoNotConvert = map[string]bool{}
628 bp2buildModuleAlwaysConvert = map[string]bool{}
629 bp2buildModuleTypeAlwaysConvert = map[string]bool{}
630 bp2buildCcLibraryStaticOnly = map[string]bool{}
631 mixedBuildsDisabled = map[string]bool{}
Jingwen Chen12b4c272021-03-10 02:05:59 -0500632)
633
Rupert Shuttleworth4f43fe92021-03-30 14:13:16 +0000634func init() {
Sam Delmericofa1831c2022-02-22 18:07:55 +0000635 for _, moduleName := range bp2buildModuleAlwaysConvertList {
636 bp2buildModuleAlwaysConvert[moduleName] = true
637 }
638
Sam Delmerico85d831a2022-03-07 19:12:42 +0000639 for _, moduleType := range bp2buildModuleTypeAlwaysConvertList {
640 bp2buildModuleTypeAlwaysConvert[moduleType] = true
641 }
642
Rupert Shuttleworth4f43fe92021-03-30 14:13:16 +0000643 for _, moduleName := range bp2buildModuleDoNotConvertList {
644 bp2buildModuleDoNotConvert[moduleName] = true
645 }
Chris Parsonsbab4d7e2021-04-15 17:27:08 -0400646
Jingwen Chen179856a2021-05-03 09:15:48 +0000647 for _, moduleName := range bp2buildCcLibraryStaticOnlyList {
648 bp2buildCcLibraryStaticOnly[moduleName] = true
649 }
650
Chris Parsonsbab4d7e2021-04-15 17:27:08 -0400651 for _, moduleName := range mixedBuildsDisabledList {
652 mixedBuildsDisabled[moduleName] = true
653 }
654}
655
Chris Parsons953b3562021-09-20 15:14:39 -0400656func GenerateCcLibraryStaticOnly(moduleName string) bool {
657 return bp2buildCcLibraryStaticOnly[moduleName]
Jingwen Chen179856a2021-05-03 09:15:48 +0000658}
659
Rupert Shuttleworth00960792021-05-12 21:20:13 -0400660func ShouldKeepExistingBuildFileForDir(dir string) bool {
661 if _, ok := bp2buildKeepExistingBuildFile[dir]; ok {
662 // Exact dir match
Rupert Shuttleworth2a4fc3e2021-04-21 07:10:09 -0400663 return true
664 }
Rupert Shuttleworth00960792021-05-12 21:20:13 -0400665 // Check if subtree match
666 for prefix, recursive := range bp2buildKeepExistingBuildFile {
667 if recursive {
668 if strings.HasPrefix(dir, prefix+"/") {
669 return true
670 }
671 }
672 }
673 // Default
674 return false
Rupert Shuttleworth2a4fc3e2021-04-21 07:10:09 -0400675}
676
Chris Parsonsbab4d7e2021-04-15 17:27:08 -0400677// MixedBuildsEnabled checks that a module is ready to be replaced by a
678// converted or handcrafted Bazel target.
Chris Parsons494eef32021-11-09 10:29:52 -0500679func (b *BazelModuleBase) MixedBuildsEnabled(ctx ModuleContext) bool {
680 if ctx.Os() == Windows {
681 // Windows toolchains are not currently supported.
682 return false
683 }
Chris Parsons58852a02021-12-09 18:10:18 -0500684 if !ctx.Module().Enabled() {
685 return false
686 }
Chris Parsonsbab4d7e2021-04-15 17:27:08 -0400687 if !ctx.Config().BazelContext.BazelEnabled() {
688 return false
689 }
Liz Kammer6eff3232021-08-26 08:37:59 -0400690 if !convertedToBazel(ctx, ctx.Module()) {
Chris Parsonsbab4d7e2021-04-15 17:27:08 -0400691 return false
692 }
Liz Kammer6eff3232021-08-26 08:37:59 -0400693
Chris Parsons953b3562021-09-20 15:14:39 -0400694 if GenerateCcLibraryStaticOnly(ctx.Module().Name()) {
Jingwen Chen179856a2021-05-03 09:15:48 +0000695 // Don't use partially-converted cc_library targets in mixed builds,
696 // since mixed builds would generally rely on both static and shared
697 // variants of a cc_library.
698 return false
699 }
Chris Parsonsbab4d7e2021-04-15 17:27:08 -0400700 return !mixedBuildsDisabled[ctx.Module().Name()]
Rupert Shuttleworth4f43fe92021-03-30 14:13:16 +0000701}
702
Liz Kammer6eff3232021-08-26 08:37:59 -0400703// ConvertedToBazel returns whether this module has been converted (with bp2build or manually) to Bazel.
Jingwen Chen55bc8202021-11-02 06:40:51 +0000704func convertedToBazel(ctx BazelConversionContext, module blueprint.Module) bool {
Liz Kammer6eff3232021-08-26 08:37:59 -0400705 b, ok := module.(Bazelable)
706 if !ok {
707 return false
708 }
Liz Kammerbe46fcc2021-11-01 15:32:43 -0400709 return b.shouldConvertWithBp2build(ctx, module) || b.HasHandcraftedLabel()
Liz Kammer6eff3232021-08-26 08:37:59 -0400710}
711
Liz Kammerbe46fcc2021-11-01 15:32:43 -0400712// ShouldConvertWithBp2build returns whether the given BazelModuleBase should be converted with bp2build.
713func (b *BazelModuleBase) ShouldConvertWithBp2build(ctx BazelConversionContext) bool {
714 return b.shouldConvertWithBp2build(ctx, ctx.Module())
Liz Kammer6eff3232021-08-26 08:37:59 -0400715}
716
Liz Kammerbe46fcc2021-11-01 15:32:43 -0400717func (b *BazelModuleBase) shouldConvertWithBp2build(ctx BazelConversionContext, module blueprint.Module) bool {
Sam Delmerico85d831a2022-03-07 19:12:42 +0000718 moduleName := module.Name()
719 moduleNameAllowed := bp2buildModuleAlwaysConvert[moduleName]
720 moduleTypeAllowed := bp2buildModuleTypeAlwaysConvert[ctx.OtherModuleType(module)]
721 allowlistConvert := moduleNameAllowed || moduleTypeAllowed
722 if moduleNameAllowed && moduleTypeAllowed {
723 ctx.(BaseModuleContext).ModuleErrorf("A module cannot be in bp2buildModuleAlwaysConvert and also be" +
724 " in bp2buildModuleTypeAlwaysConvert")
725 }
Sam Delmericofa1831c2022-02-22 18:07:55 +0000726
Sam Delmerico85d831a2022-03-07 19:12:42 +0000727 if bp2buildModuleDoNotConvert[moduleName] {
728 if moduleNameAllowed {
Sam Delmericofa1831c2022-02-22 18:07:55 +0000729 ctx.(BaseModuleContext).ModuleErrorf("a module cannot be in bp2buildModuleDoNotConvert" +
730 " and also be in bp2buildModuleAlwaysConvert")
731 }
Jingwen Chen5d72cba2021-03-25 09:28:38 +0000732 return false
733 }
734
Liz Kammerbe46fcc2021-11-01 15:32:43 -0400735 if !b.bazelProps().Bazel_module.CanConvertToBazel {
736 return false
Jingwen Chen12b4c272021-03-10 02:05:59 -0500737 }
738
Sam Delmerico85d831a2022-03-07 19:12:42 +0000739 propValue := b.bazelProperties.Bazel_module.Bp2build_available
Liz Kammer6eff3232021-08-26 08:37:59 -0400740 packagePath := ctx.OtherModuleDir(module)
Sam Delmerico85d831a2022-03-07 19:12:42 +0000741 // Modules in unit tests which are enabled in the allowlist by type or name
742 // trigger this conditional because unit tests run under the "." package path
743 isTestModule := packagePath == "." && proptools.BoolDefault(propValue, false)
744 if allowlistConvert && !isTestModule && ShouldKeepExistingBuildFileForDir(packagePath) {
745 if moduleNameAllowed {
746 ctx.(BaseModuleContext).ModuleErrorf("A module cannot be in a directory listed in bp2buildKeepExistingBuildFile"+
747 " and also be in bp2buildModuleAlwaysConvert. Directory: '%s'", packagePath)
748 }
Sam Delmerico94d26c22022-02-25 21:34:51 +0000749 return false
750 }
751
752 config := ctx.Config().bp2buildPackageConfig
Jingwen Chen12b4c272021-03-10 02:05:59 -0500753 // This is a tristate value: true, false, or unset.
Jingwen Chen12b4c272021-03-10 02:05:59 -0500754 if bp2buildDefaultTrueRecursively(packagePath, config) {
Sam Delmerico85d831a2022-03-07 19:12:42 +0000755 if moduleNameAllowed {
Sam Delmerico94d26c22022-02-25 21:34:51 +0000756 ctx.(BaseModuleContext).ModuleErrorf("A module cannot be in a directory marked Bp2BuildDefaultTrue"+
757 " or Bp2BuildDefaultTrueRecursively and also be in bp2buildModuleAlwaysConvert. Directory: '%s'",
758 packagePath)
Sam Delmericofa1831c2022-02-22 18:07:55 +0000759 }
760
Jingwen Chen12b4c272021-03-10 02:05:59 -0500761 // Allow modules to explicitly opt-out.
762 return proptools.BoolDefault(propValue, true)
763 }
764
765 // Allow modules to explicitly opt-in.
Sam Delmerico85d831a2022-03-07 19:12:42 +0000766 return proptools.BoolDefault(propValue, allowlistConvert)
Jingwen Chen12b4c272021-03-10 02:05:59 -0500767}
768
769// bp2buildDefaultTrueRecursively checks that the package contains a prefix from the
770// set of package prefixes where all modules must be converted. That is, if the
771// package is x/y/z, and the list contains either x, x/y, or x/y/z, this function will
772// return true.
773//
774// However, if the package is x/y, and it matches a Bp2BuildDefaultFalse "x/y" entry
775// exactly, this module will return false early.
776//
777// This function will also return false if the package doesn't match anything in
778// the config.
779func bp2buildDefaultTrueRecursively(packagePath string, config Bp2BuildConfig) bool {
780 ret := false
781
Jingwen Chen294e7742021-08-31 05:58:01 +0000782 // Check if the package path has an exact match in the config.
783 if config[packagePath] == Bp2BuildDefaultTrue || config[packagePath] == Bp2BuildDefaultTrueRecursively {
Jingwen Chen91220d72021-03-24 02:18:33 -0400784 return true
Jingwen Chen294e7742021-08-31 05:58:01 +0000785 } else if config[packagePath] == Bp2BuildDefaultFalse {
Jingwen Chen12b4c272021-03-10 02:05:59 -0500786 return false
787 }
788
Jingwen Chen91220d72021-03-24 02:18:33 -0400789 // If not, check for the config recursively.
Jingwen Chen12b4c272021-03-10 02:05:59 -0500790 packagePrefix := ""
791 // e.g. for x/y/z, iterate over x, x/y, then x/y/z, taking the final value from the allowlist.
792 for _, part := range strings.Split(packagePath, "/") {
793 packagePrefix += part
794 if config[packagePrefix] == Bp2BuildDefaultTrueRecursively {
795 // package contains this prefix and this prefix should convert all modules
796 return true
797 }
798 // Continue to the next part of the package dir.
799 packagePrefix += "/"
800 }
801
802 return ret
Liz Kammerea6666f2021-02-17 10:17:28 -0500803}
Liz Kammerba3ea162021-02-17 13:22:03 -0500804
805// GetBazelBuildFileContents returns the file contents of a hand-crafted BUILD file if available or
806// an error if there are errors reading the file.
807// TODO(b/181575318): currently we append the whole BUILD file, let's change that to do
808// something more targeted based on the rule type and target.
809func (b *BazelModuleBase) GetBazelBuildFileContents(c Config, path, name string) (string, error) {
Liz Kammerbdc60992021-02-24 16:55:11 -0500810 if !strings.Contains(b.HandcraftedLabel(), path) {
811 return "", fmt.Errorf("%q not found in bazel_module.label %q", path, b.HandcraftedLabel())
Liz Kammerba3ea162021-02-17 13:22:03 -0500812 }
813 name = filepath.Join(path, name)
814 f, err := c.fs.Open(name)
815 if err != nil {
816 return "", err
817 }
818 defer f.Close()
819
820 data, err := ioutil.ReadAll(f)
821 if err != nil {
822 return "", err
823 }
824 return string(data[:]), nil
825}
Liz Kammerbe46fcc2021-11-01 15:32:43 -0400826
827func registerBp2buildConversionMutator(ctx RegisterMutatorsContext) {
828 ctx.TopDown("bp2build_conversion", convertWithBp2build).Parallel()
829}
830
831func convertWithBp2build(ctx TopDownMutatorContext) {
832 bModule, ok := ctx.Module().(Bazelable)
833 if !ok || !bModule.shouldConvertWithBp2build(ctx, ctx.Module()) {
834 return
835 }
836
837 bModule.ConvertWithBp2build(ctx)
838}
Wei Libafb6d62021-12-10 03:14:59 -0800839
840// GetMainClassInManifest scans the manifest file specified in filepath and returns
841// the value of attribute Main-Class in the manifest file if it exists, or returns error.
842// WARNING: this is for bp2build converters of java_* modules only.
843func GetMainClassInManifest(c Config, filepath string) (string, error) {
844 file, err := c.fs.Open(filepath)
845 if err != nil {
846 return "", err
847 }
Liz Kammer0fe123d2022-02-07 10:17:35 -0500848 defer file.Close()
Wei Libafb6d62021-12-10 03:14:59 -0800849 scanner := bufio.NewScanner(file)
850 for scanner.Scan() {
851 line := scanner.Text()
852 if strings.HasPrefix(line, "Main-Class:") {
853 return strings.TrimSpace(line[len("Main-Class:"):]), nil
854 }
855 }
856
857 return "", errors.New("Main-Class is not found.")
858}