mirror of
https://github.com/vim/vim.git
synced 2025-07-26 11:04:33 -04:00
patch 9.0.0198: ml_get error when switching buffer in Visual mode
Problem: ml_get error when switching buffer in Visual mode. Solution: End Visual mode when switching buffer. (closes #10902)
This commit is contained in:
parent
6a76e84f55
commit
cfeb8a584b
@ -1818,6 +1818,14 @@ set_curbuf(buf_T *buf, int action)
|
|||||||
static void
|
static void
|
||||||
enter_buffer(buf_T *buf)
|
enter_buffer(buf_T *buf)
|
||||||
{
|
{
|
||||||
|
// when closing the current buffer stop Visual mode
|
||||||
|
if (VIsual_active
|
||||||
|
#if defined(EXITFREE)
|
||||||
|
&& !entered_free_all_mem
|
||||||
|
#endif
|
||||||
|
)
|
||||||
|
end_visual_mode();
|
||||||
|
|
||||||
// Get the buffer in the current window.
|
// Get the buffer in the current window.
|
||||||
curwin->w_buffer = buf;
|
curwin->w_buffer = buf;
|
||||||
curbuf = buf;
|
curbuf = buf;
|
||||||
|
@ -1481,5 +1481,25 @@ func Test_visual_area_adjusted_when_hiding()
|
|||||||
bwipe!
|
bwipe!
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func Test_switch_buffer_ends_visual_mode()
|
||||||
|
enew
|
||||||
|
call setline(1, 'foo')
|
||||||
|
set hidden
|
||||||
|
set virtualedit=all
|
||||||
|
let buf1 = bufnr()
|
||||||
|
enew
|
||||||
|
let buf2 = bufnr()
|
||||||
|
call setline(1, ['', '', '', ''])
|
||||||
|
call cursor(4, 5)
|
||||||
|
call feedkeys("\<C-V>3k4h", 'xt')
|
||||||
|
exe 'buffer' buf1
|
||||||
|
call assert_equal('n', mode())
|
||||||
|
|
||||||
|
set nohidden
|
||||||
|
set virtualedit=
|
||||||
|
bwipe!
|
||||||
|
exe 'bwipe!' buf2
|
||||||
|
endfunc
|
||||||
|
|
||||||
|
|
||||||
" vim: shiftwidth=2 sts=2 expandtab
|
" vim: shiftwidth=2 sts=2 expandtab
|
||||||
|
@ -735,6 +735,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 */
|
||||||
|
/**/
|
||||||
|
198,
|
||||||
/**/
|
/**/
|
||||||
197,
|
197,
|
||||||
/**/
|
/**/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user