6548708: Annotation processing should free service loader if there are no processors
Reviewed-by: jjg
This commit is contained in:
parent
47307bdb89
commit
a898594639
@ -287,11 +287,12 @@ public class JavacProcessingEnvironment implements ProcessingEnvironment, Closea
|
||||
// The to-be-wrapped iterator.
|
||||
private Iterator<?> iterator;
|
||||
private Log log;
|
||||
private Class<?> loaderClass;
|
||||
private boolean jusl;
|
||||
private Object loader;
|
||||
|
||||
ServiceIterator(ClassLoader classLoader, Log log) {
|
||||
Class<?> loaderClass;
|
||||
String loadMethodName;
|
||||
boolean jusl;
|
||||
|
||||
this.log = log;
|
||||
try {
|
||||
@ -324,6 +325,7 @@ public class JavacProcessingEnvironment implements ProcessingEnvironment, Closea
|
||||
// For java.util.ServiceLoader, we have to call another
|
||||
// method to get the iterator.
|
||||
if (jusl) {
|
||||
loader = result; // Store ServiceLoader to call reload later
|
||||
Method m = loaderClass.getMethod("iterator");
|
||||
result = m.invoke(result); // serviceLoader.iterator();
|
||||
}
|
||||
@ -365,6 +367,18 @@ public class JavacProcessingEnvironment implements ProcessingEnvironment, Closea
|
||||
public void remove() {
|
||||
throw new UnsupportedOperationException();
|
||||
}
|
||||
|
||||
public void close() {
|
||||
if (jusl) {
|
||||
try {
|
||||
// Call java.util.ServiceLoader.reload
|
||||
Method reloadMethod = loaderClass.getMethod("reload");
|
||||
reloadMethod.invoke(loader);
|
||||
} catch(Exception e) {
|
||||
; // Ignore problems during a call to reload.
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@ -552,7 +566,7 @@ public class JavacProcessingEnvironment implements ProcessingEnvironment, Closea
|
||||
* been discoverd so far as well as the means to discover more, if
|
||||
* necessary. A single iterator should be used per round of
|
||||
* annotation processing. The iterator first visits already
|
||||
* discovered processors then fails over to the service provided
|
||||
* discovered processors then fails over to the service provider
|
||||
* mechanism if additional queries are made.
|
||||
*/
|
||||
class DiscoveredProcessors implements Iterable<ProcessorState> {
|
||||
@ -624,6 +638,16 @@ public class JavacProcessingEnvironment implements ProcessingEnvironment, Closea
|
||||
this.processorIterator = processorIterator;
|
||||
this.procStateList = new ArrayList<ProcessorState>();
|
||||
}
|
||||
|
||||
/**
|
||||
* Free jar files, etc. if using a service loader.
|
||||
*/
|
||||
public void close() {
|
||||
if (processorIterator != null &&
|
||||
processorIterator instanceof ServiceIterator) {
|
||||
((ServiceIterator) processorIterator).close();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void discoverAndRunProcs(Context context,
|
||||
@ -1023,6 +1047,8 @@ public class JavacProcessingEnvironment implements ProcessingEnvironment, Closea
|
||||
*/
|
||||
public void close() throws IOException {
|
||||
filer.close();
|
||||
if (discoveredProcs != null) // Make calling close idempotent
|
||||
discoveredProcs.close();
|
||||
discoveredProcs = null;
|
||||
if (processorClassLoader != null && processorClassLoader instanceof Closeable)
|
||||
((Closeable) processorClassLoader).close();
|
||||
|
Loading…
x
Reference in New Issue
Block a user