From 073f5872f8d4648398569c2ff48ef5bcbd7b159c Mon Sep 17 00:00:00 2001 From: TheMode Date: Sat, 8 May 2021 04:33:32 +0200 Subject: [PATCH] Fix jline reader thread never being shutdown --- .../server/terminal/MinestomTerminal.java | 41 +++++++++++-------- 1 file changed, 23 insertions(+), 18 deletions(-) diff --git a/src/main/java/net/minestom/server/terminal/MinestomTerminal.java b/src/main/java/net/minestom/server/terminal/MinestomTerminal.java index cd5c1efe1..49078fda2 100644 --- a/src/main/java/net/minestom/server/terminal/MinestomTerminal.java +++ b/src/main/java/net/minestom/server/terminal/MinestomTerminal.java @@ -22,26 +22,31 @@ public class MinestomTerminal { @ApiStatus.Internal public static void start() { - try { - terminal = TerminalBuilder.terminal(); - } catch (IOException e) { - e.printStackTrace(); - } - LineReader reader = LineReaderBuilder.builder() - .terminal(terminal) - .build(); - running = true; - while (running) { - String command; + final Thread thread = new Thread(null, () -> { try { - command = reader.readLine(PROMPT); - COMMAND_MANAGER.execute(COMMAND_MANAGER.getConsoleSender(), command); - } catch (UserInterruptException e) { - // Ignore - } catch (EndOfFileException e) { - return; + terminal = TerminalBuilder.terminal(); + } catch (IOException e) { + e.printStackTrace(); } - } + LineReader reader = LineReaderBuilder.builder() + .terminal(terminal) + .build(); + running = true; + + while (running) { + String command; + try { + command = reader.readLine(PROMPT); + COMMAND_MANAGER.execute(COMMAND_MANAGER.getConsoleSender(), command); + } catch (UserInterruptException e) { + // Ignore + } catch (EndOfFileException e) { + return; + } + } + }, "Jline"); + thread.setDaemon(true); + thread.start(); } @ApiStatus.Internal