Skip to content

Commit

Permalink
remote-testsvn: fix unitialized variable
Browse files Browse the repository at this point in the history
In remote-test-svn, there is a parse_rev_note function to
parse lines of the form "Revision-number" from notes. If it
finds such a line and parses it, it returns 0, copying the
value into a "struct rev_note". If it finds an entry that is
garbled or out of range, it returns -1 to signal an error.

However, if it does not find any "Revision-number" line at
all, it returns success but does not put anything into the
rev_note. So upon a successful return, the rev_note may or
may not be initialized, and the caller has no way of
knowing.

gcc does not usually catch the use of the unitialized
variable because the conditional assignment happens in a
separate function from the point of use. However, when
compiling with -O3, gcc will inline parse_rev_note and
notice the problem.

We can fix it by returning "-1" when no note is found (so on
a zero return, we always found a valid value).

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
  • Loading branch information
peff authored and gitster committed Dec 15, 2012
1 parent 790c83c commit bfae342
Showing 1 changed file with 3 additions and 1 deletion.
4 changes: 3 additions & 1 deletion remote-testsvn.c
Expand Up @@ -90,10 +90,12 @@ static int parse_rev_note(const char *msg, struct rev_note *res)
if (end == value || i < 0 || i > UINT32_MAX)
return -1;
res->rev_nr = i;
return 0;
}
msg += len + 1;
}
return 0;
/* didn't find it */
return -1;
}

static int note2mark_cb(const unsigned char *object_sha1,
Expand Down

0 comments on commit bfae342

Please sign in to comment.