From: Bram Moolenaar Date: Sat, 25 Feb 2023 14:24:44 +0000 (+0000) Subject: patch 9.0.1354: "gr CTRL-G" stays in virtual replace mode X-Git-Tag: v9.0.1354 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=d6a4ea3aa0d3f4a886ea900e94bf4e8ca8ae8d63;p=vim patch 9.0.1354: "gr CTRL-G" stays in virtual replace mode Problem: "gr CTRL-G" stays in virtual replace mode. (Pierre Ganty) Solution: Prepend CTRL-V before control characters. (closes #12045) --- diff --git a/src/edit.c b/src/edit.c index a030e537a..ff9fc0ed0 100644 --- a/src/edit.c +++ b/src/edit.c @@ -3527,6 +3527,10 @@ ins_ctrl_g(void) dont_sync_undo = MAYBE; break; + case ESC: + // Esc after CTRL-G cancels it. + break; + // Unknown CTRL-G command, reserved for future expansion. default: vim_beep(BO_CTRLG); } diff --git a/src/normal.c b/src/normal.c index b3ea5e8bc..95bb1a97d 100644 --- a/src/normal.c +++ b/src/normal.c @@ -5033,6 +5033,10 @@ nv_vreplace(cmdarg_T *cap) { if (cap->extra_char == Ctrl_V) // get another character cap->extra_char = get_literal(FALSE); + if (cap->extra_char < ' ') + // Prefix a control character with CTRL-V to avoid it being used as + // a command. + stuffcharReadbuff(Ctrl_V); stuffcharReadbuff(cap->extra_char); stuffcharReadbuff(ESC); if (virtual_active()) diff --git a/src/testdir/test_edit.vim b/src/testdir/test_edit.vim index 1b00ae98f..f0896d2c5 100644 --- a/src/testdir/test_edit.vim +++ b/src/testdir/test_edit.vim @@ -2068,8 +2068,12 @@ endfunc func Test_edit_gr_special() enew call setline(1, ['abcdef', 'xxxxxx']) - exe "normal! gr\x" - call assert_equal('bcdef', getline(1)) + exe "normal! gr\lx" + call assert_equal("\def", getline(1)) + + call setline(1, 'abcdef') + exe "normal! 0gr\lx" + call assert_equal("\def", getline(1)) bwipe! endfunc diff --git a/src/version.c b/src/version.c index c3631e6cc..315f91eac 100644 --- a/src/version.c +++ b/src/version.c @@ -695,6 +695,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ +/**/ + 1354, /**/ 1353, /**/