From 0e8183d2bbe89964ef8bca5f391f182648193466 Mon Sep 17 00:00:00 2001 From: apio Date: Thu, 14 Sep 2023 21:31:45 +0200 Subject: [PATCH] shell: Allow running as interactive even if not running in a TTY --- shell/main.cpp | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/shell/main.cpp b/shell/main.cpp index 70c68a2b..026475af 100644 --- a/shell/main.cpp +++ b/shell/main.cpp @@ -85,6 +85,7 @@ Result luna_main(int argc, char** argv) { StringView path; StringView command; + bool interactive { false }; SharedPtr input_file; @@ -93,6 +94,7 @@ Result luna_main(int argc, char** argv) parser.add_system_program_info("sh"_sv); parser.add_positional_argument(path, "path"_sv, "-"_sv); parser.add_value_argument(command, 'c', "command"_sv, "execute a single command and then exit"_sv); + parser.add_switch_argument(interactive, 'i', "interactive"_sv, "run an interactive shell"_sv); parser.parse(argc, argv); // TODO: This does not properly handle builtins. @@ -105,7 +107,7 @@ Result luna_main(int argc, char** argv) input_file->set_close_on_exec(); } - bool interactive = isatty(input_file->fd()); + if (isatty(input_file->fd())) interactive = true; if (interactive) {