From: Bram Moolenaar Date: Sat, 30 Jan 2021 20:40:03 +0000 (+0100) Subject: patch 8.2.2433: opening cmdline window gives error in BufLeave autocommand X-Git-Tag: v8.2.2433 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=b63f3ca66db20f7b135aae706d36be538f91f8cc;p=vim patch 8.2.2433: opening cmdline window gives error in BufLeave autocommand Problem: Opening cmdline window gives error in BufLeave autocommand. Solution: Reset cmdwin_type when triggering the autocommand. --- diff --git a/src/ex_cmds.c b/src/ex_cmds.c index 12219e7ba..b678f6699 100644 --- a/src/ex_cmds.c +++ b/src/ex_cmds.c @@ -2710,6 +2710,12 @@ do_ecmd( */ if (buf != curbuf) { +#ifdef FEAT_CMDWIN + int save_cmdwin_type = cmdwin_type; + + // BufLeave applies to the old buffer. + cmdwin_type = 0; +#endif /* * Be careful: The autocommands may delete any buffer and change * the current buffer. @@ -2724,6 +2730,9 @@ do_ecmd( new_name = vim_strsave(buf->b_fname); set_bufref(&au_new_curbuf, buf); apply_autocmds(EVENT_BUFLEAVE, NULL, NULL, FALSE, curbuf); +#ifdef FEAT_CMDWIN + cmdwin_type = save_cmdwin_type; +#endif if (!bufref_valid(&au_new_curbuf)) { // new buffer has been deleted diff --git a/src/testdir/test_cmdline.vim b/src/testdir/test_cmdline.vim index c2bbcc6c0..7f62dfe77 100644 --- a/src/testdir/test_cmdline.vim +++ b/src/testdir/test_cmdline.vim @@ -1237,6 +1237,7 @@ func Test_cmdwin_autocmd() augroup CmdWin au! + autocmd BufLeave * if &buftype == '' | update | endif autocmd CmdwinEnter * startinsert augroup END diff --git a/src/version.c b/src/version.c index dc20c3349..555a2f937 100644 --- a/src/version.c +++ b/src/version.c @@ -750,6 +750,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ +/**/ + 2433, /**/ 2432, /**/