Skip to content

Commit

Permalink
parse_fetch: convert to use struct object_id
Browse files Browse the repository at this point in the history
Convert the parse_fetch function to use struct object_id.  Remove the
strlen check as get_oid_hex will fail safely on receiving a too-short
NUL-terminated string.

Signed-off-by: brian m. carlson <sandals@crustytoothpaste.net>
Signed-off-by: Jeff King <peff@peff.net>
  • Loading branch information
brian m. carlson authored and Jeff King committed Nov 20, 2015
1 parent 854ecb9 commit 8338c91
Showing 1 changed file with 6 additions and 6 deletions.
12 changes: 6 additions & 6 deletions remote-curl.c
Original file line number Diff line number Diff line change
Expand Up @@ -803,19 +803,19 @@ static void parse_fetch(struct strbuf *buf)
if (skip_prefix(buf->buf, "fetch ", &p)) {
const char *name;
struct ref *ref;
unsigned char old_sha1[20];
struct object_id old_oid;

if (strlen(p) < 40 || get_sha1_hex(p, old_sha1))
if (get_oid_hex(p, &old_oid))
die("protocol error: expected sha/ref, got %s'", p);
if (p[40] == ' ')
name = p + 41;
else if (!p[40])
if (p[GIT_SHA1_HEXSZ] == ' ')
name = p + GIT_SHA1_HEXSZ + 1;
else if (!p[GIT_SHA1_HEXSZ])
name = "";
else
die("protocol error: expected sha/ref, got %s'", p);

ref = alloc_ref(name);
hashcpy(ref->old_oid.hash, old_sha1);
oidcpy(&ref->old_oid, &old_oid);

*list = ref;
list = &ref->next;
Expand Down

0 comments on commit 8338c91

Please sign in to comment.