summaryrefslogtreecommitdiffstats
path: root/bisect.c
diff options
context:
space:
mode:
authorMartin Ågren <martin.agren@gmail.com>2017-11-05 21:24:29 +0100
committerJunio C Hamano <gitster@pobox.com>2017-11-06 02:15:29 +0100
commitfc5c40bb2bb1921f3bdfa55c1d846dc080c356b2 (patch)
tree77201679493967c9e2263956aa192cf81a7b0d5e /bisect.c
parentbisect: change calling-convention of `find_bisection()` (diff)
downloadgit-fc5c40bb2bb1921f3bdfa55c1d846dc080c356b2.tar.xz
git-fc5c40bb2bb1921f3bdfa55c1d846dc080c356b2.zip
bisect: fix memory leak in `find_bisection()`
`find_bisection()` rebuilds the commit list it is given by reversing it and skipping uninteresting commits. The uninteresting list entries are leaked. Free them to fix the leak. Signed-off-by: Martin Ågren <martin.agren@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to '')
-rw-r--r--bisect.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/bisect.c b/bisect.c
index 5a3ae49714..2f4321767a 100644
--- a/bisect.c
+++ b/bisect.c
@@ -379,8 +379,10 @@ void find_bisection(struct commit_list **commit_list, int *reaches,
unsigned flags = p->item->object.flags;
next = p->next;
- if (flags & UNINTERESTING)
+ if (flags & UNINTERESTING) {
+ free(p);
continue;
+ }
p->next = last;
last = p;
if (!(flags & TREESAME))