0
0
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:
altermo 2024-01-16 17:25:17 +01:00 committed by Christian Brabandt
parent ac4cffc6d9
commit 7d711fe209
No known key found for this signature in database
GPG Key ID: F3F92DA383FDDE09
3 changed files with 40 additions and 0 deletions

View File

@ -5371,6 +5371,9 @@ do_insert_char_pre(int c)
if (!has_insertcharpre())
return NULL;
if (c == Ctrl_RSB)
return NULL;
if (has_mbyte)
buf[(*mb_char2bytes)(c, buf)] = NUL;
else

View File

@ -2123,4 +2123,39 @@ func Test_edit_shift_bs()
call StopVimInTerminal(buf)
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

View File

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