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:
zeertzjq
2022-06-23 07:00:23 +08:00
committed by GitHub
3 changed files with 24 additions and 6 deletions

View File

@ -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

View File

@ -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();

View File

@ -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()}
]]) ]])