Replace ApiStrToNum uses with ApiLevel. am: c8060536e8 am: 6e3d089818
				
					
				
			Original change: https://android-review.googlesource.com/c/platform/build/soong/+/1371896 Change-Id: Ib7861bde161e92291228ec0405e6d0c206296944
This commit is contained in:
		| @@ -24,29 +24,36 @@ import ( | |||||||
| 	"github.com/google/blueprint" | 	"github.com/google/blueprint" | ||||||
| ) | ) | ||||||
|  |  | ||||||
| const ( | var ( | ||||||
| 	SdkVersion_Android10 = 29 | 	SdkVersion_Android10 = uncheckedFinalApiLevel(29) | ||||||
| ) | ) | ||||||
|  |  | ||||||
| type ApexInfo struct { | type ApexInfo struct { | ||||||
| 	// Name of the apex variation that this module is mutated into | 	// Name of the apex variation that this module is mutated into | ||||||
| 	ApexVariationName string | 	ApexVariationName string | ||||||
|  |  | ||||||
| 	MinSdkVersion int | 	// Serialized ApiLevel. Use via MinSdkVersion() method. Cannot be stored in | ||||||
| 	Updatable     bool | 	// its struct form because this is cloned into properties structs, and | ||||||
| 	RequiredSdks  SdkRefs | 	// ApiLevel has private members. | ||||||
|  | 	MinSdkVersionStr string | ||||||
|  | 	Updatable        bool | ||||||
|  | 	RequiredSdks     SdkRefs | ||||||
|  |  | ||||||
| 	InApexes []string | 	InApexes []string | ||||||
| } | } | ||||||
|  |  | ||||||
| func (i ApexInfo) mergedName() string { | func (i ApexInfo) mergedName(ctx EarlyModuleContext) string { | ||||||
| 	name := "apex" + strconv.Itoa(i.MinSdkVersion) | 	name := "apex" + strconv.Itoa(i.MinSdkVersion(ctx).FinalOrFutureInt()) | ||||||
| 	for _, sdk := range i.RequiredSdks { | 	for _, sdk := range i.RequiredSdks { | ||||||
| 		name += "_" + sdk.Name + "_" + sdk.Version | 		name += "_" + sdk.Name + "_" + sdk.Version | ||||||
| 	} | 	} | ||||||
| 	return name | 	return name | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func (this *ApexInfo) MinSdkVersion(ctx EarlyModuleContext) ApiLevel { | ||||||
|  | 	return ApiLevelOrPanic(ctx, this.MinSdkVersionStr) | ||||||
|  | } | ||||||
|  |  | ||||||
| // Extracted from ApexModule to make it easier to define custom subsets of the | // Extracted from ApexModule to make it easier to define custom subsets of the | ||||||
| // ApexModule interface and improve code navigation within the IDE. | // ApexModule interface and improve code navigation within the IDE. | ||||||
| type DepIsInSameApex interface { | type DepIsInSameApex interface { | ||||||
| @@ -141,7 +148,7 @@ type ApexModule interface { | |||||||
|  |  | ||||||
| 	// Returns nil if this module supports sdkVersion | 	// Returns nil if this module supports sdkVersion | ||||||
| 	// Otherwise, returns error with reason | 	// Otherwise, returns error with reason | ||||||
| 	ShouldSupportSdkVersion(ctx BaseModuleContext, sdkVersion int) error | 	ShouldSupportSdkVersion(ctx BaseModuleContext, sdkVersion ApiLevel) error | ||||||
|  |  | ||||||
| 	// Returns true if this module needs a unique variation per apex, for example if | 	// Returns true if this module needs a unique variation per apex, for example if | ||||||
| 	// use_apex_name_macro is set. | 	// use_apex_name_macro is set. | ||||||
| @@ -347,18 +354,18 @@ func (a byApexName) Less(i, j int) bool { return a[i].ApexVariationName < a[j].A | |||||||
| // mergeApexVariations deduplicates APEX variations that would build identically into a common | // mergeApexVariations deduplicates APEX variations that would build identically into a common | ||||||
| // variation.  It returns the reduced list of variations and a list of aliases from the original | // variation.  It returns the reduced list of variations and a list of aliases from the original | ||||||
| // variation names to the new variation names. | // variation names to the new variation names. | ||||||
| func mergeApexVariations(apexVariations []ApexInfo) (merged []ApexInfo, aliases [][2]string) { | func mergeApexVariations(ctx EarlyModuleContext, apexVariations []ApexInfo) (merged []ApexInfo, aliases [][2]string) { | ||||||
| 	sort.Sort(byApexName(apexVariations)) | 	sort.Sort(byApexName(apexVariations)) | ||||||
| 	seen := make(map[string]int) | 	seen := make(map[string]int) | ||||||
| 	for _, apexInfo := range apexVariations { | 	for _, apexInfo := range apexVariations { | ||||||
| 		apexName := apexInfo.ApexVariationName | 		apexName := apexInfo.ApexVariationName | ||||||
| 		mergedName := apexInfo.mergedName() | 		mergedName := apexInfo.mergedName(ctx) | ||||||
| 		if index, exists := seen[mergedName]; exists { | 		if index, exists := seen[mergedName]; exists { | ||||||
| 			merged[index].InApexes = append(merged[index].InApexes, apexName) | 			merged[index].InApexes = append(merged[index].InApexes, apexName) | ||||||
| 			merged[index].Updatable = merged[index].Updatable || apexInfo.Updatable | 			merged[index].Updatable = merged[index].Updatable || apexInfo.Updatable | ||||||
| 		} else { | 		} else { | ||||||
| 			seen[mergedName] = len(merged) | 			seen[mergedName] = len(merged) | ||||||
| 			apexInfo.ApexVariationName = apexInfo.mergedName() | 			apexInfo.ApexVariationName = apexInfo.mergedName(ctx) | ||||||
| 			apexInfo.InApexes = CopyOf(apexInfo.InApexes) | 			apexInfo.InApexes = CopyOf(apexInfo.InApexes) | ||||||
| 			merged = append(merged, apexInfo) | 			merged = append(merged, apexInfo) | ||||||
| 		} | 		} | ||||||
| @@ -374,7 +381,7 @@ func (m *ApexModuleBase) CreateApexVariations(mctx BottomUpMutatorContext) []Mod | |||||||
| 		var apexVariations []ApexInfo | 		var apexVariations []ApexInfo | ||||||
| 		var aliases [][2]string | 		var aliases [][2]string | ||||||
| 		if !mctx.Module().(ApexModule).UniqueApexVariations() && !m.ApexProperties.UniqueApexVariationsForDeps { | 		if !mctx.Module().(ApexModule).UniqueApexVariations() && !m.ApexProperties.UniqueApexVariationsForDeps { | ||||||
| 			apexVariations, aliases = mergeApexVariations(m.apexVariations) | 			apexVariations, aliases = mergeApexVariations(mctx, m.apexVariations) | ||||||
| 		} else { | 		} else { | ||||||
| 			apexVariations = m.apexVariations | 			apexVariations = m.apexVariations | ||||||
| 		} | 		} | ||||||
| @@ -603,7 +610,13 @@ func (d *ApexBundleDepsInfo) BuildDepsInfoLists(ctx ModuleContext, minSdkVersion | |||||||
| } | } | ||||||
|  |  | ||||||
| // TODO(b/158059172): remove minSdkVersion allowlist | // TODO(b/158059172): remove minSdkVersion allowlist | ||||||
| var minSdkVersionAllowlist = map[string]int{ | var minSdkVersionAllowlist = func(apiMap map[string]int) map[string]ApiLevel { | ||||||
|  | 	list := make(map[string]ApiLevel, len(apiMap)) | ||||||
|  | 	for name, finalApiInt := range apiMap { | ||||||
|  | 		list[name] = uncheckedFinalApiLevel(finalApiInt) | ||||||
|  | 	} | ||||||
|  | 	return list | ||||||
|  | }(map[string]int{ | ||||||
| 	"adbd":                  30, | 	"adbd":                  30, | ||||||
| 	"android.net.ipsec.ike": 30, | 	"android.net.ipsec.ike": 30, | ||||||
| 	"androidx-constraintlayout_constraintlayout-solver": 30, | 	"androidx-constraintlayout_constraintlayout-solver": 30, | ||||||
| @@ -672,7 +685,7 @@ var minSdkVersionAllowlist = map[string]int{ | |||||||
| 	"statsd":                                            30, | 	"statsd":                                            30, | ||||||
| 	"tensorflow_headers":                                30, | 	"tensorflow_headers":                                30, | ||||||
| 	"xz-java":                                           29, | 	"xz-java":                                           29, | ||||||
| } | }) | ||||||
|  |  | ||||||
| // Function called while walking an APEX's payload dependencies. | // Function called while walking an APEX's payload dependencies. | ||||||
| // | // | ||||||
| @@ -686,7 +699,7 @@ type UpdatableModule interface { | |||||||
| } | } | ||||||
|  |  | ||||||
| // CheckMinSdkVersion checks if every dependency of an updatable module sets min_sdk_version accordingly | // CheckMinSdkVersion checks if every dependency of an updatable module sets min_sdk_version accordingly | ||||||
| func CheckMinSdkVersion(m UpdatableModule, ctx ModuleContext, minSdkVersion int) { | func CheckMinSdkVersion(m UpdatableModule, ctx ModuleContext, minSdkVersion ApiLevel) { | ||||||
| 	// do not enforce min_sdk_version for host | 	// do not enforce min_sdk_version for host | ||||||
| 	if ctx.Host() { | 	if ctx.Host() { | ||||||
| 		return | 		return | ||||||
| @@ -699,7 +712,7 @@ func CheckMinSdkVersion(m UpdatableModule, ctx ModuleContext, minSdkVersion int) | |||||||
|  |  | ||||||
| 	// do not enforce deps.min_sdk_version if APEX/APK doesn't set min_sdk_version or | 	// do not enforce deps.min_sdk_version if APEX/APK doesn't set min_sdk_version or | ||||||
| 	// min_sdk_version is not finalized (e.g. current or codenames) | 	// min_sdk_version is not finalized (e.g. current or codenames) | ||||||
| 	if minSdkVersion == FutureApiLevel { | 	if minSdkVersion.IsCurrent() { | ||||||
| 		return | 		return | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| @@ -714,7 +727,7 @@ func CheckMinSdkVersion(m UpdatableModule, ctx ModuleContext, minSdkVersion int) | |||||||
| 		} | 		} | ||||||
| 		if err := to.ShouldSupportSdkVersion(ctx, minSdkVersion); err != nil { | 		if err := to.ShouldSupportSdkVersion(ctx, minSdkVersion); err != nil { | ||||||
| 			toName := ctx.OtherModuleName(to) | 			toName := ctx.OtherModuleName(to) | ||||||
| 			if ver, ok := minSdkVersionAllowlist[toName]; !ok || ver > minSdkVersion { | 			if ver, ok := minSdkVersionAllowlist[toName]; !ok || ver.GreaterThan(minSdkVersion) { | ||||||
| 				ctx.OtherModuleErrorf(to, "should support min_sdk_version(%v) for %q: %v. Dependency path: %s", | 				ctx.OtherModuleErrorf(to, "should support min_sdk_version(%v) for %q: %v. Dependency path: %s", | ||||||
| 					minSdkVersion, ctx.ModuleName(), err.Error(), ctx.GetPathString(false)) | 					minSdkVersion, ctx.ModuleName(), err.Error(), ctx.GetPathString(false)) | ||||||
| 				return false | 				return false | ||||||
|   | |||||||
| @@ -49,6 +49,14 @@ type ApiLevel struct { | |||||||
| 	isPreview bool | 	isPreview bool | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func (this ApiLevel) FinalOrFutureInt() int { | ||||||
|  | 	if this.IsPreview() { | ||||||
|  | 		return FutureApiLevel | ||||||
|  | 	} else { | ||||||
|  | 		return this.number | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
| // Returns the canonical name for this API level. For a finalized API level | // Returns the canonical name for this API level. For a finalized API level | ||||||
| // this will be the API number as a string. For a preview API level this | // this will be the API number as a string. For a preview API level this | ||||||
| // will be the codename, or "current". | // will be the codename, or "current". | ||||||
| @@ -261,6 +269,17 @@ func getFinalCodenamesMap(config Config) map[string]int { | |||||||
| 			"R":     30, | 			"R":     30, | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|  | 		// TODO: Differentiate "current" and "future". | ||||||
|  | 		// The code base calls it FutureApiLevel, but the spelling is "current", | ||||||
|  | 		// and these are really two different things. When defining APIs it | ||||||
|  | 		// means the API has not yet been added to a specific release. When | ||||||
|  | 		// choosing an API level to build for it means that the future API level | ||||||
|  | 		// should be used, except in the case where the build is finalized in | ||||||
|  | 		// which case the platform version should be used. This is *weird*, | ||||||
|  | 		// because in the circumstance where API foo was added in R and bar was | ||||||
|  | 		// added in S, both of these are usable when building for "current" when | ||||||
|  | 		// neither R nor S are final, but the S APIs stop being available in a | ||||||
|  | 		// final R build. | ||||||
| 		if Bool(config.productVariables.Platform_sdk_final) { | 		if Bool(config.productVariables.Platform_sdk_final) { | ||||||
| 			apiLevelsMap["current"] = config.PlatformSdkVersionInt() | 			apiLevelsMap["current"] = config.PlatformSdkVersionInt() | ||||||
| 		} | 		} | ||||||
| @@ -300,24 +319,6 @@ func getApiLevelsMap(config Config) map[string]int { | |||||||
| 	}).(map[string]int) | 	}).(map[string]int) | ||||||
| } | } | ||||||
|  |  | ||||||
| // Converts an API level string into its numeric form. |  | ||||||
| // * Codenames are decoded. |  | ||||||
| // * Numeric API levels are simply converted. |  | ||||||
| // * "current" is mapped to FutureApiLevel(10000) |  | ||||||
| // * "minimum" is NDK specific and not handled with this. (refer normalizeNdkApiLevel in cc.go) |  | ||||||
| func ApiStrToNum(ctx BaseModuleContext, apiLevel string) (int, error) { |  | ||||||
| 	if apiLevel == "current" { |  | ||||||
| 		return FutureApiLevel, nil |  | ||||||
| 	} |  | ||||||
| 	if num, ok := getApiLevelsMap(ctx.Config())[apiLevel]; ok { |  | ||||||
| 		return num, nil |  | ||||||
| 	} |  | ||||||
| 	if num, err := strconv.Atoi(apiLevel); err == nil { |  | ||||||
| 		return num, nil |  | ||||||
| 	} |  | ||||||
| 	return 0, fmt.Errorf("SDK version should be one of \"current\", <number> or <codename>: %q", apiLevel) |  | ||||||
| } |  | ||||||
|  |  | ||||||
| func (a *apiLevelsSingleton) GenerateBuildActions(ctx SingletonContext) { | func (a *apiLevelsSingleton) GenerateBuildActions(ctx SingletonContext) { | ||||||
| 	apiLevelsMap := getApiLevelsMap(ctx.Config()) | 	apiLevelsMap := getApiLevelsMap(ctx.Config()) | ||||||
| 	apiLevelsJson := GetApiLevelsJson(ctx) | 	apiLevelsJson := GetApiLevelsJson(ctx) | ||||||
|   | |||||||
							
								
								
									
										30
									
								
								apex/apex.go
									
									
									
									
									
								
							
							
						
						
									
										30
									
								
								apex/apex.go
									
									
									
									
									
								
							| @@ -795,7 +795,7 @@ func apexDepsMutator(mctx android.TopDownMutatorContext) { | |||||||
| 	} | 	} | ||||||
| 	apexInfo := android.ApexInfo{ | 	apexInfo := android.ApexInfo{ | ||||||
| 		ApexVariationName: mctx.ModuleName(), | 		ApexVariationName: mctx.ModuleName(), | ||||||
| 		MinSdkVersion:     a.minSdkVersion(mctx), | 		MinSdkVersionStr:  a.minSdkVersion(mctx).String(), | ||||||
| 		RequiredSdks:      a.RequiredSdks(), | 		RequiredSdks:      a.RequiredSdks(), | ||||||
| 		Updatable:         a.Updatable(), | 		Updatable:         a.Updatable(), | ||||||
| 		InApexes:          []string{mctx.ModuleName()}, | 		InApexes:          []string{mctx.ModuleName()}, | ||||||
| @@ -1952,27 +1952,21 @@ func (a *apexBundle) WalkPayloadDeps(ctx android.ModuleContext, do android.Paylo | |||||||
| 	}) | 	}) | ||||||
| } | } | ||||||
|  |  | ||||||
| func (a *apexBundle) minSdkVersion(ctx android.BaseModuleContext) int { | func (a *apexBundle) minSdkVersion(ctx android.BaseModuleContext) android.ApiLevel { | ||||||
| 	ver := proptools.String(a.properties.Min_sdk_version) | 	ver := proptools.String(a.properties.Min_sdk_version) | ||||||
| 	if ver == "" { | 	if ver == "" { | ||||||
| 		return android.FutureApiLevel | 		return android.CurrentApiLevel | ||||||
| 	} | 	} | ||||||
| 	// Treat the current codenames as "current", which means future API version (10000) | 	apiLevel, err := android.ApiLevelFromUser(ctx, ver) | ||||||
| 	// Otherwise, ApiStrToNum converts codename(non-finalized) to a value from [9000...] |  | ||||||
| 	// and would fail to build against "current". |  | ||||||
| 	if android.InList(ver, ctx.Config().PlatformVersionActiveCodenames()) { |  | ||||||
| 		return android.FutureApiLevel |  | ||||||
| 	} |  | ||||||
| 	// In "REL" branch, "current" is mapped to finalized sdk version |  | ||||||
| 	if ctx.Config().PlatformSdkCodename() == "REL" && ver == "current" { |  | ||||||
| 		return ctx.Config().PlatformSdkVersionInt() |  | ||||||
| 	} |  | ||||||
| 	// Finalized codenames are OKAY and will be converted to int |  | ||||||
| 	intVer, err := android.ApiStrToNum(ctx, ver) |  | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		ctx.PropertyErrorf("min_sdk_version", "%s", err.Error()) | 		ctx.PropertyErrorf("min_sdk_version", "%s", err.Error()) | ||||||
|  | 		return android.NoneApiLevel | ||||||
| 	} | 	} | ||||||
| 	return intVer | 	if apiLevel.IsPreview() { | ||||||
|  | 		// All codenames should build against "current". | ||||||
|  | 		return android.CurrentApiLevel | ||||||
|  | 	} | ||||||
|  | 	return apiLevel | ||||||
| } | } | ||||||
|  |  | ||||||
| func (a *apexBundle) Updatable() bool { | func (a *apexBundle) Updatable() bool { | ||||||
| @@ -2046,7 +2040,9 @@ func (a *apexBundle) checkMinSdkVersion(ctx android.ModuleContext) { | |||||||
| 	if proptools.Bool(a.properties.Use_vendor) && ctx.DeviceConfig().VndkVersion() == "" { | 	if proptools.Bool(a.properties.Use_vendor) && ctx.DeviceConfig().VndkVersion() == "" { | ||||||
| 		return | 		return | ||||||
| 	} | 	} | ||||||
| 	android.CheckMinSdkVersion(a, ctx, a.minSdkVersion(ctx)) | 	// apexBundle::minSdkVersion reports its own errors. | ||||||
|  | 	minSdkVersion := a.minSdkVersion(ctx) | ||||||
|  | 	android.CheckMinSdkVersion(a, ctx, minSdkVersion) | ||||||
| } | } | ||||||
|  |  | ||||||
| // Ensures that a lib providing stub isn't statically linked | // Ensures that a lib providing stub isn't statically linked | ||||||
|   | |||||||
| @@ -1425,13 +1425,7 @@ func TestApexMinSdkVersion_SupportsCodeNames(t *testing.T) { | |||||||
| 		ldArgs := ctx.ModuleForTests(from, "android_arm64_armv8-a_"+from_variant).Rule("ld").Args["libFlags"] | 		ldArgs := ctx.ModuleForTests(from, "android_arm64_armv8-a_"+from_variant).Rule("ld").Args["libFlags"] | ||||||
| 		ensureNotContains(t, ldArgs, "android_arm64_armv8-a_"+to_variant+"/"+to+".so") | 		ensureNotContains(t, ldArgs, "android_arm64_armv8-a_"+to_variant+"/"+to+".so") | ||||||
| 	} | 	} | ||||||
| 	// 9000 is quite a magic number. | 	expectLink("libx", "shared_apex10000", "libz", "shared_R") | ||||||
| 	// Finalized SDK codenames are mapped as P(28), Q(29), ... |  | ||||||
| 	// And, codenames which are not finalized yet(active_codenames + future_codenames) are numbered from 9000, 9001, ... |  | ||||||
| 	// to distinguish them from finalized and future_api(10000) |  | ||||||
| 	// In this test, "R" is assumed not finalized yet( listed in Platform_version_active_codenames) and translated into 9000 |  | ||||||
| 	// (refer android/api_levels.go) |  | ||||||
| 	expectLink("libx", "shared_apex10000", "libz", "shared_9000") |  | ||||||
| 	expectNoLink("libx", "shared_apex10000", "libz", "shared_29") | 	expectNoLink("libx", "shared_apex10000", "libz", "shared_29") | ||||||
| 	expectNoLink("libx", "shared_apex10000", "libz", "shared") | 	expectNoLink("libx", "shared_apex10000", "libz", "shared") | ||||||
| } | } | ||||||
| @@ -6130,7 +6124,7 @@ func TestNonPreferredPrebuiltDependency(t *testing.T) { | |||||||
| 			name: "mylib", | 			name: "mylib", | ||||||
| 			srcs: ["mylib.cpp"], | 			srcs: ["mylib.cpp"], | ||||||
| 			stubs: { | 			stubs: { | ||||||
| 				versions: ["10000"], | 				versions: ["current"], | ||||||
| 			}, | 			}, | ||||||
| 			apex_available: ["myapex"], | 			apex_available: ["myapex"], | ||||||
| 		} | 		} | ||||||
| @@ -6140,7 +6134,7 @@ func TestNonPreferredPrebuiltDependency(t *testing.T) { | |||||||
| 			prefer: false, | 			prefer: false, | ||||||
| 			srcs: ["prebuilt.so"], | 			srcs: ["prebuilt.so"], | ||||||
| 			stubs: { | 			stubs: { | ||||||
| 				versions: ["10000"], | 				versions: ["current"], | ||||||
| 			}, | 			}, | ||||||
| 			apex_available: ["myapex"], | 			apex_available: ["myapex"], | ||||||
| 		} | 		} | ||||||
|   | |||||||
| @@ -21,7 +21,6 @@ import ( | |||||||
| 	"path/filepath" | 	"path/filepath" | ||||||
| 	"runtime" | 	"runtime" | ||||||
| 	"sort" | 	"sort" | ||||||
| 	"strconv" |  | ||||||
| 	"strings" | 	"strings" | ||||||
|  |  | ||||||
| 	"android/soong/android" | 	"android/soong/android" | ||||||
| @@ -214,7 +213,8 @@ func (a *apexBundle) buildManifest(ctx android.ModuleContext, provideNativeLibs, | |||||||
| 		}, | 		}, | ||||||
| 	}) | 	}) | ||||||
|  |  | ||||||
| 	if a.minSdkVersion(ctx) == android.SdkVersion_Android10 { | 	minSdkVersion := a.minSdkVersion(ctx) | ||||||
|  | 	if minSdkVersion.EqualTo(android.SdkVersion_Android10) { | ||||||
| 		// b/143654022 Q apexd can't understand newly added keys in apex_manifest.json | 		// b/143654022 Q apexd can't understand newly added keys in apex_manifest.json | ||||||
| 		// prepare stripped-down version so that APEX modules built from R+ can be installed to Q | 		// prepare stripped-down version so that APEX modules built from R+ can be installed to Q | ||||||
| 		a.manifestJsonOut = android.PathForModuleOut(ctx, "apex_manifest.json") | 		a.manifestJsonOut = android.PathForModuleOut(ctx, "apex_manifest.json") | ||||||
| @@ -426,7 +426,8 @@ func (a *apexBundle) buildUnflattenedApex(ctx android.ModuleContext) { | |||||||
| 	var emitCommands []string | 	var emitCommands []string | ||||||
| 	imageContentFile := android.PathForModuleOut(ctx, "content.txt") | 	imageContentFile := android.PathForModuleOut(ctx, "content.txt") | ||||||
| 	emitCommands = append(emitCommands, "echo ./apex_manifest.pb >> "+imageContentFile.String()) | 	emitCommands = append(emitCommands, "echo ./apex_manifest.pb >> "+imageContentFile.String()) | ||||||
| 	if a.minSdkVersion(ctx) == android.SdkVersion_Android10 { | 	minSdkVersion := a.minSdkVersion(ctx) | ||||||
|  | 	if minSdkVersion.EqualTo(android.SdkVersion_Android10) { | ||||||
| 		emitCommands = append(emitCommands, "echo ./apex_manifest.json >> "+imageContentFile.String()) | 		emitCommands = append(emitCommands, "echo ./apex_manifest.json >> "+imageContentFile.String()) | ||||||
| 	} | 	} | ||||||
| 	for _, fi := range a.filesInfo { | 	for _, fi := range a.filesInfo { | ||||||
| @@ -536,8 +537,9 @@ func (a *apexBundle) buildUnflattenedApex(ctx android.ModuleContext) { | |||||||
| 		// TODO(b/157078772): propagate min_sdk_version to apexer. | 		// TODO(b/157078772): propagate min_sdk_version to apexer. | ||||||
| 		minSdkVersion := ctx.Config().DefaultAppTargetSdk() | 		minSdkVersion := ctx.Config().DefaultAppTargetSdk() | ||||||
|  |  | ||||||
| 		if a.minSdkVersion(ctx) == android.SdkVersion_Android10 { | 		moduleMinSdkVersion := a.minSdkVersion(ctx) | ||||||
| 			minSdkVersion = strconv.Itoa(a.minSdkVersion(ctx)) | 		if moduleMinSdkVersion.EqualTo(android.SdkVersion_Android10) { | ||||||
|  | 			minSdkVersion = moduleMinSdkVersion.String() | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		if java.UseApiFingerprint(ctx) { | 		if java.UseApiFingerprint(ctx) { | ||||||
| @@ -566,7 +568,7 @@ func (a *apexBundle) buildUnflattenedApex(ctx android.ModuleContext) { | |||||||
| 			ctx.PropertyErrorf("test_only_no_hashtree", "not available") | 			ctx.PropertyErrorf("test_only_no_hashtree", "not available") | ||||||
| 			return | 			return | ||||||
| 		} | 		} | ||||||
| 		if a.minSdkVersion(ctx) > android.SdkVersion_Android10 || a.testOnlyShouldSkipHashtreeGeneration() { | 		if moduleMinSdkVersion.GreaterThan(android.SdkVersion_Android10) || a.testOnlyShouldSkipHashtreeGeneration() { | ||||||
| 			// Apexes which are supposed to be installed in builtin dirs(/system, etc) | 			// Apexes which are supposed to be installed in builtin dirs(/system, etc) | ||||||
| 			// don't need hashtree for activation. Therefore, by removing hashtree from | 			// don't need hashtree for activation. Therefore, by removing hashtree from | ||||||
| 			// apex bundle (filesystem image in it, to be specific), we can save storage. | 			// apex bundle (filesystem image in it, to be specific), we can save storage. | ||||||
| @@ -583,7 +585,7 @@ func (a *apexBundle) buildUnflattenedApex(ctx android.ModuleContext) { | |||||||
| 			optFlags = append(optFlags, "--do_not_check_keyname") | 			optFlags = append(optFlags, "--do_not_check_keyname") | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		if a.minSdkVersion(ctx) == android.SdkVersion_Android10 { | 		if moduleMinSdkVersion == android.SdkVersion_Android10 { | ||||||
| 			implicitInputs = append(implicitInputs, a.manifestJsonOut) | 			implicitInputs = append(implicitInputs, a.manifestJsonOut) | ||||||
| 			optFlags = append(optFlags, "--manifest_json "+a.manifestJsonOut.String()) | 			optFlags = append(optFlags, "--manifest_json "+a.manifestJsonOut.String()) | ||||||
| 		} | 		} | ||||||
|   | |||||||
| @@ -16,7 +16,6 @@ package apex | |||||||
|  |  | ||||||
| import ( | import ( | ||||||
| 	"path/filepath" | 	"path/filepath" | ||||||
| 	"strconv" |  | ||||||
| 	"strings" | 	"strings" | ||||||
| 	"sync" | 	"sync" | ||||||
|  |  | ||||||
| @@ -124,10 +123,10 @@ func makeCompatSymlinks(name string, ctx android.ModuleContext) (symlinks []stri | |||||||
| 	// Since prebuilt vndk libs still depend on system/lib/vndk path | 	// Since prebuilt vndk libs still depend on system/lib/vndk path | ||||||
| 	if strings.HasPrefix(name, vndkApexNamePrefix) { | 	if strings.HasPrefix(name, vndkApexNamePrefix) { | ||||||
| 		vndkVersion := strings.TrimPrefix(name, vndkApexNamePrefix) | 		vndkVersion := strings.TrimPrefix(name, vndkApexNamePrefix) | ||||||
| 		if numVer, err := strconv.Atoi(vndkVersion); err != nil { | 		if ver, err := android.ApiLevelFromUser(ctx, vndkVersion); err != nil { | ||||||
| 			ctx.ModuleErrorf("apex_vndk should be named as %v<ver:number>: %s", vndkApexNamePrefix, name) | 			ctx.ModuleErrorf("apex_vndk should be named as %v<ver:number>: %s", vndkApexNamePrefix, name) | ||||||
| 			return | 			return | ||||||
| 		} else if numVer > android.SdkVersion_Android10 { | 		} else if ver.GreaterThan(android.SdkVersion_Android10) { | ||||||
| 			return | 			return | ||||||
| 		} | 		} | ||||||
| 		// the name of vndk apex is formatted "com.android.vndk.v" + version | 		// the name of vndk apex is formatted "com.android.vndk.v" + version | ||||||
|   | |||||||
							
								
								
									
										45
									
								
								cc/cc.go
									
									
									
									
									
								
							
							
						
						
									
										45
									
								
								cc/cc.go
									
									
									
									
									
								
							| @@ -354,7 +354,7 @@ type ModuleContextIntf interface { | |||||||
| 	useClangLld(actx ModuleContext) bool | 	useClangLld(actx ModuleContext) bool | ||||||
| 	isForPlatform() bool | 	isForPlatform() bool | ||||||
| 	apexVariationName() string | 	apexVariationName() string | ||||||
| 	apexSdkVersion() int | 	apexSdkVersion() android.ApiLevel | ||||||
| 	hasStubsVariants() bool | 	hasStubsVariants() bool | ||||||
| 	isStubs() bool | 	isStubs() bool | ||||||
| 	bootstrap() bool | 	bootstrap() bool | ||||||
| @@ -615,7 +615,7 @@ type Module struct { | |||||||
| 	kytheFiles android.Paths | 	kytheFiles android.Paths | ||||||
|  |  | ||||||
| 	// For apex variants, this is set as apex.min_sdk_version | 	// For apex variants, this is set as apex.min_sdk_version | ||||||
| 	apexSdkVersion int | 	apexSdkVersion android.ApiLevel | ||||||
| } | } | ||||||
|  |  | ||||||
| func (c *Module) Toc() android.OptionalPath { | func (c *Module) Toc() android.OptionalPath { | ||||||
| @@ -1328,7 +1328,7 @@ func (ctx *moduleContextImpl) apexVariationName() string { | |||||||
| 	return ctx.mod.ApexVariationName() | 	return ctx.mod.ApexVariationName() | ||||||
| } | } | ||||||
|  |  | ||||||
| func (ctx *moduleContextImpl) apexSdkVersion() int { | func (ctx *moduleContextImpl) apexSdkVersion() android.ApiLevel { | ||||||
| 	return ctx.mod.apexSdkVersion | 	return ctx.mod.apexSdkVersion | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -2315,16 +2315,16 @@ func (c *Module) depsToPaths(ctx android.ModuleContext) PathDeps { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	// For the dependency from platform to apex, use the latest stubs | 	// For the dependency from platform to apex, use the latest stubs | ||||||
| 	c.apexSdkVersion = android.FutureApiLevel | 	c.apexSdkVersion = android.CurrentApiLevel | ||||||
| 	if !c.IsForPlatform() { | 	if !c.IsForPlatform() { | ||||||
| 		c.apexSdkVersion = c.ApexProperties.Info.MinSdkVersion | 		c.apexSdkVersion = c.ApexProperties.Info.MinSdkVersion(ctx) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	if android.InList("hwaddress", ctx.Config().SanitizeDevice()) { | 	if android.InList("hwaddress", ctx.Config().SanitizeDevice()) { | ||||||
| 		// In hwasan build, we override apexSdkVersion to the FutureApiLevel(10000) | 		// In hwasan build, we override apexSdkVersion to the FutureApiLevel(10000) | ||||||
| 		// so that even Q(29/Android10) apexes could use the dynamic unwinder by linking the newer stubs(e.g libc(R+)). | 		// so that even Q(29/Android10) apexes could use the dynamic unwinder by linking the newer stubs(e.g libc(R+)). | ||||||
| 		// (b/144430859) | 		// (b/144430859) | ||||||
| 		c.apexSdkVersion = android.FutureApiLevel | 		c.apexSdkVersion = android.CurrentApiLevel | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	ctx.VisitDirectDeps(func(dep android.Module) { | 	ctx.VisitDirectDeps(func(dep android.Module) { | ||||||
| @@ -2421,7 +2421,7 @@ func (c *Module) depsToPaths(ctx android.ModuleContext) PathDeps { | |||||||
|  |  | ||||||
| 		if libDepTag, ok := depTag.(libraryDependencyTag); ok { | 		if libDepTag, ok := depTag.(libraryDependencyTag); ok { | ||||||
| 			// Only use static unwinder for legacy (min_sdk_version = 29) apexes (b/144430859) | 			// Only use static unwinder for legacy (min_sdk_version = 29) apexes (b/144430859) | ||||||
| 			if libDepTag.staticUnwinder && c.apexSdkVersion > android.SdkVersion_Android10 { | 			if libDepTag.staticUnwinder && c.apexSdkVersion.GreaterThan(android.SdkVersion_Android10) { | ||||||
| 				return | 				return | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
| @@ -2465,7 +2465,7 @@ func (c *Module) depsToPaths(ctx android.ModuleContext) PathDeps { | |||||||
|  |  | ||||||
| 				// when to use (unspecified) stubs, check min_sdk_version and choose the right one | 				// when to use (unspecified) stubs, check min_sdk_version and choose the right one | ||||||
| 				if useThisDep && depIsStubs && !libDepTag.explicitlyVersioned { | 				if useThisDep && depIsStubs && !libDepTag.explicitlyVersioned { | ||||||
| 					versionToUse, err := c.ChooseSdkVersion(ccDep.StubsVersions(), c.apexSdkVersion) | 					versionToUse, err := c.ChooseSdkVersion(ccDep.StubsVersions(), c.apexSdkVersion.FinalOrFutureInt()) | ||||||
| 					if err != nil { | 					if err != nil { | ||||||
| 						ctx.OtherModuleErrorf(dep, err.Error()) | 						ctx.OtherModuleErrorf(dep, err.Error()) | ||||||
| 						return | 						return | ||||||
| @@ -2488,7 +2488,7 @@ func (c *Module) depsToPaths(ctx android.ModuleContext) PathDeps { | |||||||
| 						// if this is for use_vendor apex && dep has stubsVersions | 						// if this is for use_vendor apex && dep has stubsVersions | ||||||
| 						// apply the same rule of apex sdk enforcement to choose right version | 						// apply the same rule of apex sdk enforcement to choose right version | ||||||
| 						var err error | 						var err error | ||||||
| 						versionToUse, err = c.ChooseSdkVersion(versions, c.apexSdkVersion) | 						versionToUse, err = c.ChooseSdkVersion(versions, c.apexSdkVersion.FinalOrFutureInt()) | ||||||
| 						if err != nil { | 						if err != nil { | ||||||
| 							ctx.OtherModuleErrorf(dep, err.Error()) | 							ctx.OtherModuleErrorf(dep, err.Error()) | ||||||
| 							return | 							return | ||||||
| @@ -3012,21 +3012,8 @@ func (c *Module) DepIsInSameApex(ctx android.BaseModuleContext, dep android.Modu | |||||||
| 	return true | 	return true | ||||||
| } | } | ||||||
|  |  | ||||||
| // b/154667674: refactor this to handle "current" in a consistent way | func (c *Module) ShouldSupportSdkVersion(ctx android.BaseModuleContext, | ||||||
| func decodeSdkVersionString(ctx android.BaseModuleContext, versionString string) (int, error) { | 	sdkVersion android.ApiLevel) error { | ||||||
| 	if versionString == "" { |  | ||||||
| 		return 0, fmt.Errorf("not specified") |  | ||||||
| 	} |  | ||||||
| 	if versionString == "current" { |  | ||||||
| 		if ctx.Config().PlatformSdkCodename() == "REL" { |  | ||||||
| 			return ctx.Config().PlatformSdkVersionInt(), nil |  | ||||||
| 		} |  | ||||||
| 		return android.FutureApiLevel, nil |  | ||||||
| 	} |  | ||||||
| 	return android.ApiStrToNum(ctx, versionString) |  | ||||||
| } |  | ||||||
|  |  | ||||||
| func (c *Module) ShouldSupportSdkVersion(ctx android.BaseModuleContext, sdkVersion int) error { |  | ||||||
| 	// We ignore libclang_rt.* prebuilt libs since they declare sdk_version: 14(b/121358700) | 	// We ignore libclang_rt.* prebuilt libs since they declare sdk_version: 14(b/121358700) | ||||||
| 	if strings.HasPrefix(ctx.OtherModuleName(c), "libclang_rt") { | 	if strings.HasPrefix(ctx.OtherModuleName(c), "libclang_rt") { | ||||||
| 		return nil | 		return nil | ||||||
| @@ -3050,11 +3037,17 @@ func (c *Module) ShouldSupportSdkVersion(ctx android.BaseModuleContext, sdkVersi | |||||||
| 		// non-SDK variant resets sdk_version, which works too. | 		// non-SDK variant resets sdk_version, which works too. | ||||||
| 		minSdkVersion = c.SdkVersion() | 		minSdkVersion = c.SdkVersion() | ||||||
| 	} | 	} | ||||||
| 	ver, err := decodeSdkVersionString(ctx, minSdkVersion) | 	if minSdkVersion == "" { | ||||||
|  | 		return fmt.Errorf("neither min_sdk_version nor sdk_version specificed") | ||||||
|  | 	} | ||||||
|  | 	// Not using nativeApiLevelFromUser because the context here is not | ||||||
|  | 	// necessarily a native context. | ||||||
|  | 	ver, err := android.ApiLevelFromUser(ctx, minSdkVersion) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| 	if ver > sdkVersion { |  | ||||||
|  | 	if ver.GreaterThan(sdkVersion) { | ||||||
| 		return fmt.Errorf("newer SDK(%v)", ver) | 		return fmt.Errorf("newer SDK(%v)", ver) | ||||||
| 	} | 	} | ||||||
| 	return nil | 	return nil | ||||||
|   | |||||||
| @@ -354,7 +354,9 @@ func (compiler *baseCompiler) compilerFlags(ctx ModuleContext, flags Flags, deps | |||||||
| 			flags.Global.CommonFlags = append(flags.Global.CommonFlags, "-D__ANDROID_APEX_NAME__='\""+ctx.apexVariationName()+"\"'") | 			flags.Global.CommonFlags = append(flags.Global.CommonFlags, "-D__ANDROID_APEX_NAME__='\""+ctx.apexVariationName()+"\"'") | ||||||
| 		} | 		} | ||||||
| 		if ctx.Device() { | 		if ctx.Device() { | ||||||
| 			flags.Global.CommonFlags = append(flags.Global.CommonFlags, "-D__ANDROID_SDK_VERSION__="+strconv.Itoa(ctx.apexSdkVersion())) | 			flags.Global.CommonFlags = append(flags.Global.CommonFlags, | ||||||
|  | 				fmt.Sprintf("-D__ANDROID_SDK_VERSION__=%d", | ||||||
|  | 					ctx.apexSdkVersion().FinalOrFutureInt())) | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|   | |||||||
| @@ -19,8 +19,6 @@ import ( | |||||||
| 	"io" | 	"io" | ||||||
| 	"path/filepath" | 	"path/filepath" | ||||||
| 	"regexp" | 	"regexp" | ||||||
| 	"sort" |  | ||||||
| 	"strconv" |  | ||||||
| 	"strings" | 	"strings" | ||||||
| 	"sync" | 	"sync" | ||||||
|  |  | ||||||
| @@ -1520,20 +1518,18 @@ func LinkageMutator(mctx android.BottomUpMutatorContext) { | |||||||
| } | } | ||||||
|  |  | ||||||
| func normalizeVersions(ctx android.BaseModuleContext, versions []string) { | func normalizeVersions(ctx android.BaseModuleContext, versions []string) { | ||||||
| 	numVersions := make([]int, len(versions)) | 	var previous android.ApiLevel | ||||||
| 	for i, v := range versions { | 	for i, v := range versions { | ||||||
| 		numVer, err := android.ApiStrToNum(ctx, v) | 		ver, err := android.ApiLevelFromUser(ctx, v) | ||||||
| 		if err != nil { | 		if err != nil { | ||||||
| 			ctx.PropertyErrorf("versions", "%s", err.Error()) | 			ctx.PropertyErrorf("versions", "%s", err.Error()) | ||||||
| 			return | 			return | ||||||
| 		} | 		} | ||||||
| 		numVersions[i] = numVer | 		if i > 0 && ver.LessThanOrEqualTo(previous) { | ||||||
| 	} | 			ctx.PropertyErrorf("versions", "not sorted: %v", versions) | ||||||
| 	if !sort.IsSorted(sort.IntSlice(numVersions)) { | 		} | ||||||
| 		ctx.PropertyErrorf("versions", "not sorted: %v", versions) | 		versions[i] = ver.String() | ||||||
| 	} | 		previous = ver | ||||||
| 	for i, v := range numVersions { |  | ||||||
| 		versions[i] = strconv.Itoa(v) |  | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -195,7 +195,7 @@ func TestStubsVersions(t *testing.T) { | |||||||
| 			name: "libfoo", | 			name: "libfoo", | ||||||
| 			srcs: ["foo.c"], | 			srcs: ["foo.c"], | ||||||
| 			stubs: { | 			stubs: { | ||||||
| 				versions: ["29", "R", "10000"], | 				versions: ["29", "R", "current"], | ||||||
| 			}, | 			}, | ||||||
| 		} | 		} | ||||||
| 	` | 	` | ||||||
| @@ -204,7 +204,7 @@ func TestStubsVersions(t *testing.T) { | |||||||
| 	ctx := testCcWithConfig(t, config) | 	ctx := testCcWithConfig(t, config) | ||||||
|  |  | ||||||
| 	variants := ctx.ModuleVariantsForTests("libfoo") | 	variants := ctx.ModuleVariantsForTests("libfoo") | ||||||
| 	for _, expectedVer := range []string{"29", "9000", "10000"} { | 	for _, expectedVer := range []string{"29", "R", "current"} { | ||||||
| 		expectedVariant := "android_arm_armv7-a-neon_shared_" + expectedVer | 		expectedVariant := "android_arm_armv7-a-neon_shared_" + expectedVer | ||||||
| 		if !inList(expectedVariant, variants) { | 		if !inList(expectedVariant, variants) { | ||||||
| 			t.Errorf("missing expected variant: %q", expectedVariant) | 			t.Errorf("missing expected variant: %q", expectedVariant) | ||||||
| @@ -218,7 +218,7 @@ func TestStubsVersions_NotSorted(t *testing.T) { | |||||||
| 			name: "libfoo", | 			name: "libfoo", | ||||||
| 			srcs: ["foo.c"], | 			srcs: ["foo.c"], | ||||||
| 			stubs: { | 			stubs: { | ||||||
| 				versions: ["29", "10000", "R"], | 				versions: ["29", "current", "R"], | ||||||
| 			}, | 			}, | ||||||
| 		} | 		} | ||||||
| 	` | 	` | ||||||
| @@ -233,10 +233,10 @@ func TestStubsVersions_ParseError(t *testing.T) { | |||||||
| 			name: "libfoo", | 			name: "libfoo", | ||||||
| 			srcs: ["foo.c"], | 			srcs: ["foo.c"], | ||||||
| 			stubs: { | 			stubs: { | ||||||
| 				versions: ["29", "10000", "X"], | 				versions: ["29", "current", "X"], | ||||||
| 			}, | 			}, | ||||||
| 		} | 		} | ||||||
| 	` | 	` | ||||||
|  |  | ||||||
| 	testCcError(t, `"libfoo" .*: versions: SDK version should be`, bp) | 	testCcError(t, `"libfoo" .*: versions: "X" could not be parsed as an integer and is not a recognized codename`, bp) | ||||||
| } | } | ||||||
|   | |||||||
| @@ -555,7 +555,8 @@ func (g *Module) AndroidMk() android.AndroidMkData { | |||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
| func (g *Module) ShouldSupportSdkVersion(ctx android.BaseModuleContext, sdkVersion int) error { | func (g *Module) ShouldSupportSdkVersion(ctx android.BaseModuleContext, | ||||||
|  | 	sdkVersion android.ApiLevel) error { | ||||||
| 	// Because generated outputs are checked by client modules(e.g. cc_library, ...) | 	// Because generated outputs are checked by client modules(e.g. cc_library, ...) | ||||||
| 	// we can safely ignore the check here. | 	// we can safely ignore the check here. | ||||||
| 	return nil | 	return nil | ||||||
|   | |||||||
| @@ -774,7 +774,8 @@ func (a *AARImport) DepIsInSameApex(ctx android.BaseModuleContext, dep android.M | |||||||
| 	return a.depIsInSameApex(ctx, dep) | 	return a.depIsInSameApex(ctx, dep) | ||||||
| } | } | ||||||
|  |  | ||||||
| func (g *AARImport) ShouldSupportSdkVersion(ctx android.BaseModuleContext, sdkVersion int) error { | func (g *AARImport) ShouldSupportSdkVersion(ctx android.BaseModuleContext, | ||||||
|  | 	sdkVersion android.ApiLevel) error { | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -436,7 +436,7 @@ func (a *AndroidApp) checkAppSdkVersions(ctx android.ModuleContext) { | |||||||
|  |  | ||||||
| 		if minSdkVersion, err := a.minSdkVersion().effectiveVersion(ctx); err == nil { | 		if minSdkVersion, err := a.minSdkVersion().effectiveVersion(ctx); err == nil { | ||||||
| 			a.checkJniLibsSdkVersion(ctx, minSdkVersion) | 			a.checkJniLibsSdkVersion(ctx, minSdkVersion) | ||||||
| 			android.CheckMinSdkVersion(a, ctx, int(minSdkVersion)) | 			android.CheckMinSdkVersion(a, ctx, minSdkVersion.ApiLevel(ctx)) | ||||||
| 		} else { | 		} else { | ||||||
| 			ctx.PropertyErrorf("min_sdk_version", "%s", err.Error()) | 			ctx.PropertyErrorf("min_sdk_version", "%s", err.Error()) | ||||||
| 		} | 		} | ||||||
| @@ -1637,7 +1637,8 @@ func (a *AndroidAppImport) minSdkVersion() sdkSpec { | |||||||
| 	return sdkSpecFrom("") | 	return sdkSpecFrom("") | ||||||
| } | } | ||||||
|  |  | ||||||
| func (j *AndroidAppImport) ShouldSupportSdkVersion(ctx android.BaseModuleContext, sdkVersion int) error { | func (j *AndroidAppImport) ShouldSupportSdkVersion(ctx android.BaseModuleContext, | ||||||
|  | 	sdkVersion android.ApiLevel) error { | ||||||
| 	// Do not check for prebuilts against the min_sdk_version of enclosing APEX | 	// Do not check for prebuilts against the min_sdk_version of enclosing APEX | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										11
									
								
								java/java.go
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								java/java.go
									
									
									
									
									
								
							| @@ -1876,7 +1876,8 @@ func (j *Module) DepIsInSameApex(ctx android.BaseModuleContext, dep android.Modu | |||||||
| 	return j.depIsInSameApex(ctx, dep) | 	return j.depIsInSameApex(ctx, dep) | ||||||
| } | } | ||||||
|  |  | ||||||
| func (j *Module) ShouldSupportSdkVersion(ctx android.BaseModuleContext, sdkVersion int) error { | func (j *Module) ShouldSupportSdkVersion(ctx android.BaseModuleContext, | ||||||
|  | 	sdkVersion android.ApiLevel) error { | ||||||
| 	sdkSpec := j.minSdkVersion() | 	sdkSpec := j.minSdkVersion() | ||||||
| 	if !sdkSpec.specified() { | 	if !sdkSpec.specified() { | ||||||
| 		return fmt.Errorf("min_sdk_version is not specified") | 		return fmt.Errorf("min_sdk_version is not specified") | ||||||
| @@ -1888,7 +1889,7 @@ func (j *Module) ShouldSupportSdkVersion(ctx android.BaseModuleContext, sdkVersi | |||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| 	if int(ver) > sdkVersion { | 	if ver.ApiLevel(ctx).GreaterThan(sdkVersion) { | ||||||
| 		return fmt.Errorf("newer SDK(%v)", ver) | 		return fmt.Errorf("newer SDK(%v)", ver) | ||||||
| 	} | 	} | ||||||
| 	return nil | 	return nil | ||||||
| @@ -2753,7 +2754,8 @@ func (j *Import) DepIsInSameApex(ctx android.BaseModuleContext, dep android.Modu | |||||||
| 	return j.depIsInSameApex(ctx, dep) | 	return j.depIsInSameApex(ctx, dep) | ||||||
| } | } | ||||||
|  |  | ||||||
| func (j *Import) ShouldSupportSdkVersion(ctx android.BaseModuleContext, sdkVersion int) error { | func (j *Import) ShouldSupportSdkVersion(ctx android.BaseModuleContext, | ||||||
|  | 	sdkVersion android.ApiLevel) error { | ||||||
| 	// Do not check for prebuilts against the min_sdk_version of enclosing APEX | 	// Do not check for prebuilts against the min_sdk_version of enclosing APEX | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
| @@ -2936,7 +2938,8 @@ func (j *DexImport) DexJarBuildPath() android.Path { | |||||||
| 	return j.dexJarFile | 	return j.dexJarFile | ||||||
| } | } | ||||||
|  |  | ||||||
| func (j *DexImport) ShouldSupportSdkVersion(ctx android.BaseModuleContext, sdkVersion int) error { | func (j *DexImport) ShouldSupportSdkVersion(ctx android.BaseModuleContext, | ||||||
|  | 	sdkVersion android.ApiLevel) error { | ||||||
| 	// we don't check prebuilt modules for sdk_version | 	// we don't check prebuilt modules for sdk_version | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|   | |||||||
| @@ -133,6 +133,10 @@ func (v sdkVersion) String() string { | |||||||
| 	return "(no version)" | 	return "(no version)" | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func (v sdkVersion) ApiLevel(ctx android.EarlyModuleContext) android.ApiLevel { | ||||||
|  | 	return android.ApiLevelOrPanic(ctx, v.String()) | ||||||
|  | } | ||||||
|  |  | ||||||
| // asNumberString directly converts the numeric value of this sdk version as a string. | // asNumberString directly converts the numeric value of this sdk version as a string. | ||||||
| // When isNumbered() is true, this method is the same as String(). However, for sdkVersionCurrent | // When isNumbered() is true, this method is the same as String(). However, for sdkVersionCurrent | ||||||
| // and sdkVersionNone, this returns 10000 and 0 while String() returns "current" and "(no version"), | // and sdkVersionNone, this returns 10000 and 0 while String() returns "current" and "(no version"), | ||||||
|   | |||||||
| @@ -1878,7 +1878,8 @@ func (module *SdkLibraryImport) DepIsInSameApex(mctx android.BaseModuleContext, | |||||||
| 	return false | 	return false | ||||||
| } | } | ||||||
|  |  | ||||||
| func (module *SdkLibraryImport) ShouldSupportSdkVersion(ctx android.BaseModuleContext, sdkVersion int) error { | func (module *SdkLibraryImport) ShouldSupportSdkVersion(ctx android.BaseModuleContext, | ||||||
|  | 	sdkVersion android.ApiLevel) error { | ||||||
| 	// we don't check prebuilt modules for sdk_version | 	// we don't check prebuilt modules for sdk_version | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
| @@ -2078,7 +2079,8 @@ func (module *sdkLibraryXml) DepsMutator(ctx android.BottomUpMutatorContext) { | |||||||
| 	// do nothing | 	// do nothing | ||||||
| } | } | ||||||
|  |  | ||||||
| func (module *sdkLibraryXml) ShouldSupportSdkVersion(ctx android.BaseModuleContext, sdkVersion int) error { | func (module *sdkLibraryXml) ShouldSupportSdkVersion(ctx android.BaseModuleContext, | ||||||
|  | 	sdkVersion android.ApiLevel) error { | ||||||
| 	// sdkLibraryXml doesn't need to be checked separately because java_sdk_library is checked | 	// sdkLibraryXml doesn't need to be checked separately because java_sdk_library is checked | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|   | |||||||
| @@ -310,7 +310,8 @@ func (m *syspropLibrary) AndroidMk() android.AndroidMkData { | |||||||
| 		}} | 		}} | ||||||
| } | } | ||||||
|  |  | ||||||
| func (m *syspropLibrary) ShouldSupportSdkVersion(ctx android.BaseModuleContext, sdkVersion int) error { | func (m *syspropLibrary) ShouldSupportSdkVersion(ctx android.BaseModuleContext, | ||||||
|  | 	sdkVersion android.ApiLevel) error { | ||||||
| 	return fmt.Errorf("sysprop_library is not supposed to be part of apex modules") | 	return fmt.Errorf("sysprop_library is not supposed to be part of apex modules") | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user