summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPeter Stephenson <pws@users.sourceforge.net>2006-11-11 13:16:10 +0000
committerPeter Stephenson <pws@users.sourceforge.net>2006-11-11 13:16:10 +0000
commitb09a7cc5bfa0cca9eff94d5fcdd40ea611001f3c (patch)
tree87254ce597a07b88aaaa274d44296f1a1ac55dd7
parent254b3f1a6b85e6cfefe21fea3d81c3f97c003ec2 (diff)
downloadzsh-b09a7cc5bfa0cca9eff94d5fcdd40ea611001f3c.tar.gz
zsh-b09a7cc5bfa0cca9eff94d5fcdd40ea611001f3c.zip
22997: fix ${...?...} exit and traps
-rw-r--r--ChangeLog6
-rw-r--r--Src/builtin.c5
-rw-r--r--Src/subst.c13
3 files changed, 22 insertions, 2 deletions
diff --git a/ChangeLog b/ChangeLog
index d52cbd0f8..bc07302b5 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+2006-11-11 Peter Stephenson <p.w.stephenson@ntlworld.com>
+
+ * 22997: Src/builtin.c, Src/subst.c: ${...?...} didn't go through
+ proper exit sequence and didn't take account of being in a
+ subshell and didn't call exit trap anyway because errflag was set.
+
2006-11-10 Peter Stephenson <pws@csr.com>
* 22993: Completion/Unix/Command/_make: slightly more
diff --git a/Src/builtin.c b/Src/builtin.c
index 85c961e3d..e567675ff 100644
--- a/Src/builtin.c
+++ b/Src/builtin.c
@@ -4413,6 +4413,11 @@ zexit(int val, int from_where)
* indicate we shouldn't do any recursive processing.
*/
in_exit = -1;
+ /*
+ * We want to do all remaining processing regardless of preceeding
+ * errors.
+ */
+ errflag = 0;
if (isset(MONITOR)) {
/* send SIGHUP to any jobs left running */
diff --git a/Src/subst.c b/Src/subst.c
index 06e16c183..5e41beff1 100644
--- a/Src/subst.c
+++ b/Src/subst.c
@@ -2591,8 +2591,17 @@ paramsubst(LinkList l, LinkNode n, char **str, int qt, int ssub)
if (vunset) {
*idend = '\0';
zerr("%s: %s", idbeg, *s ? s : "parameter not set");
- if (!interact)
- exit(1);
+ if (!interact) {
+ if (mypid == getpid()) {
+ /*
+ * paranoia: don't check for jobs, but there shouldn't
+ * be any if not interactive.
+ */
+ stopmsg = 1;
+ zexit(1, 0);
+ } else
+ _exit(1);
+ }
return NULL;
}
break;