0
0
mirror of https://github.com/vim/vim.git synced 2025-08-26 20:03:41 -04:00

patch 9.1.1407: Can't use getpos('v') in OptionSet when using setbufvar()

Problem:  Can't use getpos('v') in OptionSet when using setbufvar().
Solution: Don't reset Visual selection when switching to the same
          buffer (zeertzjq).

closes: #17373

Signed-off-by: zeertzjq <zeertzjq@outlook.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
zeertzjq 2025-05-25 16:59:50 +02:00 committed by Christian Brabandt
parent 9772025d24
commit 5717ee33db
No known key found for this signature in database
GPG Key ID: F3F92DA383FDDE09
3 changed files with 28 additions and 3 deletions

View File

@ -1585,9 +1585,10 @@ aucmd_prepbuf(
#ifdef FEAT_AUTOCHDIR #ifdef FEAT_AUTOCHDIR
int save_acd; int save_acd;
#endif #endif
int same_buffer = buf == curbuf;
// Find a window that is for the new buffer // Find a window that is for the new buffer
if (buf == curbuf) // be quick when buf is curbuf if (same_buffer) // be quick when buf is curbuf
win = curwin; win = curwin;
else else
FOR_ALL_WINDOWS(win) FOR_ALL_WINDOWS(win)
@ -1677,8 +1678,9 @@ aucmd_prepbuf(
aco->new_curwin_id = curwin->w_id; aco->new_curwin_id = curwin->w_id;
set_bufref(&aco->new_curbuf, curbuf); set_bufref(&aco->new_curbuf, curbuf);
// disable the Visual area, the position may be invalid in another buffer
aco->save_VIsual_active = VIsual_active; aco->save_VIsual_active = VIsual_active;
if (!same_buffer)
// disable the Visual area, position may be invalid in another buffer
VIsual_active = FALSE; VIsual_active = FALSE;
} }

View File

@ -3761,6 +3761,27 @@ func Test_Visual_doautoall_redraw()
%bwipe! %bwipe!
endfunc endfunc
func Test_get_Visual_selection_in_curbuf_autocmd()
call test_override('starting', 1)
new
autocmd OptionSet list let b:text = getregion(getpos('.'), getpos('v'))
call setline(1, 'foo bar baz')
normal! gg0fbvtb
setlocal list
call assert_equal(['bar '], b:text)
exe "normal! \<Esc>"
normal! v0
call setbufvar('%', '&list', v:false)
call assert_equal(['foo bar '], b:text)
exe "normal! \<Esc>"
autocmd! OptionSet list
bwipe!
call test_override('starting', 0)
endfunc
" This was using freed memory. " This was using freed memory.
func Test_BufNew_arglocal() func Test_BufNew_arglocal()
arglocal arglocal

View File

@ -709,6 +709,8 @@ static char *(features[]) =
static int included_patches[] = static int included_patches[] =
{ /* Add new patch number below this line */ { /* Add new patch number below this line */
/**/
1407,
/**/ /**/
1406, 1406,
/**/ /**/