mirror of
https://github.com/vim/vim.git
synced 2025-09-27 04:14:06 -04:00
patch 8.2.4026: ml_get error with specific win_execute() command
Problem: ml_get error with specific win_execute() command. (Sean Dewar) Solution: Check cursor and Visual area are OK.
This commit is contained in:
@@ -743,6 +743,12 @@ f_win_execute(typval_T *argvars, typval_T *rettv)
|
|||||||
// Update the status line if the cursor moved.
|
// Update the status line if the cursor moved.
|
||||||
if (win_valid(wp) && !EQUAL_POS(curpos, wp->w_cursor))
|
if (win_valid(wp) && !EQUAL_POS(curpos, wp->w_cursor))
|
||||||
wp->w_redr_status = TRUE;
|
wp->w_redr_status = TRUE;
|
||||||
|
|
||||||
|
// In case the command moved the cursor or changed the Visual area,
|
||||||
|
// check it is valid.
|
||||||
|
check_cursor();
|
||||||
|
if (VIsual_active)
|
||||||
|
check_pos(curbuf, &VIsual);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -153,8 +153,23 @@ func Test_win_execute_visual_redraw()
|
|||||||
call setline(1, ['a', 'b', 'c'])
|
call setline(1, ['a', 'b', 'c'])
|
||||||
new
|
new
|
||||||
wincmd p
|
wincmd p
|
||||||
|
" start Visual in current window, redraw in other window with fewer lines
|
||||||
call feedkeys("G\<C-V>", 'txn')
|
call feedkeys("G\<C-V>", 'txn')
|
||||||
call win_execute(winnr('#')->win_getid(), 'redraw')
|
call win_execute(winnr('#')->win_getid(), 'redraw')
|
||||||
|
call feedkeys("\<Esc>", 'txn')
|
||||||
|
bwipe!
|
||||||
|
bwipe!
|
||||||
|
|
||||||
|
enew
|
||||||
|
new
|
||||||
|
call setline(1, ['a', 'b', 'c'])
|
||||||
|
let winid = win_getid()
|
||||||
|
wincmd p
|
||||||
|
" start Visual in current window, extend it in other window with more lines
|
||||||
|
call feedkeys("\<C-V>", 'txn')
|
||||||
|
call win_execute(winid, 'call feedkeys("G\<C-V>", ''txn'')')
|
||||||
|
redraw
|
||||||
|
|
||||||
bwipe!
|
bwipe!
|
||||||
bwipe!
|
bwipe!
|
||||||
endfunc
|
endfunc
|
||||||
|
@@ -750,6 +750,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 */
|
||||||
|
/**/
|
||||||
|
4026,
|
||||||
/**/
|
/**/
|
||||||
4025,
|
4025,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user