summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog6
-rw-r--r--Src/exec.c6
2 files changed, 10 insertions, 2 deletions
diff --git a/ChangeLog b/ChangeLog
index 094a35b08..78803b6ae 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+2015-04-24 Peter Stephenson <p.stephenson@samsung.com>
+
+ * 34955: Src/exec.c: list_pipe_job needs saving and restoring
+ with some other similar variables in execlist() in order
+ to stop source() messing up job control.
+
2015-04-24 Mikael Magnusson <mikachu@gmail.com>
* Oliver: 34940: Completion/Zsh/Command/_fc: fix typo breaking
diff --git a/Src/exec.c b/Src/exec.c
index 2a8185cbc..60b79c6ea 100644
--- a/Src/exec.c
+++ b/Src/exec.c
@@ -1146,7 +1146,7 @@ execlist(Estate state, int dont_change_job, int exiting)
Wordcode next;
wordcode code;
int ret, cj, csp, ltype;
- int old_pline_level, old_list_pipe;
+ int old_pline_level, old_list_pipe, old_list_pipe_job;
zlong oldlineno;
/*
* ERREXIT only forces the shell to exit if the last command in a &&
@@ -1159,10 +1159,11 @@ execlist(Estate state, int dont_change_job, int exiting)
cj = thisjob;
old_pline_level = pline_level;
old_list_pipe = list_pipe;
+ old_list_pipe_job = list_pipe_job;
oldlineno = lineno;
if (sourcelevel && unset(SHINSTDIN))
- pline_level = list_pipe = 0;
+ pline_level = list_pipe = list_pipe_job = 0;
/* Loop over all sets of comands separated by newline, *
* semi-colon or ampersand (`sublists'). */
@@ -1397,6 +1398,7 @@ sublist_done:
}
pline_level = old_pline_level;
list_pipe = old_list_pipe;
+ list_pipe_job = old_list_pipe_job;
lineno = oldlineno;
if (dont_change_job)
thisjob = cj;