zig

fork of https://codeberg.org/ziglang/zig
Log | Files | Refs | README | LICENSE

commit 4b902b44a244e29106637f9777aa71b1cd4c22d2 (tree)
parent c64f6f950343aef3c6d8fbffcff3ff4fc76960f4
Author: Andrew Kelley <superjoe30@gmail.com>
Date:   Thu, 22 Sep 2016 10:48:42 -0400

os: fix file descriptor leak in os_exec

See #182

Diffstat:
Msrc/os.cpp | 10++++++++--
1 file changed, 8 insertions(+), 2 deletions(-)

diff --git a/src/os.cpp b/src/os.cpp @@ -263,6 +263,7 @@ static int os_exec_process_posix(const char *exe, ZigList<const char *> &args, } else { // parent close(stdin_pipe[0]); + close(stdin_pipe[1]); close(stdout_pipe[1]); close(stderr_pipe[1]); @@ -270,8 +271,13 @@ static int os_exec_process_posix(const char *exe, ZigList<const char *> &args, waitpid(pid, &status, 0); populate_termination(term, status); - os_fetch_file(fdopen(stdout_pipe[0], "rb"), out_stdout); - os_fetch_file(fdopen(stderr_pipe[0], "rb"), out_stderr); + FILE *stdout_f = fdopen(stdout_pipe[0], "rb"); + FILE *stderr_f = fdopen(stderr_pipe[0], "rb"); + os_fetch_file(stdout_f, out_stdout); + os_fetch_file(stderr_f, out_stderr); + + fclose(stdout_f); + fclose(stderr_f); return 0; }