about summary refs log tree commit diff
path: root/Src/Zle/zle_main.c
diff options
context:
space:
mode:
authorBart Schaefer <schaefer@zsh.org>2016-11-23 18:15:17 -0800
committerBart Schaefer <schaefer@zsh.org>2016-11-23 18:15:17 -0800
commitc0f95d07e7be34a30047a8202aeb01b864600151 (patch)
tree57d960358318aed5658a5306c095b7c4ee0f5dce /Src/Zle/zle_main.c
parent07509be51ae06b699dba6a3a85d76d79812a0d75 (diff)
downloadzsh-c0f95d07e7be34a30047a8202aeb01b864600151.tar.gz
zsh-c0f95d07e7be34a30047a8202aeb01b864600151.tar.xz
zsh-c0f95d07e7be34a30047a8202aeb01b864600151.zip
unposted: clear ERRFLAG_ERROR before invoking immortal widget (cf. 39934)
Updates commit cbb9ca3d
Diffstat (limited to 'Src/Zle/zle_main.c')
-rw-r--r--Src/Zle/zle_main.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/Src/Zle/zle_main.c b/Src/Zle/zle_main.c
index 938dc0e29..15ea79643 100644
--- a/Src/Zle/zle_main.c
+++ b/Src/Zle/zle_main.c
@@ -1498,8 +1498,12 @@ execzlefunc(Thingy func, char **args, int set_bindk)
 	    opts[XTRACE] = oxt;
 	    sfcontext = osc;
 	    endparamscope();
-	    if (errflag == ERRFLAG_ERROR && !(ret = execimmortal(func, args)))
+	    if (errflag == ERRFLAG_ERROR) {
+		int saverr = errflag;
 		errflag &= ~ERRFLAG_ERROR;
+		if ((ret = execimmortal(func, args)) != 0)
+		    errflag |= saverr;
+	    }
 	    lastcmd = w->flags & ~(WIDGET_INUSE|WIDGET_FREE);
 	    if (inuse) {
 		w->flags &= WIDGET_INUSE|WIDGET_FREE;