diff options
author | Christian Brabandt <cb@256bit.org> | 2023-09-04 22:09:12 +0200 |
---|---|---|
committer | Christian Brabandt <cb@256bit.org> | 2023-09-04 22:09:12 +0200 |
commit | 623ba31821a41acee7e948794e84867680b97885 (patch) | |
tree | bf6c964be7cd4f4c8885c139096b3b434dc81444 /src | |
parent | e073a8b79f1d3398b27f35b7920746b564a169e9 (diff) |
patch 9.0.1864: still crash with bt_quickfix1_pocv9.0.1864
Problem: crash with bt_quickfix1_poc when cleaning up
and EXITFREE is defined
Solution: Test if buffer is valid in a window, else close
window directly, don't try to access buffer properties
While at it, increase the crash timeout slightly, so that CI has a
chance to finish processing the test_crash() test.
Signed-off-by: Christian Brabandt <cb@256bit.org>
Diffstat (limited to 'src')
-rw-r--r-- | src/testdir/test_crash.vim | 4 | ||||
-rw-r--r-- | src/version.c | 2 | ||||
-rw-r--r-- | src/window.c | 7 |
3 files changed, 11 insertions, 2 deletions
diff --git a/src/testdir/test_crash.vim b/src/testdir/test_crash.vim index b997cc1d29..8c79d3abd6 100644 --- a/src/testdir/test_crash.vim +++ b/src/testdir/test_crash.vim @@ -40,7 +40,7 @@ func Test_crash1() " clean up call delete('Xerr') " This test takes a bit longer - call TermWait(buf, 500) + call TermWait(buf, 1000) let file = 'crash/poc_tagfunc.vim' let args = printf(cmn_args, vim, file) @@ -55,7 +55,7 @@ func Test_crash1() \ ' && echo "crash 6: [OK]" >> X_crash1_result.txt' .. "\<cr>") " clean up call delete('X') - call TermWait(buf, 200) + call TermWait(buf, 1000) " clean up exe buf .. "bw!" diff --git a/src/version.c b/src/version.c index a19b81eb63..c2faee46cc 100644 --- a/src/version.c +++ b/src/version.c @@ -700,6 +700,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 1864, +/**/ 1863, /**/ 1862, diff --git a/src/window.c b/src/window.c index 152365e7d9..1af2395df8 100644 --- a/src/window.c +++ b/src/window.c @@ -4158,6 +4158,13 @@ close_others( if (wp == curwin) // don't close current window continue; + // autoccommands messed this one up + if (!buf_valid(wp->w_buffer) && win_valid(wp)) + { + wp->w_buffer = NULL; + win_close(wp, 0); + continue; + } // Check if it's allowed to abandon this window r = can_abandon(wp->w_buffer, forceit); if (!win_valid(wp)) // autocommands messed wp up |