diff options
author | Bram Moolenaar <Bram@vim.org> | 2020-03-14 17:21:34 +0100 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2020-03-14 17:21:34 +0100 |
commit | 2573af3519ad062ddad647b97e32090f106f2ac1 (patch) | |
tree | 8de45c3c96c93235b20c8739c8dbb27c2f68c135 | |
parent | 193982650960f8411df51f3b3b0d44a75e1ac034 (diff) | |
download | vim-git-8.2.0381.tar.gz |
patch 8.2.0381: using freed memory with :lvimgrep and autocommandv8.2.0381
Problem: Using freed memory with :lvimgrep and autocommand. (extracted from
POC by Dominique Pelle)
Solution: Avoid deleting a dummy buffer used in a window. (closes #5777)
-rw-r--r-- | src/quickfix.c | 21 | ||||
-rw-r--r-- | src/testdir/test_quickfix.vim | 8 | ||||
-rw-r--r-- | src/version.c | 2 |
3 files changed, 30 insertions, 1 deletions
diff --git a/src/quickfix.c b/src/quickfix.c index 7ae489b5d..f82a18716 100644 --- a/src/quickfix.c +++ b/src/quickfix.c @@ -6268,7 +6268,26 @@ load_dummy_buffer( static void wipe_dummy_buffer(buf_T *buf, char_u *dirname_start) { - if (curbuf != buf) // safety check + // If any autocommand opened a window on the dummy buffer, close that + // window. If we can't close them all then give up. + while (buf->b_nwindows > 0) + { + int did_one = FALSE; + win_T *wp; + + if (firstwin->w_next != NULL) + for (wp = firstwin; wp != NULL; wp = wp->w_next) + if (wp->w_buffer == buf) + { + if (win_close(wp, FALSE) == OK) + did_one = TRUE; + break; + } + if (!did_one) + return; + } + + if (curbuf != buf && buf->b_nwindows == 0) // safety check { #if defined(FEAT_EVAL) cleanup_T cs; diff --git a/src/testdir/test_quickfix.vim b/src/testdir/test_quickfix.vim index 2b51b576c..c1b50631b 100644 --- a/src/testdir/test_quickfix.vim +++ b/src/testdir/test_quickfix.vim @@ -3684,6 +3684,14 @@ func Test_lvimgrep_crash() enew | only endfunc +func Test_lvimgrep_crash2() + au BufNewFile x sfind + call assert_fails('lvimgrep x x', 'E480:') + call assert_fails('lvimgrep x x x', 'E480:') + + au! BufNewFile +endfunc + " Test for the position of the quickfix and location list window func Test_qfwin_pos() " Open two windows diff --git a/src/version.c b/src/version.c index 2d5c134c3..e49c628a3 100644 --- a/src/version.c +++ b/src/version.c @@ -739,6 +739,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 381, +/**/ 380, /**/ 379, |