diff options
author | Junio C Hamano <gitster@pobox.com> | 2020-09-18 17:58:03 -0700 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2020-09-18 17:58:03 -0700 |
commit | 3ad8d3e4f9855de6444b081e59328a55de1def80 (patch) | |
tree | bd96f50d711ebf57a9744c70f7e95fe26c2eabfb /add-patch.c | |
parent | e96b271d185b59d93f7deab454a788c9d8dd0e50 (diff) | |
parent | 324efcf6b6d30d43b98e76c7beac90ecfb40d637 (diff) | |
download | git-3ad8d3e4f9855de6444b081e59328a55de1def80.tar.gz |
Merge branch 'pw/add-p-leakfix'
Leakfix.
* pw/add-p-leakfix:
add -p: fix memory leak
Diffstat (limited to 'add-patch.c')
-rw-r--r-- | add-patch.c | 24 |
1 files changed, 16 insertions, 8 deletions
diff --git a/add-patch.c b/add-patch.c index 457b8c550e..2fcab983a6 100644 --- a/add-patch.c +++ b/add-patch.c @@ -266,6 +266,20 @@ struct add_p_state { const char *revision; }; +static void add_p_state_clear(struct add_p_state *s) +{ + size_t i; + + strbuf_release(&s->answer); + strbuf_release(&s->buf); + strbuf_release(&s->plain); + strbuf_release(&s->colored); + for (i = 0; i < s->file_diff_nr; i++) + free(s->file_diff[i].hunk); + free(s->file_diff); + clear_add_i_state(&s->s); +} + static void err(struct add_p_state *s, const char *fmt, ...) { va_list args; @@ -1690,9 +1704,7 @@ int run_add_p(struct repository *r, enum add_p_mode mode, repo_refresh_and_write_index(r, REFRESH_QUIET, 0, 1, NULL, NULL, NULL) < 0) || parse_diff(&s, ps) < 0) { - strbuf_release(&s.plain); - strbuf_release(&s.colored); - clear_add_i_state(&s.s); + add_p_state_clear(&s); return -1; } @@ -1707,10 +1719,6 @@ int run_add_p(struct repository *r, enum add_p_mode mode, else if (binary_count == s.file_diff_nr) fprintf(stderr, _("Only binary files changed.\n")); - strbuf_release(&s.answer); - strbuf_release(&s.buf); - strbuf_release(&s.plain); - strbuf_release(&s.colored); - clear_add_i_state(&s.s); + add_p_state_clear(&s); return 0; } |