From 4ce27b2f9ececd863062cb6fe65c86e464215287 Mon Sep 17 00:00:00 2001 From: Jonathan Gibbons Date: Wed, 29 Oct 2014 18:01:22 -0700 Subject: [PATCH] 8062504: javadoc Start does not close file managers that it opens Reviewed-by: ksrini --- .../share/classes/com/sun/tools/javadoc/Start.java | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/javadoc/Start.java b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/javadoc/Start.java index de8f96cef65..3d4db8623f3 100644 --- a/langtools/src/jdk.javadoc/share/classes/com/sun/tools/javadoc/Start.java +++ b/langtools/src/jdk.javadoc/share/classes/com/sun/tools/javadoc/Start.java @@ -88,6 +88,9 @@ public class Start extends ToolOption.Helper { */ private boolean apiMode; + private JavaFileManager fileManager; + private boolean closeFileManagerOnExit; + Start(String programName, PrintWriter errWriter, PrintWriter warnWriter, @@ -239,6 +242,12 @@ public class Start extends ToolOption.Helper { messager.error(Messager.NOPOS, "main.fatal.exception"); failed = true; } finally { + if (fileManager != null && closeFileManagerOnExit) { + try { + fileManager.close(); + } catch (IOException ignore) { + } + } messager.exitNotice(); messager.flush(); } @@ -270,7 +279,8 @@ public class Start extends ToolOption.Helper { } - JavaFileManager fileManager = context.get(JavaFileManager.class); + fileManager = context.get(JavaFileManager.class); + setDocletInvoker(docletClass, fileManager, argv); compOpts = Options.instance(context); @@ -333,6 +343,7 @@ public class Start extends ToolOption.Helper { if (fileManager == null) { JavacFileManager.preRegister(context); fileManager = context.get(JavaFileManager.class); + closeFileManagerOnExit = true; } if (fileManager instanceof BaseFileManager) { ((BaseFileManager) fileManager).handleOptions(fileManagerOpts);