mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-28 04:35:09 +00:00
Remove the send_sigcont from continue_job
We can just send sigcont if the job is stopped; no need to make this an explicit param.
This commit is contained in:
parent
84b25855b0
commit
1823f5d95f
5 changed files with 11 additions and 10 deletions
|
@ -32,7 +32,7 @@ static int send_to_bg(parser_t &parser, io_streams_t &streams, job_t *j) {
|
||||||
j->command_wcstr());
|
j->command_wcstr());
|
||||||
parser.job_promote(j);
|
parser.job_promote(j);
|
||||||
j->group->set_is_foreground(false);
|
j->group->set_is_foreground(false);
|
||||||
j->continue_job(parser, true, j->is_stopped());
|
j->continue_job(parser, true);
|
||||||
return STATUS_CMD_OK;
|
return STATUS_CMD_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -107,6 +107,6 @@ int builtin_fg(parser_t &parser, io_streams_t &streams, wchar_t **argv) {
|
||||||
parser.job_promote(job);
|
parser.job_promote(job);
|
||||||
job->group->set_is_foreground(true);
|
job->group->set_is_foreground(true);
|
||||||
|
|
||||||
job->continue_job(parser, true, job->is_stopped());
|
job->continue_job(parser, true);
|
||||||
return STATUS_CMD_OK;
|
return STATUS_CMD_OK;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1003,7 +1003,7 @@ bool exec_job(parser_t &parser, const shared_ptr<job_t> &j, const io_chain_t &bl
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
j->continue_job(parser, reclaim_foreground_pgrp, false);
|
j->continue_job(parser, reclaim_foreground_pgrp);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -896,7 +896,7 @@ maybe_t<pid_t> job_t::get_pgid() const { return group->get_pgid(); }
|
||||||
|
|
||||||
job_id_t job_t::job_id() const { return group->get_id(); }
|
job_id_t job_t::job_id() const { return group->get_id(); }
|
||||||
|
|
||||||
void job_t::continue_job(parser_t &parser, bool reclaim_foreground_pgrp, bool send_sigcont) {
|
void job_t::continue_job(parser_t &parser, bool reclaim_foreground_pgrp) {
|
||||||
// Put job first in the job list.
|
// Put job first in the job list.
|
||||||
parser.job_promote(this);
|
parser.job_promote(this);
|
||||||
mut_flags().notified = false;
|
mut_flags().notified = false;
|
||||||
|
@ -904,6 +904,9 @@ void job_t::continue_job(parser_t &parser, bool reclaim_foreground_pgrp, bool se
|
||||||
int pgid = -2;
|
int pgid = -2;
|
||||||
if (auto tmp = get_pgid()) pgid = *tmp;
|
if (auto tmp = get_pgid()) pgid = *tmp;
|
||||||
|
|
||||||
|
// We must send_sigcont if the job is stopped.
|
||||||
|
bool send_sigcont = this->is_stopped();
|
||||||
|
|
||||||
FLOGF(proc_job_run, L"%ls job %d, gid %d (%ls), %ls, %ls",
|
FLOGF(proc_job_run, L"%ls job %d, gid %d (%ls), %ls, %ls",
|
||||||
send_sigcont ? L"Continue" : L"Start", job_id(), pgid, command_wcstr(),
|
send_sigcont ? L"Continue" : L"Start", job_id(), pgid, command_wcstr(),
|
||||||
is_completed() ? L"COMPLETED" : L"UNCOMPLETED",
|
is_completed() ? L"COMPLETED" : L"UNCOMPLETED",
|
||||||
|
|
10
src/proc.h
10
src/proc.h
|
@ -454,14 +454,12 @@ class job_t {
|
||||||
/// \return whether this job and its parent chain are fully constructed.
|
/// \return whether this job and its parent chain are fully constructed.
|
||||||
bool job_chain_is_fully_constructed() const;
|
bool job_chain_is_fully_constructed() const;
|
||||||
|
|
||||||
/// Resume a (possibly) stopped job. Puts job in the foreground. If cont is true, restore the
|
/// Continues running a job, which may be stopped, or may just have started.
|
||||||
/// saved terminal modes and send the process group a SIGCONT signal to wake it up before we
|
/// This will send SIGCONT if the job is stopped.
|
||||||
/// block.
|
|
||||||
///
|
///
|
||||||
/// \param reclaim_foreground_pgrp whether, when the job finishes or stops, to reclaim the
|
/// \param reclaim_foreground_pgrp whether, when the job finishes or stops, to reclaim the
|
||||||
/// foreground pgrp (via tcsetpgrp). \param send_sigcont Whether SIGCONT should be sent to the
|
/// foreground pgrp (via tcsetpgrp).
|
||||||
/// job if it is in the foreground.
|
void continue_job(parser_t &parser, bool reclaim_foreground_pgrp);
|
||||||
void continue_job(parser_t &parser, bool reclaim_foreground_pgrp, bool send_sigcont);
|
|
||||||
|
|
||||||
/// Send the specified signal to all processes in this job.
|
/// Send the specified signal to all processes in this job.
|
||||||
/// \return true on success, false on failure.
|
/// \return true on success, false on failure.
|
||||||
|
|
Loading…
Reference in a new issue