receive-pack: redirect unpack-objects stdout to /dev/null

The unpack-objects command should not generally produce any
output on stdout. However, if it's given extra input after
the packfile, it will spew the remainder to stdout. When
called by receive-pack, this means we will break protocol,
since our stdout is connected to the remote send-pack.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Jeff King 2012-09-21 01:32:52 -04:00 committed by Junio C Hamano
parent 8ef2794ba8
commit 59bfdfb82a

View File

@ -821,6 +821,7 @@ static const char *unpack(void)
if (ntohl(hdr.hdr_entries) < unpack_limit) { if (ntohl(hdr.hdr_entries) < unpack_limit) {
int code, i = 0; int code, i = 0;
struct child_process child;
const char *unpacker[5]; const char *unpacker[5];
unpacker[i++] = "unpack-objects"; unpacker[i++] = "unpack-objects";
if (quiet) if (quiet)
@ -829,7 +830,11 @@ static const char *unpack(void)
unpacker[i++] = "--strict"; unpacker[i++] = "--strict";
unpacker[i++] = hdr_arg; unpacker[i++] = hdr_arg;
unpacker[i++] = NULL; unpacker[i++] = NULL;
code = run_command_v_opt(unpacker, RUN_GIT_CMD); memset(&child, 0, sizeof(child));
child.argv = unpacker;
child.no_stdout = 1;
child.git_cmd = 1;
code = run_command(&child);
if (!code) if (!code)
return NULL; return NULL;
return "unpack-objects abnormal exit"; return "unpack-objects abnormal exit";