Merge "Add sdk_genrule" into main
This commit is contained in:
@@ -446,8 +446,10 @@ func osMutator(bpctx blueprint.BottomUpMutatorContext) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
createCommonOSVariant := base.commonProperties.CreateCommonOSVariant
|
||||||
|
|
||||||
// If there are no supported OSes then disable the module.
|
// If there are no supported OSes then disable the module.
|
||||||
if len(moduleOSList) == 0 {
|
if len(moduleOSList) == 0 && !createCommonOSVariant {
|
||||||
base.Disable()
|
base.Disable()
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
@@ -458,7 +460,6 @@ func osMutator(bpctx blueprint.BottomUpMutatorContext) {
|
|||||||
osNames[i] = os.String()
|
osNames[i] = os.String()
|
||||||
}
|
}
|
||||||
|
|
||||||
createCommonOSVariant := base.commonProperties.CreateCommonOSVariant
|
|
||||||
if createCommonOSVariant {
|
if createCommonOSVariant {
|
||||||
// A CommonOS variant was requested so add it to the list of OS variants to
|
// A CommonOS variant was requested so add it to the list of OS variants to
|
||||||
// create. It needs to be added to the end because it needs to depend on the
|
// create. It needs to be added to the end because it needs to depend on the
|
||||||
|
@@ -18,6 +18,7 @@ bootstrap_go_package {
|
|||||||
"bp.go",
|
"bp.go",
|
||||||
"build_release.go",
|
"build_release.go",
|
||||||
"exports.go",
|
"exports.go",
|
||||||
|
"genrule.go",
|
||||||
"member_trait.go",
|
"member_trait.go",
|
||||||
"member_type.go",
|
"member_type.go",
|
||||||
"sdk.go",
|
"sdk.go",
|
||||||
@@ -30,6 +31,7 @@ bootstrap_go_package {
|
|||||||
"cc_sdk_test.go",
|
"cc_sdk_test.go",
|
||||||
"compat_config_sdk_test.go",
|
"compat_config_sdk_test.go",
|
||||||
"exports_test.go",
|
"exports_test.go",
|
||||||
|
"genrule_test.go",
|
||||||
"java_sdk_test.go",
|
"java_sdk_test.go",
|
||||||
"license_sdk_test.go",
|
"license_sdk_test.go",
|
||||||
"member_trait_test.go",
|
"member_trait_test.go",
|
||||||
|
44
sdk/genrule.go
Normal file
44
sdk/genrule.go
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
// Copyright 2023 Google Inc. All rights reserved.
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
package sdk
|
||||||
|
|
||||||
|
import (
|
||||||
|
"android/soong/android"
|
||||||
|
"android/soong/genrule"
|
||||||
|
)
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
registerGenRuleBuildComponents(android.InitRegistrationContext)
|
||||||
|
}
|
||||||
|
|
||||||
|
func registerGenRuleBuildComponents(ctx android.RegistrationContext) {
|
||||||
|
ctx.RegisterModuleType("sdk_genrule", SdkGenruleFactory)
|
||||||
|
}
|
||||||
|
|
||||||
|
// sdk_genrule_host is a genrule that can depend on sdk and sdk_snapshot module types
|
||||||
|
//
|
||||||
|
// What this means is that it's a genrule with only the "common_os" variant.
|
||||||
|
// sdk modules have 3 variants: host, android, and common_os. The common_os one depends
|
||||||
|
// on the host/device ones and packages their result into a final snapshot zip.
|
||||||
|
// Genrules probably want access to this snapshot zip when they depend on an sdk module,
|
||||||
|
// which means they want to depend on the common_os variant and not the host/android
|
||||||
|
// variants.
|
||||||
|
func SdkGenruleFactory() android.Module {
|
||||||
|
module := genrule.NewGenRule()
|
||||||
|
|
||||||
|
android.InitCommonOSAndroidMultiTargetsArchModule(module, android.NeitherHostNorDeviceSupported, android.MultilibCommon)
|
||||||
|
android.InitDefaultableModule(module)
|
||||||
|
|
||||||
|
return module
|
||||||
|
}
|
52
sdk/genrule_test.go
Normal file
52
sdk/genrule_test.go
Normal file
@@ -0,0 +1,52 @@
|
|||||||
|
// Copyright 2018 Google Inc. All rights reserved.
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
|
||||||
|
package sdk
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"android/soong/android"
|
||||||
|
"android/soong/genrule"
|
||||||
|
"android/soong/java"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestSdkGenrule(t *testing.T) {
|
||||||
|
// Test that an sdk_genrule can depend on an sdk, and that a genrule can depend on an sdk_genrule
|
||||||
|
bp := `
|
||||||
|
sdk {
|
||||||
|
name: "my_sdk",
|
||||||
|
}
|
||||||
|
sdk_genrule {
|
||||||
|
name: "my_sdk_genrule",
|
||||||
|
tool_files: ["tool"],
|
||||||
|
cmd: "$(location tool) $(in) $(out)",
|
||||||
|
srcs: [":my_sdk"],
|
||||||
|
out: ["out"],
|
||||||
|
}
|
||||||
|
genrule {
|
||||||
|
name: "my_regular_genrule",
|
||||||
|
srcs: [":my_sdk_genrule"],
|
||||||
|
out: ["out"],
|
||||||
|
cmd: "cp $(in) $(out)",
|
||||||
|
}
|
||||||
|
`
|
||||||
|
android.GroupFixturePreparers(
|
||||||
|
// if java components aren't registered, the sdk module doesn't create a snapshot for some reason.
|
||||||
|
java.PrepareForTestWithJavaBuildComponents,
|
||||||
|
genrule.PrepareForTestWithGenRuleBuildComponents,
|
||||||
|
PrepareForTestWithSdkBuildComponents,
|
||||||
|
android.FixtureRegisterWithContext(registerGenRuleBuildComponents),
|
||||||
|
).RunTestWithBp(t, bp)
|
||||||
|
}
|
12
sdk/sdk.go
12
sdk/sdk.go
@@ -222,6 +222,18 @@ func (s *sdk) AndroidMkEntries() []android.AndroidMkEntries {
|
|||||||
}}
|
}}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (s *sdk) OutputFiles(tag string) (android.Paths, error) {
|
||||||
|
switch tag {
|
||||||
|
case "":
|
||||||
|
if s.snapshotFile.Valid() {
|
||||||
|
return []android.Path{s.snapshotFile.Path()}, nil
|
||||||
|
}
|
||||||
|
return nil, fmt.Errorf("snapshot file not defined. This is most likely because this isn't the common_os variant of this module")
|
||||||
|
default:
|
||||||
|
return nil, fmt.Errorf("unknown tag %q", tag)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// gatherTraits gathers the traits from the dynamically generated trait specific properties.
|
// gatherTraits gathers the traits from the dynamically generated trait specific properties.
|
||||||
//
|
//
|
||||||
// Returns a map from member name to the set of required traits.
|
// Returns a map from member name to the set of required traits.
|
||||||
|
Reference in New Issue
Block a user