diff options
author | Bart Schaefer <schaefer@zsh.org> | 2022-12-09 19:30:35 -0800 |
---|---|---|
committer | Bart Schaefer <schaefer@zsh.org> | 2022-12-09 19:30:35 -0800 |
commit | 2028539cb168d652dfa77e5b85b382c319b3a99a (patch) | |
tree | f353994ad07a9f7c48a705a49cc8606574f7dbe2 | |
parent | 72540a758ac755fc89137dd9b92c8d0d6a5d95e1 (diff) | |
download | zsh-2028539cb168d652dfa77e5b85b382c319b3a99a.tar.gz zsh-2028539cb168d652dfa77e5b85b382c319b3a99a.zip |
51161: correct errno after closing xtrace FD
-rw-r--r-- | ChangeLog | 2 | ||||
-rw-r--r-- | Src/exec.c | 3 |
2 files changed, 5 insertions, 0 deletions
@@ -1,5 +1,7 @@ 2022-12-09 Bart Schaefer <schaefer@zsh.org> + * 51161: Src/exec.c: correct errno after closing xtrace FD + * Shohei YOSHIDA: 51111: Completion/Unix/Command/_global: update completion for global to version 6.6.8 diff --git a/Src/exec.c b/Src/exec.c index 1810fca5e..a1059af5e 100644 --- a/Src/exec.c +++ b/Src/exec.c @@ -4336,10 +4336,13 @@ execcmd_exec(Estate state, Execcmd_params eparams, } } if (newxtrerr) { + int eno = errno; fil = fileno(newxtrerr); fclose(newxtrerr); xtrerr = oxtrerr; + /* Call zclose() to clean up internal tables, ignore EBADF */ zclose(fil); + errno = eno; } zsfree(STTYval); |