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:
parent
9772025d24
commit
5717ee33db
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
@ -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,
|
||||||
/**/
|
/**/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user