Strip META-INF/services from implementation jars when using as header jars
If a header jar couldn't be built (for example when an API generating annoation processor is in use) the implementation jar is reused as the header jar. If the implementation jar contains an annotation processor listed in META-INF/services/javax.annotation.processing.Processor then later javac executions with the implementation jar in the classpath could attempt to run the annotation processors unexpectedly. Remove the META-INF/services directory when using an implementation jar as a header jar. Bug: 290933559 Test: builds Change-Id: I40d48644bc5a09a9564dc2c4b38f627edd00fcf8
This commit is contained in:
@@ -1477,7 +1477,13 @@ func (j *Module) compile(ctx android.ModuleContext, aaptSrcJar android.Path) {
|
||||
|
||||
j.implementationJarFile = outputFile
|
||||
if j.headerJarFile == nil {
|
||||
j.headerJarFile = j.implementationJarFile
|
||||
// If this module couldn't generate a header jar (for example due to api generating annotation processors)
|
||||
// then use the implementation jar. Run it through zip2zip first to remove any files in META-INF/services
|
||||
// so that javac on modules that depend on this module don't pick up annotation processors (which may be
|
||||
// missing their implementations) from META-INF/services/javax.annotation.processing.Processor.
|
||||
headerJarFile := android.PathForModuleOut(ctx, "javac-header", jarName)
|
||||
convertImplementationJarToHeaderJar(ctx, j.implementationJarFile, headerJarFile)
|
||||
j.headerJarFile = headerJarFile
|
||||
}
|
||||
|
||||
// enforce syntax check to jacoco filters for any build (http://b/183622051)
|
||||
|
Reference in New Issue
Block a user