mirror of
https://github.com/git/git.git
synced 2025-12-12 20:36:24 +01:00
combine-diff: fix leaking lost lines
The `cnt` variable tracks the number of lines in a patch diff. It can happen though that there are no newlines, in which case we'd still end up allocating our array of `sline`s. In fact, we always allocate it with `cnt + 2` entries. But when we loop through the array to clear it at the end of this function we only loop until `lno < cnt`, and thus we may not end up releasing whatever the two extra `sline`s contain. Plug this memory leak. Signed-off-by: Patrick Steinhardt <ps@pks.im> Signed-off-by: Taylor Blau <me@ttaylorr.com>
This commit is contained in:
committed by
Taylor Blau
parent
8eded2ff0e
commit
9a2c5b013b
@@ -1220,7 +1220,7 @@ static void show_patch_diff(struct combine_diff_path *elem, int num_parent,
|
||||
}
|
||||
free(result);
|
||||
|
||||
for (lno = 0; lno < cnt; lno++) {
|
||||
for (lno = 0; lno < cnt + 2; lno++) {
|
||||
if (sline[lno].lost) {
|
||||
struct lline *ll = sline[lno].lost;
|
||||
while (ll) {
|
||||
|
||||
@@ -5,6 +5,7 @@ test_description='combined diff'
|
||||
GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME=main
|
||||
export GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME
|
||||
|
||||
TEST_PASSES_SANITIZE_LEAK=true
|
||||
. ./test-lib.sh
|
||||
. "$TEST_DIRECTORY"/lib-diff.sh
|
||||
|
||||
|
||||
Reference in New Issue
Block a user