| // Copyright (C) 2021 The Android Open Source Project | 
 | // | 
 | // 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 java | 
 |  | 
 | import ( | 
 | 	"android/soong/android" | 
 | 	"github.com/google/blueprint" | 
 | ) | 
 |  | 
 | // MonolithicHiddenAPIInfo contains information needed/provided by the hidden API generation of the | 
 | // monolithic hidden API files. | 
 | // | 
 | // Each list of paths includes all the equivalent paths from each of the bootclasspath_fragment | 
 | // modules that contribute to the platform-bootclasspath. | 
 | type MonolithicHiddenAPIInfo struct { | 
 | 	// FlagsFilesByCategory maps from the flag file category to the paths containing information for | 
 | 	// that category. | 
 | 	FlagsFilesByCategory FlagFilesByCategory | 
 |  | 
 | 	// The paths to the generated annotation-flags.csv files. | 
 | 	AnnotationFlagsPaths android.Paths | 
 |  | 
 | 	// The paths to the generated metadata.csv files. | 
 | 	MetadataPaths android.Paths | 
 |  | 
 | 	// The paths to the generated index.csv files. | 
 | 	IndexPaths android.Paths | 
 |  | 
 | 	// The subsets of the monolithic hiddenapi-stubs-flags.txt file that are provided by each | 
 | 	// bootclasspath_fragment modules. | 
 | 	StubFlagSubsets SignatureCsvSubsets | 
 |  | 
 | 	// The subsets of the monolithic hiddenapi-flags.csv file that are provided by each | 
 | 	// bootclasspath_fragment modules. | 
 | 	FlagSubsets SignatureCsvSubsets | 
 |  | 
 | 	// The classes jars from the libraries on the platform bootclasspath. | 
 | 	ClassesJars android.Paths | 
 | } | 
 |  | 
 | // newMonolithicHiddenAPIInfo creates a new MonolithicHiddenAPIInfo from the flagFilesByCategory | 
 | // plus information provided by each of the fragments. | 
 | func newMonolithicHiddenAPIInfo(ctx android.ModuleContext, flagFilesByCategory FlagFilesByCategory, classpathElements ClasspathElements) MonolithicHiddenAPIInfo { | 
 | 	monolithicInfo := MonolithicHiddenAPIInfo{} | 
 |  | 
 | 	monolithicInfo.FlagsFilesByCategory = flagFilesByCategory | 
 |  | 
 | 	// Merge all the information from the classpathElements. The fragments form a DAG so it is possible that | 
 | 	// this will introduce duplicates so they will be resolved after processing all the classpathElements. | 
 | 	for _, element := range classpathElements { | 
 | 		switch e := element.(type) { | 
 | 		case *ClasspathLibraryElement: | 
 | 			classesJars := retrieveClassesJarsFromModule(e.Module()) | 
 | 			monolithicInfo.ClassesJars = append(monolithicInfo.ClassesJars, classesJars...) | 
 |  | 
 | 		case *ClasspathFragmentElement: | 
 | 			fragment := e.Module() | 
 | 			if info, ok := android.OtherModuleProvider(ctx, fragment, HiddenAPIInfoProvider); ok { | 
 | 				monolithicInfo.append(ctx, fragment, &info) | 
 | 			} else { | 
 | 				ctx.ModuleErrorf("%s does not provide hidden API information", fragment) | 
 | 			} | 
 | 		} | 
 | 	} | 
 |  | 
 | 	return monolithicInfo | 
 | } | 
 |  | 
 | // append appends all the files from the supplied info to the corresponding files in this struct. | 
 | func (i *MonolithicHiddenAPIInfo) append(ctx android.ModuleContext, otherModule android.Module, other *HiddenAPIInfo) { | 
 | 	i.FlagsFilesByCategory.append(other.FlagFilesByCategory) | 
 | 	i.AnnotationFlagsPaths = append(i.AnnotationFlagsPaths, other.AnnotationFlagsPath) | 
 | 	i.MetadataPaths = append(i.MetadataPaths, other.MetadataPath) | 
 | 	i.IndexPaths = append(i.IndexPaths, other.IndexPath) | 
 |  | 
 | 	apexInfo, ok := android.OtherModuleProvider(ctx, otherModule, android.ApexInfoProvider) | 
 | 	if !ok { | 
 | 		ctx.ModuleErrorf("Could not determine min_version_version of %s\n", otherModule.Name()) | 
 | 		return | 
 | 	} | 
 | 	if apexInfo.MinSdkVersion.LessThanOrEqualTo(android.ApiLevelR) { | 
 | 		// Restrict verify_overlaps to R and older modules. | 
 | 		// The runtime in S does not have the same restriction that | 
 | 		// requires the hiddenapi flags to be generated in a monolithic | 
 | 		// invocation. | 
 | 		i.StubFlagSubsets = append(i.StubFlagSubsets, other.StubFlagSubset()) | 
 | 		i.FlagSubsets = append(i.FlagSubsets, other.FlagSubset()) | 
 | 	} | 
 | } | 
 |  | 
 | var MonolithicHiddenAPIInfoProvider = blueprint.NewProvider[MonolithicHiddenAPIInfo]() |