Merge "Fix check-boot-jars when a boot jar is provided by prebuilt" am: 0e63a8e761 am: ac2a42054f am: 71f093e485 am: e82eebba38
				
					
				
			Original change: https://android-review.googlesource.com/c/platform/build/soong/+/1341756 Change-Id: I1a43f97e85f2340a0d3f998fe509dec31363b525
This commit is contained in:
		| @@ -184,7 +184,7 @@ func (a *apexBundle) androidMkForFiles(w io.Writer, apexBundleName, apexName, mo | ||||
| 			// we need to remove the suffix from LOCAL_MODULE_STEM, otherwise | ||||
| 			// we will have foo.jar.jar | ||||
| 			fmt.Fprintln(w, "LOCAL_MODULE_STEM :=", strings.TrimSuffix(fi.Stem(), ".jar")) | ||||
| 			if javaModule, ok := fi.module.(java.Dependency); ok { | ||||
| 			if javaModule, ok := fi.module.(java.ApexDependency); ok { | ||||
| 				fmt.Fprintln(w, "LOCAL_SOONG_CLASSES_JAR :=", javaModule.ImplementationAndResourcesJars()[0].String()) | ||||
| 				fmt.Fprintln(w, "LOCAL_SOONG_HEADER_JAR :=", javaModule.HeaderJars()[0].String()) | ||||
| 			} else { | ||||
|   | ||||
| @@ -1687,7 +1687,9 @@ type javaDependency interface { | ||||
| func apexFileForJavaLibrary(ctx android.BaseModuleContext, lib javaDependency, module android.Module) apexFile { | ||||
| 	dirInApex := "javalib" | ||||
| 	fileToCopy := lib.DexJarBuildPath() | ||||
| 	af := newApexFile(ctx, fileToCopy, module.Name(), dirInApex, javaSharedLib, module) | ||||
| 	// Remove prebuilt_ if necessary so the source and prebuilt modules have the same name. | ||||
| 	name := strings.TrimPrefix(module.Name(), "prebuilt_") | ||||
| 	af := newApexFile(ctx, fileToCopy, name, dirInApex, javaSharedLib, module) | ||||
| 	af.jacocoReportClassesFile = lib.JacocoReportClassesFile() | ||||
| 	af.stem = lib.Stem() + ".jar" | ||||
| 	return af | ||||
|   | ||||
| @@ -500,11 +500,16 @@ func (j *Module) OutputFiles(tag string) (android.Paths, error) { | ||||
|  | ||||
| var _ android.OutputFileProducer = (*Module)(nil) | ||||
|  | ||||
| type Dependency interface { | ||||
| // Methods that need to be implemented for a module that is added to apex java_libs property. | ||||
| type ApexDependency interface { | ||||
| 	HeaderJars() android.Paths | ||||
| 	ImplementationAndResourcesJars() android.Paths | ||||
| } | ||||
|  | ||||
| type Dependency interface { | ||||
| 	ApexDependency | ||||
| 	ImplementationJars() android.Paths | ||||
| 	ResourceJars() android.Paths | ||||
| 	ImplementationAndResourcesJars() android.Paths | ||||
| 	DexJarBuildPath() android.Path | ||||
| 	DexJarInstallPath() android.Path | ||||
| 	AidlIncludeDirs() android.Paths | ||||
|   | ||||
| @@ -2009,6 +2009,26 @@ func (module *SdkLibraryImport) Stem() string { | ||||
| 	return module.BaseModuleName() | ||||
| } | ||||
|  | ||||
| var _ ApexDependency = (*SdkLibraryImport)(nil) | ||||
|  | ||||
| // to satisfy java.ApexDependency interface | ||||
| func (module *SdkLibraryImport) HeaderJars() android.Paths { | ||||
| 	if module.implLibraryModule == nil { | ||||
| 		return nil | ||||
| 	} else { | ||||
| 		return module.implLibraryModule.HeaderJars() | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // to satisfy java.ApexDependency interface | ||||
| func (module *SdkLibraryImport) ImplementationAndResourcesJars() android.Paths { | ||||
| 	if module.implLibraryModule == nil { | ||||
| 		return nil | ||||
| 	} else { | ||||
| 		return module.implLibraryModule.ImplementationAndResourcesJars() | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // | ||||
| // java_sdk_library_xml | ||||
| // | ||||
|   | ||||
		Reference in New Issue
	
	Block a user