From 6dafcc49605889385dfc3011f92eb6d25bbadeda Mon Sep 17 00:00:00 2001 From: Mahmoud Al-Qudsi Date: Wed, 31 Oct 2018 17:46:41 +0000 Subject: [PATCH] Partially revert 55b3c45 to create pgrp when launched with invalid pgrp If fish detects that it was started with a pgrp of 0 (which appears to oddly be the case when run under firejail), create new process group for fish and give it control of the terminal. This selectively reverts 55b3c45 in cases where an invalid pgrp is detected. Note that this is known to cause problems in other cases, such as #3805 and Microsoft/WSL#1653, although the former may have been ameliorated or even addressed by the recent job control overhaul, so that's why we are careful to only assign fish to its own pgroup if an invalid pgroup was detected and not as the normal case. --- src/reader.cpp | 32 ++++++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) diff --git a/src/reader.cpp b/src/reader.cpp index 137bbe94f..624af72d7 100644 --- a/src/reader.cpp +++ b/src/reader.cpp @@ -1789,6 +1789,38 @@ static void reader_interactive_init() { signal_set_handlers(); } + + // It shouldn't be necessary to place fish in its own process group and force control + // of the terminal, but that works around fish being started with an invalid pgroup, + // such as when launched via firejail (#5295) + if (shell_pgid == 0) { + shell_pgid = getpid(); + if (setpgid(shell_pgid, shell_pgid) < 0) { + debug(0, _(L"Failed to assign shell to its own process group")); + wperror(L"setpgid"); + exit_without_destructors(1); + } + + // Take control of the terminal + if (tcsetpgrp(STDIN_FILENO, shell_pgid) == -1) { + if (errno == ENOTTY) { + redirect_tty_output(); + } + debug(0, _(L"Failed to take control of the terminal")); + wperror(L"tcsetpgrp"); + exit_without_destructors(1); + } + + // Configure terminal attributes + if (tcsetattr(0, TCSANOW, &shell_modes) == -1) { + if (errno == EIO) { + redirect_tty_output(); + } + debug(1, _(L"Failed to set startup terminal mode!")); + wperror(L"tcsetattr"); + } + } + invalidate_termsize(); // For compatibility with fish 2.0's $_, now replaced with `status current-command`