Commit f41e86d6 by Patrick Steinhardt

transports: smart: fix memory leak when skipping symbolic refs

When we setup the revision walk for negotiating references with a
remote, we iterate over all references, ignoring tags and symbolic
references. While skipping over symbolic references, we forget to free
the looked up reference, resulting in a memory leak when the next
iteration simply overwrites the variable.

Fix that issue by freeing the reference at the beginning of each
iteration and collapsing return paths for error and success.
parent cda18f9b
...@@ -270,7 +270,7 @@ static int fetch_setup_walk(git_revwalk **out, git_repository *repo) ...@@ -270,7 +270,7 @@ static int fetch_setup_walk(git_revwalk **out, git_repository *repo)
git_revwalk *walk = NULL; git_revwalk *walk = NULL;
git_strarray refs; git_strarray refs;
unsigned int i; unsigned int i;
git_reference *ref; git_reference *ref = NULL;
int error; int error;
if ((error = git_reference_list(&refs, repo)) < 0) if ((error = git_reference_list(&refs, repo)) < 0)
...@@ -282,6 +282,9 @@ static int fetch_setup_walk(git_revwalk **out, git_repository *repo) ...@@ -282,6 +282,9 @@ static int fetch_setup_walk(git_revwalk **out, git_repository *repo)
git_revwalk_sorting(walk, GIT_SORT_TIME); git_revwalk_sorting(walk, GIT_SORT_TIME);
for (i = 0; i < refs.count; ++i) { for (i = 0; i < refs.count; ++i) {
git_reference_free(ref);
ref = NULL;
/* No tags */ /* No tags */
if (!git__prefixcmp(refs.strings[i], GIT_REFS_TAGS_DIR)) if (!git__prefixcmp(refs.strings[i], GIT_REFS_TAGS_DIR))
continue; continue;
...@@ -294,15 +297,12 @@ static int fetch_setup_walk(git_revwalk **out, git_repository *repo) ...@@ -294,15 +297,12 @@ static int fetch_setup_walk(git_revwalk **out, git_repository *repo)
if ((error = git_revwalk_push(walk, git_reference_target(ref))) < 0) if ((error = git_revwalk_push(walk, git_reference_target(ref))) < 0)
goto on_error; goto on_error;
git_reference_free(ref);
} }
git_strarray_free(&refs);
*out = walk; *out = walk;
return 0;
on_error: on_error:
if (error)
git_revwalk_free(walk); git_revwalk_free(walk);
git_reference_free(ref); git_reference_free(ref);
git_strarray_free(&refs); git_strarray_free(&refs);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment