Shard kythe invocations when javac is sharded
The kythe pipeline has trouble injesting all 6000 files of framework.jar at once. Shared invocations of the kythe extractor when javac is sharded to produce multiple smaller kzip files. Bug: 140426870 Test: no change to build.ninja Test: m out/soong/.intermediates/frameworks/base/framework/android_common/framework0.kzip Test: TestSharding in java_test.go Change-Id: I867db4ef5cb1e7f3ce8359a46aac2c00ed8a8912
This commit is contained in:
39
java/java.go
39
java/java.go
@@ -25,6 +25,7 @@ import (
|
||||
"strings"
|
||||
|
||||
"github.com/google/blueprint"
|
||||
"github.com/google/blueprint/pathtools"
|
||||
"github.com/google/blueprint/proptools"
|
||||
|
||||
"android/soong/android"
|
||||
@@ -1151,27 +1152,20 @@ func (j *Module) compile(ctx android.ModuleContext, aaptSrcJar android.Path) {
|
||||
if len(uniqueSrcFiles) > 0 {
|
||||
shardSrcs = shardPaths(uniqueSrcFiles, shardSize)
|
||||
for idx, shardSrc := range shardSrcs {
|
||||
classes := android.PathForModuleOut(ctx, "javac", jarName+strconv.Itoa(idx))
|
||||
TransformJavaToClasses(ctx, classes, idx, shardSrc, nil, flags, extraJarDeps)
|
||||
classes := j.compileJavaClasses(ctx, jarName, idx, shardSrc,
|
||||
nil, flags, extraJarDeps)
|
||||
jars = append(jars, classes)
|
||||
}
|
||||
}
|
||||
if len(srcJars) > 0 {
|
||||
classes := android.PathForModuleOut(ctx, "javac", jarName+strconv.Itoa(len(shardSrcs)))
|
||||
TransformJavaToClasses(ctx, classes, len(shardSrcs), nil, srcJars, flags, extraJarDeps)
|
||||
classes := j.compileJavaClasses(ctx, jarName, len(shardSrcs),
|
||||
nil, srcJars, flags, extraJarDeps)
|
||||
jars = append(jars, classes)
|
||||
}
|
||||
} else {
|
||||
classes := android.PathForModuleOut(ctx, "javac", jarName)
|
||||
TransformJavaToClasses(ctx, classes, -1, uniqueSrcFiles, srcJars, flags, extraJarDeps)
|
||||
classes := j.compileJavaClasses(ctx, jarName, -1, uniqueSrcFiles, srcJars, flags, extraJarDeps)
|
||||
jars = append(jars, classes)
|
||||
}
|
||||
if ctx.Config().EmitXrefRules() {
|
||||
extractionFile := android.PathForModuleOut(ctx, ctx.ModuleName()+".kzip")
|
||||
emitXrefRule(ctx, extractionFile, uniqueSrcFiles, srcJars, flags, extraJarDeps, "xref")
|
||||
j.kytheFiles = append(j.kytheFiles, extractionFile)
|
||||
|
||||
}
|
||||
if ctx.Failed() {
|
||||
return
|
||||
}
|
||||
@@ -1392,6 +1386,27 @@ func (j *Module) compile(ctx android.ModuleContext, aaptSrcJar android.Path) {
|
||||
j.outputFile = outputFile.WithoutRel()
|
||||
}
|
||||
|
||||
func (j *Module) compileJavaClasses(ctx android.ModuleContext, jarName string, idx int,
|
||||
srcFiles, srcJars android.Paths, flags javaBuilderFlags, extraJarDeps android.Paths) android.WritablePath {
|
||||
|
||||
kzipName := pathtools.ReplaceExtension(jarName, "kzip")
|
||||
if idx >= 0 {
|
||||
kzipName = strings.TrimSuffix(jarName, filepath.Ext(jarName)) + strconv.Itoa(idx) + ".kzip"
|
||||
jarName += strconv.Itoa(idx)
|
||||
}
|
||||
|
||||
classes := android.PathForModuleOut(ctx, "javac", jarName)
|
||||
TransformJavaToClasses(ctx, classes, idx, srcFiles, srcJars, flags, extraJarDeps)
|
||||
|
||||
if ctx.Config().EmitXrefRules() {
|
||||
extractionFile := android.PathForModuleOut(ctx, kzipName)
|
||||
emitXrefRule(ctx, extractionFile, idx, srcFiles, srcJars, flags, extraJarDeps)
|
||||
j.kytheFiles = append(j.kytheFiles, extractionFile)
|
||||
}
|
||||
|
||||
return classes
|
||||
}
|
||||
|
||||
// Check for invalid kotlinc flags. Only use this for flags explicitly passed by the user,
|
||||
// since some of these flags may be used internally.
|
||||
func CheckKotlincFlags(ctx android.ModuleContext, flags []string) {
|
||||
|
Reference in New Issue
Block a user