From ffd0de4076aa8f7075f6979f8b673705b5c49d5c Mon Sep 17 00:00:00 2001 From: Guillaume Nodet Date: Tue, 1 Aug 2023 10:21:45 +0200 Subject: [PATCH] Add a warning when using the ExecTerminalProvider on recent JDKs --- .../terminal/impl/exec/ExecTerminalProvider.java | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/terminal/src/main/java/org/jline/terminal/impl/exec/ExecTerminalProvider.java b/terminal/src/main/java/org/jline/terminal/impl/exec/ExecTerminalProvider.java index cd3f4e3b1..ed6c9e646 100644 --- a/terminal/src/main/java/org/jline/terminal/impl/exec/ExecTerminalProvider.java +++ b/terminal/src/main/java/org/jline/terminal/impl/exec/ExecTerminalProvider.java @@ -25,10 +25,13 @@ import org.jline.terminal.spi.Pty; import org.jline.terminal.spi.TerminalProvider; import org.jline.utils.ExecHelper; +import org.jline.utils.Log; import org.jline.utils.OSUtils; public class ExecTerminalProvider implements TerminalProvider { + private static boolean warned; + public String name() { return "exec"; } @@ -142,11 +145,21 @@ public String systemStreamName(Stream stream) { return result.trim(); } } catch (Throwable t) { + if ("java.lang.reflect.InaccessibleObjectException" + .equals(t.getClass().getName()) + && !warned) { + Log.warn( + "The ExecTerminalProvider requires the JVM options: '--add-opens java.base/java.lang=ALL-UNNAMED'"); + warned = true; + } // ignore } return null; } + /** + * This requires --add-opens java.base/java.lang=ALL-UNNAMED + */ private ProcessBuilder.Redirect getRedirect(FileDescriptor fd) throws ReflectiveOperationException { // This is not really allowed, but this is the only way to redirect the output or error stream // to the input. This is definitely not something you'd usually want to do, but in the case of