mirror of
https://github.com/vim/vim.git
synced 2025-07-04 23:07:33 -04:00
patch 9.1.0035: i_CTRL-] triggers InsertCharPre
Problem: i_CTRL-] triggers InsertCharPre Solution: Return if CTRL-] is received. InsertCharPre is supposed to be only used for chars to be inserted but i_CTRL-] triggers expansion and is not inserted into the buffer (altermo) closes: #13853 closes: #13864 Signed-off-by: altermo Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
parent
ac4cffc6d9
commit
7d711fe209
@ -5371,6 +5371,9 @@ do_insert_char_pre(int c)
|
|||||||
if (!has_insertcharpre())
|
if (!has_insertcharpre())
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
|
if (c == Ctrl_RSB)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
if (has_mbyte)
|
if (has_mbyte)
|
||||||
buf[(*mb_char2bytes)(c, buf)] = NUL;
|
buf[(*mb_char2bytes)(c, buf)] = NUL;
|
||||||
else
|
else
|
||||||
|
@ -2123,4 +2123,39 @@ func Test_edit_shift_bs()
|
|||||||
call StopVimInTerminal(buf)
|
call StopVimInTerminal(buf)
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func Test_edit_Ctrl_RSB()
|
||||||
|
new
|
||||||
|
let g:triggered = []
|
||||||
|
autocmd InsertCharPre <buffer> let g:triggered += [v:char]
|
||||||
|
|
||||||
|
" i_CTRL-] should not trigger InsertCharPre
|
||||||
|
exe "normal! A\<C-]>"
|
||||||
|
call assert_equal([], g:triggered)
|
||||||
|
|
||||||
|
" i_CTRL-] should expand abbreviations but not trigger InsertCharPre
|
||||||
|
inoreabbr <buffer> f foo
|
||||||
|
exe "normal! Af\<C-]>a"
|
||||||
|
call assert_equal(['f', 'f', 'o', 'o', 'a'], g:triggered)
|
||||||
|
call assert_equal('fooa', getline(1))
|
||||||
|
|
||||||
|
" CTRL-] followed by i_CTRL-V should not expand abbreviations
|
||||||
|
" i_CTRL-V doesn't trigger InsertCharPre
|
||||||
|
call setline(1, '')
|
||||||
|
exe "normal! Af\<C-V>\<C-]>"
|
||||||
|
call assert_equal("f\<C-]>", getline(1))
|
||||||
|
|
||||||
|
let g:triggered = []
|
||||||
|
call setline(1, '')
|
||||||
|
|
||||||
|
" Also test assigning to v:char
|
||||||
|
autocmd InsertCharPre <buffer> let v:char = 'f'
|
||||||
|
exe "normal! Ag\<C-]>h"
|
||||||
|
call assert_equal(['g', 'f', 'o', 'o', 'h'], g:triggered)
|
||||||
|
call assert_equal('ffff', getline(1))
|
||||||
|
|
||||||
|
autocmd! InsertCharPre
|
||||||
|
unlet g:triggered
|
||||||
|
bwipe!
|
||||||
|
endfunc
|
||||||
|
|
||||||
" vim: shiftwidth=2 sts=2 expandtab
|
" vim: shiftwidth=2 sts=2 expandtab
|
||||||
|
@ -704,6 +704,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 */
|
||||||
|
/**/
|
||||||
|
35,
|
||||||
/**/
|
/**/
|
||||||
34,
|
34,
|
||||||
/**/
|
/**/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user