Add support for writing all Soong config variables into @soong_injection.

Also remove the need to use bp2build_available on
soong_config_module_types as we want to convert every single of them
into the tree for a complete soong_injection soong_config_variables.bzl
file.

The variables are split into their bool, value and string types
respectively, as they all need to be handled differently on the Bazel
product_platform side, as well as for generating constraint values and
settings. For example, value variables need to integrate with
TemplateVariableInfo, and string variables need to include the string
value itself into the select key/constraint value.

Sample soong_config_variables.bzl file: https://gist.github.com/jin/cef700bfb20c8656a931306dd71d47e1

Test: CI
Bug: 198556411
Change-Id: I8665dd1269a507edb37de62407ed3641564bea5c
This commit is contained in:
Jingwen Chen
2021-11-19 14:29:43 +00:00
parent 58ff6801f4
commit 01812020c1
10 changed files with 239 additions and 44 deletions

View File

@@ -18,6 +18,7 @@ bootstrap_go_package {
],
deps: [
"soong-android",
"soong-android-soongconfig",
"soong-apex",
"soong-bazel",
"soong-cc",

View File

@@ -25,6 +25,8 @@ func CreateSoongInjectionFiles(cfg android.Config, metrics CodegenMetrics) []Baz
files = append(files, newFile("metrics", "converted_modules.txt", strings.Join(metrics.convertedModules, "\n")))
files = append(files, newFile("product_config", "soong_config_variables.bzl", cfg.Bp2buildSoongConfigDefinitions.String()))
return files
}

View File

@@ -82,7 +82,8 @@ func TestCreateBazelFiles_QueryView_AddsTopLevelFiles(t *testing.T) {
}
func TestCreateBazelFiles_Bp2Build_CreatesDefaultFiles(t *testing.T) {
files := CreateSoongInjectionFiles(android.Config{}, CodegenMetrics{})
testConfig := android.TestConfig("", make(map[string]string), "", make(map[string][]byte))
files := CreateSoongInjectionFiles(testConfig, CodegenMetrics{})
expectedFilePaths := []bazelFilepath{
{
@@ -97,6 +98,10 @@ func TestCreateBazelFiles_Bp2Build_CreatesDefaultFiles(t *testing.T) {
dir: "metrics",
basename: "converted_modules.txt",
},
{
dir: "product_config",
basename: "soong_config_variables.bzl",
},
}
if len(files) != len(expectedFilePaths) {

View File

@@ -44,7 +44,6 @@ soong_config_module_type {
config_namespace: "acme",
bool_variables: ["feature1"],
properties: ["cflags"],
bazel_module: { bp2build_available: true },
}
custom_cc_library_static {
@@ -85,7 +84,6 @@ soong_config_module_type {
config_namespace: "acme",
bool_variables: ["feature1"],
properties: ["cflags"],
bazel_module: { bp2build_available: true },
}
`
bp := `
@@ -140,7 +138,6 @@ soong_config_module_type {
config_namespace: "acme",
variables: ["board"],
properties: ["cflags"],
bazel_module: { bp2build_available: true },
}
custom_cc_library_static {
@@ -201,7 +198,6 @@ soong_config_module_type {
config_namespace: "acme",
variables: ["feature1", "feature2", "board"],
properties: ["cflags"],
bazel_module: { bp2build_available: true },
}
custom_cc_library_static {
@@ -271,7 +267,6 @@ soong_config_module_type {
config_namespace: "acme",
variables: ["board"],
properties: ["cflags", "static_libs"],
bazel_module: { bp2build_available: true },
}
custom_cc_library_static {
@@ -335,7 +330,6 @@ soong_config_module_type {
config_namespace: "vendor_foo",
bool_variables: ["feature"],
properties: ["cflags", "cppflags"],
bazel_module: { bp2build_available: true },
}
vendor_foo_cc_defaults {
@@ -400,7 +394,6 @@ soong_config_module_type {
config_namespace: "acme",
bool_variables: ["feature"],
properties: ["cflags"],
bazel_module: { bp2build_available: true },
}
soong_config_module_type {
@@ -409,7 +402,6 @@ soong_config_module_type {
config_namespace: "acme",
bool_variables: ["feature"],
properties: ["cflags", "asflags"],
bazel_module: { bp2build_available: true },
}
foo_cc_defaults {
@@ -506,7 +498,6 @@ soong_config_module_type {
config_namespace: "vendor_foo",
bool_variables: ["feature"],
properties: ["cflags"],
bazel_module: { bp2build_available: true },
}
soong_config_module_type {
@@ -515,7 +506,6 @@ soong_config_module_type {
config_namespace: "vendor_bar",
bool_variables: ["feature"],
properties: ["cflags"],
bazel_module: { bp2build_available: true },
}
soong_config_module_type {
@@ -524,7 +514,6 @@ soong_config_module_type {
config_namespace: "vendor_qux",
bool_variables: ["feature"],
properties: ["cflags"],
bazel_module: { bp2build_available: true },
}
vendor_foo_cc_defaults {
@@ -611,7 +600,6 @@ soong_config_module_type {
"shared_libs",
"static_libs",
],
bazel_module: { bp2build_available: true },
}
library_linking_strategy_cc_defaults {
@@ -711,7 +699,6 @@ soong_config_module_type {
"shared_libs",
"static_libs",
],
bazel_module: { bp2build_available: true },
}
library_linking_strategy_cc_defaults {
@@ -796,7 +783,6 @@ soong_config_module_type {
"shared_libs",
"static_libs",
],
bazel_module: { bp2build_available: true },
}
alphabet_cc_defaults {