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:
parent
8ef2794ba8
commit
59bfdfb82a
@ -821,6 +821,7 @@ static const char *unpack(void)
|
||||
|
||||
if (ntohl(hdr.hdr_entries) < unpack_limit) {
|
||||
int code, i = 0;
|
||||
struct child_process child;
|
||||
const char *unpacker[5];
|
||||
unpacker[i++] = "unpack-objects";
|
||||
if (quiet)
|
||||
@ -829,7 +830,11 @@ static const char *unpack(void)
|
||||
unpacker[i++] = "--strict";
|
||||
unpacker[i++] = hdr_arg;
|
||||
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)
|
||||
return NULL;
|
||||
return "unpack-objects abnormal exit";
|
||||
|
Loading…
Reference in New Issue
Block a user