diff --git a/src/nvim/edit.c b/src/nvim/edit.c index 470d57890a..6f05ba5905 100644 --- a/src/nvim/edit.c +++ b/src/nvim/edit.c @@ -4725,6 +4725,10 @@ static char *do_insert_char_pre(int c) char buf[MB_MAXBYTES + 1]; const int save_State = State; + if (c == Ctrl_RSB) { + return NULL; + } + // Return quickly when there is nothing to do. if (!has_event(EVENT_INSERTCHARPRE)) { return NULL; diff --git a/test/old/testdir/test_edit.vim b/test/old/testdir/test_edit.vim index 3fe65832c9..67143ab524 100644 --- a/test/old/testdir/test_edit.vim +++ b/test/old/testdir/test_edit.vim @@ -2118,5 +2118,39 @@ func Test_edit_overlong_file_name() bwipe! endfunc +func Test_edit_Ctrl_RSB() + new + let g:triggered = [] + autocmd InsertCharPre let g:triggered += [v:char] + + " i_CTRL-] should not trigger InsertCharPre + exe "normal! A\" + call assert_equal([], g:triggered) + + " i_CTRL-] should expand abbreviations but not trigger InsertCharPre + inoreabbr f foo + exe "normal! Af\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\\" + call assert_equal("f\", getline(1)) + + let g:triggered = [] + call setline(1, '') + + " Also test assigning to v:char + autocmd InsertCharPre let v:char = 'f' + exe "normal! Ag\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