diff --git a/langtools/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/ConsoleIOContext.java b/langtools/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/ConsoleIOContext.java index 5eeb742a06d..129e93a431f 100644 --- a/langtools/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/ConsoleIOContext.java +++ b/langtools/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/ConsoleIOContext.java @@ -215,6 +215,7 @@ class ConsoleIOContext extends IOContext { } catch (Exception ex) { throw new IOException(ex); } + input.shutdown(); } private void bind(String shortcut, Object action) { diff --git a/langtools/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/StopDetectingInputStream.java b/langtools/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/StopDetectingInputStream.java index 94c16f1e0c3..934d27bfd13 100644 --- a/langtools/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/StopDetectingInputStream.java +++ b/langtools/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/StopDetectingInputStream.java @@ -61,11 +61,14 @@ public final class StopDetectingInputStream extends InputStream { //an external editor is running. At the same time, it needs to run while the //user's code is running (so Ctrl-C is detected). Hence waiting here until //there is a confirmed need for input. - waitInputNeeded(); + StopDetectingInputStream.State currentState = waitInputNeeded(); + if (currentState == StopDetectingInputStream.State.CLOSED) { + break; + } if ((read = input.read()) == (-1)) { break; } - if (read == 3 && state == StopDetectingInputStream.State.BUFFER) { + if (read == 3 && currentState == StopDetectingInputStream.State.BUFFER) { stop.run(); } else { write(read); @@ -74,7 +77,9 @@ public final class StopDetectingInputStream extends InputStream { } catch (IOException ex) { errorHandler.accept(ex); } finally { - state = StopDetectingInputStream.State.CLOSED; + synchronized (StopDetectingInputStream.this) { + state = StopDetectingInputStream.State.CLOSED; + } } } }; @@ -107,6 +112,11 @@ public final class StopDetectingInputStream extends InputStream { } } + public synchronized void shutdown() { + state = State.CLOSED; + notifyAll(); + } + public synchronized void write(int b) { if (state != State.BUFFER) { state = State.WAIT; @@ -134,7 +144,7 @@ public final class StopDetectingInputStream extends InputStream { notifyAll(); } - private synchronized void waitInputNeeded() { + private synchronized State waitInputNeeded() { while (state == State.WAIT) { try { wait(); @@ -142,6 +152,8 @@ public final class StopDetectingInputStream extends InputStream { //ignore } } + + return state; } public enum State {