Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 0d6bb348 authored by Cole Faust's avatar Cole Faust Committed by Gerrit Code Review
Browse files

Merge "Add sdk_genrule" into main

parents c0110423 8fc38f37
Loading
Loading
Loading
Loading
+3 −2
Original line number Diff line number Diff line
@@ -446,8 +446,10 @@ func osMutator(bpctx blueprint.BottomUpMutatorContext) {
		}
	}

	createCommonOSVariant := base.commonProperties.CreateCommonOSVariant

	// If there are no supported OSes then disable the module.
	if len(moduleOSList) == 0 {
	if len(moduleOSList) == 0 && !createCommonOSVariant {
		base.Disable()
		return
	}
@@ -458,7 +460,6 @@ func osMutator(bpctx blueprint.BottomUpMutatorContext) {
		osNames[i] = os.String()
	}

	createCommonOSVariant := base.commonProperties.CreateCommonOSVariant
	if createCommonOSVariant {
		// 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
+2 −0
Original line number Diff line number Diff line
@@ -18,6 +18,7 @@ bootstrap_go_package {
        "bp.go",
        "build_release.go",
        "exports.go",
        "genrule.go",
        "member_trait.go",
        "member_type.go",
        "sdk.go",
@@ -30,6 +31,7 @@ bootstrap_go_package {
        "cc_sdk_test.go",
        "compat_config_sdk_test.go",
        "exports_test.go",
        "genrule_test.go",
        "java_sdk_test.go",
        "license_sdk_test.go",
        "member_trait_test.go",

sdk/genrule.go

0 → 100644
+44 −0
Original line number Diff line number Diff line
// 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
}

sdk/genrule_test.go

0 → 100644
+52 −0
Original line number Diff line number Diff line
// 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 −0
Original line number Diff line number Diff line
@@ -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.
//
// Returns a map from member name to the set of required traits.