1
0
forked from aniani/vim

patch 8.1.2336: when an expr mapping moves the cursor it is not restored

Problem:    When an expr mapping moves the cursor it is not restored.
Solution:   Position the cursor after an expr mapping. (closes #5256)
This commit is contained in:
Bram Moolenaar
2019-11-22 20:55:40 +01:00
parent 2118a30295
commit 4ebe0e62d0
4 changed files with 50 additions and 0 deletions

View File

@@ -2594,6 +2594,8 @@ handle_mapping(
{
int save_vgetc_busy = vgetc_busy;
int save_may_garbage_collect = may_garbage_collect;
int was_screen_col = screen_cur_col;
int was_screen_row = screen_cur_row;
vgetc_busy = 0;
may_garbage_collect = FALSE;
@@ -2602,6 +2604,11 @@ handle_mapping(
save_m_str = vim_strsave(mp->m_str);
map_str = eval_map_expr(save_m_str, NUL);
// The mapping may do anything, but we expect it to take care of
// redrawing. Do put the cursor back where it was.
windgoto(was_screen_row, was_screen_col);
out_flush();
vgetc_busy = save_vgetc_busy;
may_garbage_collect = save_may_garbage_collect;
}

View File

@@ -0,0 +1,10 @@
|o+0&#ffffff0|n|e| @71
>t|w|o| @71
|t|h|r|e@1| @69
|~+0#4040ff13&| @73
|~| @73
|~| @73
|~| @73
|~| @73
|[+0#ffffff16#e000002|o|n|]| @70
| +0#0000000#ffffff0@74

View File

@@ -2,6 +2,7 @@
source shared.vim
source check.vim
source screendump.vim
func Test_abbreviation()
" abbreviation with 0x80 should work
@@ -461,3 +462,33 @@ func Test_list_mappings()
iunmap <S-/>
call assert_equal(['No mapping found'], execute('imap')->trim()->split("\n"))
endfunc
func Test_expr_map_restore_cursor()
CheckScreendump
let lines =<< trim END
call setline(1, ['one', 'two', 'three'])
2
set ls=2
hi! link StatusLine ErrorMsg
noremap <expr> <C-B> Func()
func Func()
let g:on = !get(g:, 'on', 0)
redraws
return ''
endfunc
func Status()
return get(g:, 'on', 0) ? '[on]' : ''
endfunc
set stl=%{Status()}
END
call writefile(lines, 'XtestExprMap')
let buf = RunVimInTerminal('-S XtestExprMap', #{rows: 10})
call term_wait(buf)
call term_sendkeys(buf, "\<C-B>")
call VerifyScreenDump(buf, 'Test_map_expr_1', {})
" clean up
call StopVimInTerminal(buf)
call delete('XtestExprMap')
endfunc

View File

@@ -737,6 +737,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
2336,
/**/
2335,
/**/