mirror of
https://github.com/vim/vim.git
synced 2025-07-26 11:04:33 -04:00
patch 8.2.4837: modifiers not simplified when timed out
Problem: Modifiers not simplified when timed out or using feedkeys() with 'n" flag. Solution: Adjust how mapped flag and timeout are used. (closes #10305)
This commit is contained in:
parent
f6ced9863f
commit
68a573ce2b
@ -2699,17 +2699,19 @@ handle_mapping(
|
|||||||
* - and not an ESC sequence, not in insert mode or p_ek is on,
|
* - and not an ESC sequence, not in insert mode or p_ek is on,
|
||||||
* - and when not timed out,
|
* - and when not timed out,
|
||||||
*/
|
*/
|
||||||
if ((no_mapping == 0 || allow_keys != 0)
|
if (no_mapping == 0 || allow_keys != 0)
|
||||||
&& (typebuf.tb_maplen == 0
|
{
|
||||||
|
if ((typebuf.tb_maplen == 0
|
||||||
|| (p_remap && typebuf.tb_noremap[
|
|| (p_remap && typebuf.tb_noremap[
|
||||||
typebuf.tb_off] == RM_YES))
|
typebuf.tb_off] == RM_YES))
|
||||||
&& !*timedout)
|
&& !*timedout)
|
||||||
{
|
|
||||||
keylen = check_termcode(max_mlen + 1, NULL, 0, NULL);
|
keylen = check_termcode(max_mlen + 1, NULL, 0, NULL);
|
||||||
|
else
|
||||||
|
keylen = 0;
|
||||||
|
|
||||||
// If no termcode matched but 'pastetoggle' matched partially
|
// If no termcode matched but 'pastetoggle' matched partially
|
||||||
// it's like an incomplete key sequence.
|
// it's like an incomplete key sequence.
|
||||||
if (keylen == 0 && save_keylen == KEYLEN_PART_KEY)
|
if (keylen == 0 && save_keylen == KEYLEN_PART_KEY && !*timedout)
|
||||||
keylen = KEYLEN_PART_KEY;
|
keylen = KEYLEN_PART_KEY;
|
||||||
|
|
||||||
// If no termcode matched, try to include the modifier into the
|
// If no termcode matched, try to include the modifier into the
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
|
|
||||||
" Bracketed paste only works with "xterm". Not in GUI or Windows console.
|
" Bracketed paste only works with "xterm". Not in GUI or Windows console.
|
||||||
source check.vim
|
source check.vim
|
||||||
|
source term_util.vim
|
||||||
CheckNotMSWindows
|
CheckNotMSWindows
|
||||||
CheckNotGui
|
CheckNotGui
|
||||||
|
|
||||||
@ -217,6 +218,69 @@ func Test_pastetoggle()
|
|||||||
bwipe!
|
bwipe!
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func Test_pastetoggle_timeout_no_typed_after_mapped()
|
||||||
|
CheckRunVimInTerminal
|
||||||
|
|
||||||
|
let lines =<< trim END
|
||||||
|
set pastetoggle=abc
|
||||||
|
set ttimeoutlen=10000
|
||||||
|
imap d a
|
||||||
|
END
|
||||||
|
call writefile(lines, 'Xpastetoggle_no_typed_after_mapped.vim')
|
||||||
|
let buf = RunVimInTerminal('-S Xpastetoggle_no_typed_after_mapped.vim', #{rows: 8})
|
||||||
|
call TermWait(buf)
|
||||||
|
call term_sendkeys(buf, ":call feedkeys('id', 't')\<CR>")
|
||||||
|
call term_wait(buf, 200)
|
||||||
|
call term_sendkeys(buf, 'bc')
|
||||||
|
" 'ttimeoutlen' should NOT apply
|
||||||
|
call WaitForAssert({-> assert_match('^-- INSERT --', term_getline(buf, 8))})
|
||||||
|
|
||||||
|
call StopVimInTerminal(buf)
|
||||||
|
call delete('Xpastetoggle_no_typed_after_mapped.vim')
|
||||||
|
endfunc
|
||||||
|
|
||||||
|
func Test_pastetoggle_timeout_typed_after_mapped()
|
||||||
|
CheckRunVimInTerminal
|
||||||
|
|
||||||
|
let lines =<< trim END
|
||||||
|
set pastetoggle=abc
|
||||||
|
set ttimeoutlen=10000
|
||||||
|
imap d a
|
||||||
|
END
|
||||||
|
call writefile(lines, 'Xpastetoggle_typed_after_mapped.vim')
|
||||||
|
let buf = RunVimInTerminal('-S Xpastetoggle_typed_after_mapped.vim', #{rows: 8})
|
||||||
|
call TermWait(buf)
|
||||||
|
call term_sendkeys(buf, ":call feedkeys('idb', 't')\<CR>")
|
||||||
|
call term_wait(buf, 200)
|
||||||
|
call term_sendkeys(buf, 'c')
|
||||||
|
" 'ttimeoutlen' should apply
|
||||||
|
call WaitForAssert({-> assert_match('^-- INSERT (paste) --', term_getline(buf, 8))})
|
||||||
|
|
||||||
|
call StopVimInTerminal(buf)
|
||||||
|
call delete('Xpastetoggle_typed_after_mapped.vim')
|
||||||
|
endfunc
|
||||||
|
|
||||||
|
func Test_pastetoggle_timeout_typed_after_noremap()
|
||||||
|
CheckRunVimInTerminal
|
||||||
|
|
||||||
|
let lines =<< trim END
|
||||||
|
set pastetoggle=abc
|
||||||
|
set ttimeoutlen=10000
|
||||||
|
inoremap d a
|
||||||
|
END
|
||||||
|
call writefile(lines, 'Xpastetoggle_typed_after_noremap.vim')
|
||||||
|
let buf = RunVimInTerminal('-S Xpastetoggle_typed_after_noremap.vim', #{rows: 8})
|
||||||
|
call TermWait(buf)
|
||||||
|
call term_sendkeys(buf, ":call feedkeys('idb', 't')\<CR>")
|
||||||
|
call term_wait(buf, 200)
|
||||||
|
call term_sendkeys(buf, 'c')
|
||||||
|
" 'ttimeoutlen' should apply
|
||||||
|
call WaitForAssert({-> assert_match('^-- INSERT (paste) --', term_getline(buf, 8))})
|
||||||
|
|
||||||
|
call StopVimInTerminal(buf)
|
||||||
|
call delete('Xpastetoggle_typed_after_noremap.vim')
|
||||||
|
endfunc
|
||||||
|
|
||||||
" Test for restoring option values when 'paste' is disabled
|
" Test for restoring option values when 'paste' is disabled
|
||||||
func Test_paste_opt_restore()
|
func Test_paste_opt_restore()
|
||||||
set autoindent expandtab ruler showmatch
|
set autoindent expandtab ruler showmatch
|
||||||
|
@ -2444,5 +2444,21 @@ func Test_simplify_ctrl_at()
|
|||||||
bw!
|
bw!
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func Test_simplify_noremap()
|
||||||
|
call feedkeys("i\<*C-M>", 'nx')
|
||||||
|
call assert_equal('', getline(1))
|
||||||
|
call assert_equal([0, 2, 1, 0, 1], getcurpos())
|
||||||
|
bw!
|
||||||
|
endfunc
|
||||||
|
|
||||||
|
func Test_simplify_timedout()
|
||||||
|
inoremap <C-M>a b
|
||||||
|
call feedkeys("i\<*C-M>", 'xt')
|
||||||
|
call assert_equal('', getline(1))
|
||||||
|
call assert_equal([0, 2, 1, 0, 1], getcurpos())
|
||||||
|
iunmap <C-M>a
|
||||||
|
bw!
|
||||||
|
endfunc
|
||||||
|
|
||||||
|
|
||||||
" vim: shiftwidth=2 sts=2 expandtab
|
" vim: shiftwidth=2 sts=2 expandtab
|
||||||
|
@ -746,6 +746,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 */
|
||||||
|
/**/
|
||||||
|
4837,
|
||||||
/**/
|
/**/
|
||||||
4836,
|
4836,
|
||||||
/**/
|
/**/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user