mirror of
https://github.com/fish-shell/fish-shell.git
synced 2025-01-19 20:12:45 +08:00
Restore terminal modes after sending SIGCONT
Fixes #2214 Thanks to @bruce-hill for the patch.
This commit is contained in:
parent
068aba1902
commit
9fd9f70346
31
src/proc.cpp
31
src/proc.cpp
|
@ -823,7 +823,7 @@ pid_t terminal_acquire_before_builtin(int job_pgid) {
|
||||||
|
|
||||||
/// Returns control of the terminal to the shell, and saves the terminal attribute state to the job,
|
/// Returns control of the terminal to the shell, and saves the terminal attribute state to the job,
|
||||||
/// so that we can restore the terminal ownership to the job at a later time.
|
/// so that we can restore the terminal ownership to the job at a later time.
|
||||||
static bool terminal_return_from_job(job_t *j) {
|
static bool terminal_return_from_job(job_t *j, int restore_attrs) {
|
||||||
errno = 0;
|
errno = 0;
|
||||||
if (j->pgid == 0) {
|
if (j->pgid == 0) {
|
||||||
debug(2, "terminal_return_from_job() returning early due to no process group");
|
debug(2, "terminal_return_from_job() returning early due to no process group");
|
||||||
|
@ -845,19 +845,17 @@ static bool terminal_return_from_job(job_t *j) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Disabling this per
|
// Need to restore the terminal's attributes or `bind \cF fg` will put the
|
||||||
// https://github.com/adityagodbole/fish-shell/commit/9d229cd18c3e5c25a8bd37e9ddd3b67ddc2d1b72 On
|
// terminal into a broken state (until "enter" is pressed).
|
||||||
// Linux, 'cd . ; ftp' prevents you from typing into the ftp prompt. See
|
// See: https://github.com/fish-shell/fish-shell/issues/2114
|
||||||
// https://github.com/fish-shell/fish-shell/issues/121
|
if (restore_attrs) {
|
||||||
#if 0
|
if (tcsetattr(STDIN_FILENO, TCSADRAIN, &shell_modes) == -1) {
|
||||||
// Restore the shell's terminal modes.
|
if (errno == EIO) redirect_tty_output();
|
||||||
if (tcsetattr(STDIN_FILENO, TCSADRAIN, &shell_modes) == -1) {
|
debug(1, _(L"Could not return shell to foreground"));
|
||||||
if (errno == EIO) redirect_tty_output();
|
wperror(L"tcsetattr");
|
||||||
debug(1, _(L"Could not return shell to foreground"));
|
return false;
|
||||||
wperror(L"tcsetattr");
|
}
|
||||||
return false;
|
}
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -876,7 +874,10 @@ void job_t::continue_job(parser_t &parser, bool reclaim_foreground_pgrp, bool se
|
||||||
bool term_transferred = false;
|
bool term_transferred = false;
|
||||||
cleanup_t take_term_back([&]() {
|
cleanup_t take_term_back([&]() {
|
||||||
if (term_transferred && reclaim_foreground_pgrp) {
|
if (term_transferred && reclaim_foreground_pgrp) {
|
||||||
terminal_return_from_job(this);
|
// Only restore terminal attrs if we're continuing a job. See:
|
||||||
|
// https://github.com/fish-shell/fish-shell/issues/121
|
||||||
|
// https://github.com/fish-shell/fish-shell/issues/2114
|
||||||
|
terminal_return_from_job(this, send_sigcont);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user