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) --- Src/exec.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) (limited to 'Src/exec.c') 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 v1.2.3