Browse Source

upload-pack: use object pointer not copy of sha1 to keep track of has/needs.

This does not change what happens in the command in any way, but
is to prepare for further work.

Signed-off-by: Junio C Hamano <junkio@cox.net>
maint
Junio C Hamano 19 years ago
parent
commit
6ece0d3030
  1. 20
      upload-pack.c

20
upload-pack.c

@ -18,8 +18,8 @@ static const char upload_pack_usage[] = "git-upload-pack [--strict] [--timeout=n
#define MAX_NEEDS 256 #define MAX_NEEDS 256
static int nr_has = 0, nr_needs = 0, multi_ack = 0, nr_our_refs = 0; static int nr_has = 0, nr_needs = 0, multi_ack = 0, nr_our_refs = 0;
static int use_thin_pack = 0; static int use_thin_pack = 0;
static unsigned char has_sha1[MAX_HAS][20]; static struct object *has_tip[MAX_HAS];
static unsigned char needs_sha1[MAX_NEEDS][20]; static struct object *needs_tip[MAX_NEEDS];
static unsigned int timeout = 0; static unsigned int timeout = 0;
static int use_sideband = 0; static int use_sideband = 0;


@ -119,7 +119,7 @@ static void create_pack_file(void)
else { else {
for (i = 0; i < nr_needs; i++) { for (i = 0; i < nr_needs; i++) {
*p++ = buf; *p++ = buf;
memcpy(buf, sha1_to_hex(needs_sha1[i]), 41); memcpy(buf, sha1_to_hex(needs_tip[i]->sha1), 41);
buf += 41; buf += 41;
} }
} }
@ -127,7 +127,7 @@ static void create_pack_file(void)
for (i = 0; i < nr_has; i++) { for (i = 0; i < nr_has; i++) {
*p++ = buf; *p++ = buf;
*buf++ = '^'; *buf++ = '^';
memcpy(buf, sha1_to_hex(has_sha1[i]), 41); memcpy(buf, sha1_to_hex(has_tip[i]->sha1), 41);
buf += 41; buf += 41;
} }
*p++ = NULL; *p++ = NULL;
@ -336,7 +336,7 @@ static int got_sha1(char *hex, unsigned char *sha1)
parents = parents->next) parents = parents->next)
parents->item->object.flags |= THEY_HAVE; parents->item->object.flags |= THEY_HAVE;
} }
memcpy(has_sha1[nr_has++], sha1, 20); has_tip[nr_has++] = o;
} }
return 1; return 1;
} }
@ -395,23 +395,21 @@ static int receive_needs(void)
needs = 0; needs = 0;
for (;;) { for (;;) {
struct object *o; struct object *o;
unsigned char dummy[20], *sha1_buf; unsigned char sha1_buf[20];
len = packet_read_line(0, line, sizeof(line)); len = packet_read_line(0, line, sizeof(line));
reset_timeout(); reset_timeout();
if (!len) if (!len)
return needs; return needs;


sha1_buf = dummy;
if (needs == MAX_NEEDS) { if (needs == MAX_NEEDS) {
fprintf(stderr, fprintf(stderr,
"warning: supporting only a max of %d requests. " "warning: supporting only a max of %d requests. "
"sending everything instead.\n", "sending everything instead.\n",
MAX_NEEDS); MAX_NEEDS);
} }
else if (needs < MAX_NEEDS)
sha1_buf = needs_sha1[needs];


if (strncmp("want ", line, 5) || get_sha1_hex(line+5, sha1_buf)) if (strncmp("want ", line, 5) ||
get_sha1_hex(line+5, sha1_buf))
die("git-upload-pack: protocol error, " die("git-upload-pack: protocol error, "
"expected to get sha, not '%s'", line); "expected to get sha, not '%s'", line);
if (strstr(line+45, "multi_ack")) if (strstr(line+45, "multi_ack"))
@ -434,6 +432,8 @@ static int receive_needs(void)
die("git-upload-pack: not our ref %s", line+5); die("git-upload-pack: not our ref %s", line+5);
if (!(o->flags & WANTED)) { if (!(o->flags & WANTED)) {
o->flags |= WANTED; o->flags |= WANTED;
if (needs < MAX_NEEDS)
needs_tip[needs] = o;
needs++; needs++;
} }
} }

Loading…
Cancel
Save