From 96fd8a11d382319af89bfc8ed250003c4114da84 Mon Sep 17 00:00:00 2001 From: Sven Wischnowsky Date: Mon, 28 May 2001 09:00:21 +0000 Subject: another attempt at fixing the job problem from 14327; make execpline() reset list_pipe_job to zero if it would be set for a job started in the background (14503) --- ChangeLog | 6 ++++++ Src/exec.c | 5 ++++- 2 files changed, 10 insertions(+), 1 deletion(-) diff --git a/ChangeLog b/ChangeLog index e8a7b8a3b..5f63dd166 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,9 @@ +2001-05-28 Sven Wischnowsky + + * 14503: Src/exec.c: another attempt at fixing the job problem + from 14327; make execpline() reset list_pipe_job to zero if it + would be set for a job started in the background + 2001-05-27 Bart Schaefer * unposted: Etc/MACHINES: Mention failure of gcc 2.7.1 on HPUX, diff --git a/Src/exec.c b/Src/exec.c index 859813ef6..aa78a7ce6 100644 --- a/Src/exec.c +++ b/Src/exec.c @@ -976,13 +976,16 @@ execpline(Estate state, wordcode slcode, int how, int last1) list_pipe_pid = 0; nowait = 0; simple_pline = (WC_PIPE_TYPE(code) == WC_PIPE_END); - list_pipe_job = (simple_pline ? 0 : newjob); + list_pipe_job = newjob; } lastwj = lpforked = 0; execpline2(state, code, how, opipe[0], ipipe[1], last1); pline_level--; if (how & Z_ASYNC) { lastwj = newjob; + + if (thisjob == list_pipe_job) + list_pipe_job = 0; jobtab[thisjob].stat |= STAT_NOSTTY; if (slflags & WC_SUBLIST_COPROC) { zclose(ipipe[1]); -- cgit 1.4.1