send-pack: prefer prefixcmp over memcmp in receive_status

This code predates prefixcmp, so it used memcmp along with
static sizes. Replacing these memcmps with prefixcmp makes
the code much more readable, and the lack of static sizes
will make refactoring it in future patches simpler.

Note that we used to be unnecessarily liberal in parsing the
"unpack" status line, and would accept "unpack ok\njunk". No
version of git has ever produced that, and it violates the
BNF in Documentation/technical/pack-protocol.txt. Let's take
this opportunity to tighten the check by converting the
prefix comparison into a strcmp.

While we're in the area, let's also fix a vague error
message that does not follow our usual conventions (it
writes directly to stderr and does not use the "error:"
prefix).

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Jeff King 2013-02-20 15:00:43 -05:00 committed by Junio C Hamano
parent 030e9dd64f
commit 8f9e3e498c

View File

@ -109,9 +109,9 @@ static int receive_status(int in, struct ref *refs)
char line[1000]; char line[1000];
int ret = 0; int ret = 0;
int len = packet_read_line(in, line, sizeof(line)); int len = packet_read_line(in, line, sizeof(line));
if (len < 10 || memcmp(line, "unpack ", 7)) if (prefixcmp(line, "unpack "))
return error("did not receive remote status"); return error("did not receive remote status");
if (memcmp(line, "unpack ok\n", 10)) { if (strcmp(line, "unpack ok\n")) {
char *p = line + strlen(line) - 1; char *p = line + strlen(line) - 1;
if (*p == '\n') if (*p == '\n')
*p = '\0'; *p = '\0';
@ -125,9 +125,8 @@ static int receive_status(int in, struct ref *refs)
len = packet_read_line(in, line, sizeof(line)); len = packet_read_line(in, line, sizeof(line));
if (!len) if (!len)
break; break;
if (len < 3 || if (prefixcmp(line, "ok ") && prefixcmp(line, "ng ")) {
(memcmp(line, "ok ", 3) && memcmp(line, "ng ", 3))) { error("invalid ref status from remote: %s", line);
fprintf(stderr, "protocol error: %s\n", line);
ret = -1; ret = -1;
break; break;
} }