summaryrefslogtreecommitdiffstats
path: root/git.c
diff options
context:
space:
mode:
authorJeff King <peff@peff.net>2016-07-01 08:06:02 +0200
committerJunio C Hamano <gitster@pobox.com>2016-07-02 00:09:10 +0200
commit57f5d52a942e8bbfa82e2741faf050de0d6b3eb3 (patch)
tree01e59edce0ed0b96a8bcc275f21bc04a1db4bb34 /git.c
parentcommon-main: call git_extract_argv0_path() (diff)
downloadgit-57f5d52a942e8bbfa82e2741faf050de0d6b3eb3.tar.xz
git-57f5d52a942e8bbfa82e2741faf050de0d6b3eb3.zip
common-main: call sanitize_stdfds()
This is setup that should be done in every program for safety, but we never got around to adding it everywhere (so builtins benefited from the call in git.c, but any external commands did not). Putting it in the common main() gives us this safety everywhere. Note that the case in daemon.c is a little funny. We wait until we know whether we want to daemonize, and then either: - call daemonize(), which will close stdio and reopen it to /dev/null under the hood - sanitize_stdfds(), to fix up any odd cases But that is way too late; the point of sanitizing is to give us reliable descriptors on 0/1/2, and we will already have executed code, possibly called die(), etc. The sanitizing should be the very first thing that happens. With this patch, git-daemon will sanitize first, and can remove the call in the non-daemonize case. It does mean that daemonize() may just end up closing the descriptors we opened, but that's not a big deal (it's not wrong to do so, nor is it really less optimal than the case where our parent process redirected us from /dev/null ahead of time). Signed-off-by: Jeff King <peff@peff.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'git.c')
-rw-r--r--git.c7
1 files changed, 0 insertions, 7 deletions
diff --git a/git.c b/git.c
index 3b4e12d7c6..b65083ca97 100644
--- a/git.c
+++ b/git.c
@@ -639,13 +639,6 @@ int cmd_main(int argc, const char **argv)
if (!cmd)
cmd = "git-help";
- /*
- * Always open file descriptors 0/1/2 to avoid clobbering files
- * in die(). It also avoids messing up when the pipes are dup'ed
- * onto stdin/stdout/stderr in the child processes we spawn.
- */
- sanitize_stdfds();
-
restore_sigpipe_to_default();
git_setup_gettext();