mirror of
https://github.com/neovim/neovim
synced 2025-07-27 17:02:14 +00:00
Merge pull request #19053 from neovim/backport-19047-to-release-0.7
[Backport release-0.7] fix(input): use correct grid when restoring cursor for <expr> mapping
This commit is contained in:
@ -1993,6 +1993,7 @@ static int handle_mapping(int *keylenp, bool *timedout, int *mapdepth)
|
|||||||
const bool save_may_garbage_collect = may_garbage_collect;
|
const bool save_may_garbage_collect = may_garbage_collect;
|
||||||
const int save_cursor_row = ui_current_row();
|
const int save_cursor_row = ui_current_row();
|
||||||
const int save_cursor_col = ui_current_col();
|
const int save_cursor_col = ui_current_col();
|
||||||
|
const handle_T save_cursor_grid = ui_cursor_grid();
|
||||||
const int prev_did_emsg = did_emsg;
|
const int prev_did_emsg = did_emsg;
|
||||||
|
|
||||||
vgetc_busy = 0;
|
vgetc_busy = 0;
|
||||||
@ -2006,7 +2007,7 @@ static int handle_mapping(int *keylenp, bool *timedout, int *mapdepth)
|
|||||||
|
|
||||||
// The mapping may do anything, but we expect it to take care of
|
// The mapping may do anything, but we expect it to take care of
|
||||||
// redrawing. Do put the cursor back where it was.
|
// redrawing. Do put the cursor back where it was.
|
||||||
ui_cursor_goto(save_cursor_row, save_cursor_col);
|
ui_grid_cursor_goto(save_cursor_grid, save_cursor_row, save_cursor_col);
|
||||||
ui_flush();
|
ui_flush();
|
||||||
|
|
||||||
// If an error was displayed and the expression returns an empty
|
// If an error was displayed and the expression returns an empty
|
||||||
|
@ -503,6 +503,11 @@ int ui_current_col(void)
|
|||||||
return cursor_col;
|
return cursor_col;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
handle_T ui_cursor_grid(void)
|
||||||
|
{
|
||||||
|
return cursor_grid_handle;
|
||||||
|
}
|
||||||
|
|
||||||
void ui_flush(void)
|
void ui_flush(void)
|
||||||
{
|
{
|
||||||
cmdline_ui_flush();
|
cmdline_ui_flush();
|
||||||
|
@ -86,7 +86,7 @@ n asdf1 qwert
|
|||||||
end)
|
end)
|
||||||
end)
|
end)
|
||||||
|
|
||||||
describe(':*map cursor and redrawing', function()
|
describe('Screen', function()
|
||||||
local screen
|
local screen
|
||||||
before_each(function()
|
before_each(function()
|
||||||
clear()
|
clear()
|
||||||
@ -149,6 +149,18 @@ describe(':*map cursor and redrawing', function()
|
|||||||
]])
|
]])
|
||||||
end)
|
end)
|
||||||
|
|
||||||
|
it('cursor position does not move after empty-string :cmap <expr> #19046', function()
|
||||||
|
command([[cnoremap <expr> <F2> '']])
|
||||||
|
feed(':<F2>')
|
||||||
|
screen:expect([[
|
||||||
|
|
|
||||||
|
~ |
|
||||||
|
~ |
|
||||||
|
~ |
|
||||||
|
:^ |
|
||||||
|
]])
|
||||||
|
end)
|
||||||
|
|
||||||
it('cursor is restored after :map <expr> which redraws statusline vim-patch:8.1.2336', function()
|
it('cursor is restored after :map <expr> which redraws statusline vim-patch:8.1.2336', function()
|
||||||
exec([[
|
exec([[
|
||||||
call setline(1, ['one', 'two', 'three'])
|
call setline(1, ['one', 'two', 'three'])
|
||||||
@ -157,12 +169,12 @@ describe(':*map cursor and redrawing', function()
|
|||||||
hi! link StatusLine ErrorMsg
|
hi! link StatusLine ErrorMsg
|
||||||
noremap <expr> <C-B> Func()
|
noremap <expr> <C-B> Func()
|
||||||
func Func()
|
func Func()
|
||||||
let g:on = !get(g:, 'on', 0)
|
let g:on = !get(g:, 'on', 0)
|
||||||
redraws
|
redraws
|
||||||
return ''
|
return ''
|
||||||
endfunc
|
endfunc
|
||||||
func Status()
|
func Status()
|
||||||
return get(g:, 'on', 0) ? '[on]' : ''
|
return get(g:, 'on', 0) ? '[on]' : ''
|
||||||
endfunc
|
endfunc
|
||||||
set stl=%{Status()}
|
set stl=%{Status()}
|
||||||
]])
|
]])
|
||||||
|
Reference in New Issue
Block a user