mirror of
https://github.com/openjdk/jdk.git
synced 2025-09-20 11:04:34 +02:00
6879371: javap does not close internal default file manager
Reviewed-by: darcy
This commit is contained in:
parent
a8e28960cd
commit
b2645b9065
2 changed files with 136 additions and 3 deletions
|
@ -455,8 +455,19 @@ public class JavapTask implements DisassemblerTool.DisassemblerTask, Messages {
|
|||
return EXIT_CMDERR;
|
||||
}
|
||||
|
||||
boolean ok = run();
|
||||
return ok ? EXIT_OK : EXIT_ERROR;
|
||||
try {
|
||||
boolean ok = run();
|
||||
return ok ? EXIT_OK : EXIT_ERROR;
|
||||
} finally {
|
||||
if (defaultFileManager != null) {
|
||||
try {
|
||||
defaultFileManager.close();
|
||||
defaultFileManager = null;
|
||||
} catch (IOException e) {
|
||||
throw new InternalError(e);
|
||||
}
|
||||
}
|
||||
}
|
||||
} catch (BadArgs e) {
|
||||
reportError(e.key, e.args);
|
||||
if (e.showUsage) {
|
||||
|
@ -856,7 +867,9 @@ public class JavapTask implements DisassemblerTool.DisassemblerTask, Messages {
|
|||
}
|
||||
|
||||
private JavaFileManager getDefaultFileManager(final DiagnosticListener<? super JavaFileObject> dl, PrintWriter log) {
|
||||
return JavapFileManager.create(dl, log);
|
||||
if (defaultFileManager == null)
|
||||
defaultFileManager = JavapFileManager.create(dl, log);
|
||||
return defaultFileManager;
|
||||
}
|
||||
|
||||
private JavaFileObject getClassFileObject(String className) throws IOException {
|
||||
|
@ -1004,6 +1017,7 @@ public class JavapTask implements DisassemblerTool.DisassemblerTask, Messages {
|
|||
|
||||
protected Context context;
|
||||
JavaFileManager fileManager;
|
||||
JavaFileManager defaultFileManager;
|
||||
PrintWriter log;
|
||||
DiagnosticListener<? super JavaFileObject> diagnosticListener;
|
||||
List<String> classes;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue