From: René Scharfe Date: Sat, 26 Sep 2020 08:37:29 +0000 (+0200) Subject: ref-filter: plug memory leak in reach_filter() X-Git-Tag: v2.29.0-rc0~24^2 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=5336d5069626a9e06e224cbc1730ee96c5742108;p=thirdparty%2Fgit.git ref-filter: plug memory leak in reach_filter() 21bf933928 (ref-filter: allow merged and no-merged filters, 2020-09-15) added an early return to reach_filter(). Avoid leaking the memory of a then unused array by postponing its allocation until we know we need it. Signed-off-by: René Scharfe Signed-off-by: Junio C Hamano --- diff --git a/ref-filter.c b/ref-filter.c index 5550a0d34c..e0b8cd3ed8 100644 --- a/ref-filter.c +++ b/ref-filter.c @@ -2239,12 +2239,14 @@ static void reach_filter(struct ref_array *array, { struct rev_info revs; int i, old_nr; - struct commit **to_clear = xcalloc(sizeof(struct commit *), array->nr); + struct commit **to_clear; struct commit_list *cr; if (!check_reachable) return; + to_clear = xcalloc(sizeof(struct commit *), array->nr); + repo_init_revisions(the_repository, &revs, NULL); for (i = 0; i < array->nr; i++) {