name-rev: avoid leaking memory in the deref case

When the `name_rev()` function is asked to dereference the tip name, it
allocates memory. But when it turns out that another tip already
described the commit better than the current one, we forgot to release
the memory.

Pointed out by Coverity.

Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Johannes Schindelin 2017-05-04 15:59:06 +02:00 committed by Junio C Hamano
parent 3dc7ea91da
commit 5308224633

View File

@ -28,6 +28,7 @@ static void name_rev(struct commit *commit,
struct rev_name *name = (struct rev_name *)commit->util; struct rev_name *name = (struct rev_name *)commit->util;
struct commit_list *parents; struct commit_list *parents;
int parent_number = 1; int parent_number = 1;
char *to_free = NULL;
parse_commit(commit); parse_commit(commit);
@ -35,7 +36,7 @@ static void name_rev(struct commit *commit,
return; return;
if (deref) { if (deref) {
tip_name = xstrfmt("%s^0", tip_name); tip_name = to_free = xstrfmt("%s^0", tip_name);
if (generation) if (generation)
die("generation: %d, but deref?", generation); die("generation: %d, but deref?", generation);
@ -53,8 +54,10 @@ copy_data:
name->taggerdate = taggerdate; name->taggerdate = taggerdate;
name->generation = generation; name->generation = generation;
name->distance = distance; name->distance = distance;
} else } else {
free(to_free);
return; return;
}
for (parents = commit->parents; for (parents = commit->parents;
parents; parents;