mirror of
https://github.com/neovim/neovim.git
synced 2025-09-30 15:08:35 +00:00
Merge pull request #17102 from zeertzjq/vim-8.2.1762
vim-patch:8.2.1762: when a timer uses :stopinsert completion isn't stopped
This commit is contained in:
@@ -663,8 +663,12 @@ static int insert_execute(VimState *state, int key)
|
||||
InsertState *const s = (InsertState *)state;
|
||||
if (stop_insert_mode) {
|
||||
// Insert mode ended, possibly from a callback.
|
||||
if (key != K_IGNORE && key != K_NOP) {
|
||||
vungetc(key);
|
||||
}
|
||||
s->count = 0;
|
||||
s->nomove = true;
|
||||
ins_compl_prep(ESC);
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
@@ -445,6 +445,28 @@ func Test_issue_7021()
|
||||
set completeslash=
|
||||
endfunc
|
||||
|
||||
func Test_pum_stopped_by_timer()
|
||||
CheckScreendump
|
||||
|
||||
let lines =<< trim END
|
||||
call setline(1, ['hello', 'hullo', 'heeee', ''])
|
||||
func StartCompl()
|
||||
call timer_start(100, { -> execute('stopinsert') })
|
||||
call feedkeys("Gah\<C-N>")
|
||||
endfunc
|
||||
END
|
||||
|
||||
call writefile(lines, 'Xpumscript')
|
||||
let buf = RunVimInTerminal('-S Xpumscript', #{rows: 12})
|
||||
call term_sendkeys(buf, ":call StartCompl()\<CR>")
|
||||
call TermWait(buf, 200)
|
||||
call term_sendkeys(buf, "k")
|
||||
call VerifyScreenDump(buf, 'Test_pum_stopped_by_timer', {})
|
||||
|
||||
call StopVimInTerminal(buf)
|
||||
call delete('Xpumscript')
|
||||
endfunc
|
||||
|
||||
func Test_pum_with_folds_two_tabs()
|
||||
CheckScreendump
|
||||
|
||||
|
Reference in New Issue
Block a user