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:
parent
cbe1c8eff5
commit
e1048fb2e9
1 changed files with 28 additions and 2 deletions
30
Src/exec.c
30
Src/exec.c
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue