Browse Source

check_everything_connected: convert to argv_array

This avoids the magic "9" array-size which we must avoid
overflowing, making further patches simpler.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
maint
Jeff King 9 years ago committed by Junio C Hamano
parent
commit
3be89f9b86
  1. 21
      connected.c

21
connected.c

@ -26,10 +26,9 @@ static int check_everything_connected_real(sha1_iterate_fn fn,
const char *shallow_file) const char *shallow_file)
{ {
struct child_process rev_list = CHILD_PROCESS_INIT; struct child_process rev_list = CHILD_PROCESS_INIT;
const char *argv[9];
char commit[41]; char commit[41];
unsigned char sha1[20]; unsigned char sha1[20];
int err = 0, ac = 0; int err = 0;
struct packed_git *new_pack = NULL; struct packed_git *new_pack = NULL;
size_t base_len; size_t base_len;


@ -48,18 +47,16 @@ static int check_everything_connected_real(sha1_iterate_fn fn,
} }


if (shallow_file) { if (shallow_file) {
argv[ac++] = "--shallow-file"; argv_array_push(&rev_list.args, "--shallow-file");
argv[ac++] = shallow_file; argv_array_push(&rev_list.args, shallow_file);
} }
argv[ac++] = "rev-list"; argv_array_push(&rev_list.args,"rev-list");
argv[ac++] = "--objects"; argv_array_push(&rev_list.args, "--objects");
argv[ac++] = "--stdin"; argv_array_push(&rev_list.args, "--stdin");
argv[ac++] = "--not"; argv_array_push(&rev_list.args, "--not");
argv[ac++] = "--all"; argv_array_push(&rev_list.args, "--all");
argv[ac++] = "--quiet"; argv_array_push(&rev_list.args, "--quiet");
argv[ac] = NULL;


rev_list.argv = argv;
rev_list.git_cmd = 1; rev_list.git_cmd = 1;
rev_list.in = -1; rev_list.in = -1;
rev_list.no_stdout = 1; rev_list.no_stdout = 1;

Loading…
Cancel
Save