Skip to content

Commit

Permalink
Merge branch 'ma/bisect-leakfix'
Browse files Browse the repository at this point in the history
Leak fixes.

* ma/bisect-leakfix:
  bisect: fix memory leak when returning best element
  bisect: fix off-by-one error in `best_bisection_sorted()`
  bisect: fix memory leak in `find_bisection()`
  bisect: change calling-convention of `find_bisection()`
  • Loading branch information
gitster committed Nov 15, 2017
2 parents 6fa1f6f + f4e45cb commit f116163
Show file tree
Hide file tree
Showing 3 changed files with 29 additions and 19 deletions.
33 changes: 19 additions & 14 deletions bisect.c
Original file line number Diff line number Diff line change
Expand Up @@ -226,10 +226,11 @@ static struct commit_list *best_bisection_sorted(struct commit_list *list, int n
add_name_decoration(DECORATION_NONE, buf.buf, obj);

p->item = array[i].commit;
p = p->next;
if (i < cnt - 1)
p = p->next;
}
if (p)
p->next = NULL;
free_commit_list(p->next);
p->next = NULL;
strbuf_release(&buf);
free(array);
return list;
Expand Down Expand Up @@ -360,28 +361,29 @@ static struct commit_list *do_find_bisection(struct commit_list *list,
return best_bisection_sorted(list, nr);
}

struct commit_list *find_bisection(struct commit_list *list,
int *reaches, int *all,
int find_all)
void find_bisection(struct commit_list **commit_list, int *reaches,
int *all, int find_all)
{
int nr, on_list;
struct commit_list *p, *best, *next, *last;
struct commit_list *list, *p, *best, *next, *last;
int *weights;

show_list("bisection 2 entry", 0, 0, list);
show_list("bisection 2 entry", 0, 0, *commit_list);

/*
* Count the number of total and tree-changing items on the
* list, while reversing the list.
*/
for (nr = on_list = 0, last = NULL, p = list;
for (nr = on_list = 0, last = NULL, p = *commit_list;
p;
p = next) {
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))
Expand All @@ -397,12 +399,16 @@ struct commit_list *find_bisection(struct commit_list *list,
/* Do the real work of finding bisection commit. */
best = do_find_bisection(list, nr, weights, find_all);
if (best) {
if (!find_all)
if (!find_all) {
list->item = best->item;
free_commit_list(list->next);
best = list;
best->next = NULL;
}
*reaches = weight(best);
}
free(weights);
return best;
*commit_list = best;
}

static int register_ref(const char *refname, const struct object_id *oid,
Expand Down Expand Up @@ -960,8 +966,7 @@ int bisect_next_all(const char *prefix, int no_checkout)

bisect_common(&revs);

revs.commits = find_bisection(revs.commits, &reaches, &all,
!!skipped_revs.nr);
find_bisection(&revs.commits, &reaches, &all, !!skipped_revs.nr);
revs.commits = managed_skipped(revs.commits, &tried);

if (!revs.commits) {
Expand Down
12 changes: 9 additions & 3 deletions bisect.h
Original file line number Diff line number Diff line change
@@ -1,9 +1,15 @@
#ifndef BISECT_H
#define BISECT_H

extern struct commit_list *find_bisection(struct commit_list *list,
int *reaches, int *all,
int find_all);
/*
* Find bisection. If something is found, `reaches` will be the number of
* commits that the best commit reaches. `all` will be the count of
* non-SAMETREE commits. If nothing is found, `list` will be NULL.
* Otherwise, it will be either all non-SAMETREE commits or the single
* best commit, as chosen by `find_all`.
*/
extern void find_bisection(struct commit_list **list, int *reaches, int *all,
int find_all);

extern struct commit_list *filter_skipped(struct commit_list *list,
struct commit_list **tried,
Expand Down
3 changes: 1 addition & 2 deletions builtin/rev-list.c
Original file line number Diff line number Diff line change
Expand Up @@ -397,8 +397,7 @@ int cmd_rev_list(int argc, const char **argv, const char *prefix)
if (bisect_list) {
int reaches = reaches, all = all;

revs.commits = find_bisection(revs.commits, &reaches, &all,
bisect_find_all);
find_bisection(&revs.commits, &reaches, &all, bisect_find_all);

if (bisect_show_vars)
return show_bisect_vars(&info, reaches, all);
Expand Down

0 comments on commit f116163

Please sign in to comment.