1
0
Fork 0
mirror of git://git.code.sf.net/p/zsh/code synced 2025-01-01 17:24:50 +01:00

Ensure we _exit if forked in execcmd_exec().

This commit is contained in:
Peter Stephenson 2018-04-20 11:58:19 +01:00
parent cbe1c8eff5
commit e1048fb2e9

View file

@ -2942,8 +2942,11 @@ execcmd_exec(Estate state, Execcmd_params eparams,
is_builtin = 1; is_builtin = 1;
/* autoload the builtin if necessary */ /* autoload the builtin if necessary */
if (!(hn = resolvebuiltin(cmdarg, hn))) if (!(hn = resolvebuiltin(cmdarg, hn))) {
if (forked)
_exit(lastval);
return; return;
}
if (type != WC_TYPESET) if (type != WC_TYPESET)
magic_assign = (hn->flags & BINF_MAGICEQUALS); magic_assign = (hn->flags & BINF_MAGICEQUALS);
break; break;
@ -3121,6 +3124,8 @@ execcmd_exec(Estate state, Execcmd_params eparams,
zerr("unknown exec flag -%c", *cmdopt); zerr("unknown exec flag -%c", *cmdopt);
lastval = 1; lastval = 1;
errflag |= ERRFLAG_ERROR; errflag |= ERRFLAG_ERROR;
if (forked)
_exit(lastval);
return; return;
} }
} }
@ -3214,6 +3219,8 @@ execcmd_exec(Estate state, Execcmd_params eparams,
zerr("redirection with no command"); zerr("redirection with no command");
lastval = 1; lastval = 1;
errflag |= ERRFLAG_ERROR; errflag |= ERRFLAG_ERROR;
if (forked)
_exit(lastval);
return; return;
} else if (!nullcmd || !*nullcmd || opts[SHNULLCMD]) { } else if (!nullcmd || !*nullcmd || opts[SHNULLCMD]) {
if (!args) if (!args)
@ -3232,6 +3239,8 @@ execcmd_exec(Estate state, Execcmd_params eparams,
} }
} else if ((cflags & BINF_PREFIX) && (cflags & BINF_COMMAND)) { } else if ((cflags & BINF_PREFIX) && (cflags & BINF_COMMAND)) {
lastval = 0; lastval = 0;
if (forked)
_exit(lastval);
return; return;
} else { } else {
/* /*
@ -3242,6 +3251,8 @@ execcmd_exec(Estate state, Execcmd_params eparams,
if (badcshglob == 1) { if (badcshglob == 1) {
zerr("no match"); zerr("no match");
lastval = 1; lastval = 1;
if (forked)
_exit(lastval);
return; return;
} }
cmdoutval = use_cmdoutval ? lastval : 0; cmdoutval = use_cmdoutval ? lastval : 0;
@ -3255,12 +3266,16 @@ execcmd_exec(Estate state, Execcmd_params eparams,
fputc('\n', xtrerr); fputc('\n', xtrerr);
fflush(xtrerr); fflush(xtrerr);
} }
if (forked)
_exit(lastval);
return; return;
} }
} else if (isset(RESTRICTED) && (cflags & BINF_EXEC) && do_exec) { } else if (isset(RESTRICTED) && (cflags & BINF_EXEC) && do_exec) {
zerrnam("exec", "%s: restricted", zerrnam("exec", "%s: restricted",
(char *) getdata(firstnode(args))); (char *) getdata(firstnode(args)));
lastval = 1; lastval = 1;
if (forked)
_exit(lastval);
return; return;
} }
@ -3295,6 +3310,8 @@ execcmd_exec(Estate state, Execcmd_params eparams,
lastval = 1; lastval = 1;
if (oautocont >= 0) if (oautocont >= 0)
opts[AUTOCONTINUE] = oautocont; opts[AUTOCONTINUE] = oautocont;
if (forked)
_exit(lastval);
return; return;
} }
break; break;
@ -3303,8 +3320,11 @@ execcmd_exec(Estate state, Execcmd_params eparams,
is_builtin = 1; is_builtin = 1;
/* autoload the builtin if necessary */ /* autoload the builtin if necessary */
if (!(hn = resolvebuiltin(cmdarg, hn))) if (!(hn = resolvebuiltin(cmdarg, hn))) {
if (forked)
_exit(lastval);
return; return;
}
break; break;
} }
cflags &= ~BINF_BUILTIN & ~BINF_COMMAND; cflags &= ~BINF_BUILTIN & ~BINF_COMMAND;
@ -3319,6 +3339,8 @@ execcmd_exec(Estate state, Execcmd_params eparams,
lastval = 1; lastval = 1;
if (oautocont >= 0) if (oautocont >= 0)
opts[AUTOCONTINUE] = oautocont; opts[AUTOCONTINUE] = oautocont;
if (forked)
_exit(lastval);
return; return;
} }
@ -3396,6 +3418,8 @@ execcmd_exec(Estate state, Execcmd_params eparams,
lastval = 1; lastval = 1;
if (oautocont >= 0) if (oautocont >= 0)
opts[AUTOCONTINUE] = oautocont; opts[AUTOCONTINUE] = oautocont;
if (forked)
_exit(lastval);
return; return;
} }
} }
@ -3424,6 +3448,8 @@ execcmd_exec(Estate state, Execcmd_params eparams,
lastval = 1; lastval = 1;
if (oautocont >= 0) if (oautocont >= 0)
opts[AUTOCONTINUE] = oautocont; opts[AUTOCONTINUE] = oautocont;
if (forked)
_exit(lastval);
return; return;
} }