Skip to content

Commit

Permalink
upload-pack: move rev-list code out of check_non_tip()
Browse files Browse the repository at this point in the history
Signed-off-by: Nguyễn Thái Ngọc Duy <pclouds@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
  • Loading branch information
pclouds authored and gitster committed Jun 13, 2016
1 parent 7fcbd37 commit 3f0f662
Showing 1 changed file with 23 additions and 13 deletions.
36 changes: 23 additions & 13 deletions upload-pack.c
Original file line number Diff line number Diff line change
Expand Up @@ -451,7 +451,7 @@ static int is_our_ref(struct object *o)
return o->flags & ((allow_hidden_ref ? HIDDEN_REF : 0) | OUR_REF);
}

static void check_non_tip(void)
static int has_unreachable(struct object_array *src)
{
static const char *argv[] = {
"rev-list", "--stdin", NULL,
Expand All @@ -461,14 +461,6 @@ static void check_non_tip(void)
char namebuf[42]; /* ^ + SHA-1 + LF */
int i;

/*
* In the normal in-process case without
* uploadpack.allowReachableSHA1InWant,
* non-tip requests can never happen.
*/
if (!stateless_rpc && !(allow_unadvertised_object_request & ALLOW_REACHABLE_SHA1))
goto error;

cmd.argv = argv;
cmd.git_cmd = 1;
cmd.no_stderr = 1;
Expand Down Expand Up @@ -498,8 +490,8 @@ static void check_non_tip(void)
goto error;
}
namebuf[40] = '\n';
for (i = 0; i < want_obj.nr; i++) {
o = want_obj.objects[i].item;
for (i = 0; i < src->nr; i++) {
o = src->objects[i].item;
if (is_our_ref(o))
continue;
memcpy(namebuf, oid_to_hex(&o->oid), GIT_SHA1_HEXSZ);
Expand Down Expand Up @@ -530,7 +522,7 @@ static void check_non_tip(void)
sigchain_pop(SIGPIPE);

/* All the non-tip ones are ancestors of what we advertised */
return;
return 0;

error:
sigchain_pop(SIGPIPE);
Expand All @@ -539,10 +531,28 @@ static void check_non_tip(void)
close(cmd.in);
if (cmd.out >= 0)
close(cmd.out);
return 1;
}

static void check_non_tip(void)
{
int i;

/*
* In the normal in-process case without
* uploadpack.allowReachableSHA1InWant,
* non-tip requests can never happen.
*/
if (!stateless_rpc && !(allow_unadvertised_object_request & ALLOW_REACHABLE_SHA1))
goto error;
if (!has_unreachable(&want_obj))
/* All the non-tip ones are ancestors of what we advertised */
return;

error:
/* Pick one of them (we know there at least is one) */
for (i = 0; i < want_obj.nr; i++) {
o = want_obj.objects[i].item;
struct object *o = want_obj.objects[i].item;
if (!is_our_ref(o))
die("git upload-pack: not our ref %s",
oid_to_hex(&o->oid));
Expand Down

0 comments on commit 3f0f662

Please sign in to comment.