summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2019-03-10 09:41:51 +0100
committerBram Moolenaar <Bram@vim.org>2019-03-10 09:41:51 +0100
commit6edbbd8114320089c0e603e033775d9dd34cb10a (patch)
tree3b1e288ce9d406cd0d497a7e28446c9aa415844d
parentcbef8e1aa1f260ffde16491b1678eae53a36cf68 (diff)
downloadvim-git-6edbbd8114320089c0e603e033775d9dd34cb10a.tar.gz
patch 8.1.1003: playing back recorded key sequence mistakes key codev8.1.1003
Problem: Playing back recorded key sequence mistakes key code. Solution: Insert a <Nop> after the <Esc>. (closes #4068)
-rw-r--r--src/getchar.c11
-rw-r--r--src/testdir/test_registers.vim14
-rw-r--r--src/version.c2
3 files changed, 27 insertions, 0 deletions
diff --git a/src/getchar.c b/src/getchar.c
index 4e5c8b68c..0e9942ba3 100644
--- a/src/getchar.c
+++ b/src/getchar.c
@@ -2913,6 +2913,17 @@ vgetorpeek(int advance)
if (gui.in_use && shape_changed)
gui_update_cursor(TRUE, FALSE);
#endif
+ if (timedout && c == ESC)
+ {
+ char_u nop_buf[3];
+
+ // When recording there will be no timeout. Add a <Nop> after the ESC
+ // to avoid that it forms a key code with following characters.
+ nop_buf[0] = K_SPECIAL;
+ nop_buf[1] = KS_EXTRA;
+ nop_buf[2] = KE_NOP;
+ gotchars(nop_buf, 3);
+ }
--vgetc_busy;
diff --git a/src/testdir/test_registers.vim b/src/testdir/test_registers.vim
index 1ed0a66d1..b57555aed 100644
--- a/src/testdir/test_registers.vim
+++ b/src/testdir/test_registers.vim
@@ -146,3 +146,17 @@ func Test_register_one()
bwipe!
endfunc
+
+" Check that replaying a typed sequence does not use an Esc and following
+" characters as an escape sequence.
+func Test_recording_esc_sequence()
+ new
+ let save_F2 = &t_F2
+ let t_F2 = "\<Esc>OQ"
+ call feedkeys("qqiTest\<Esc>", "xt")
+ call feedkeys("OQuirk\<Esc>q", "xt")
+ call feedkeys("Go\<Esc>@q", "xt")
+ call assert_equal(['Quirk', 'Test', 'Quirk', 'Test'], getline(1, 4))
+ bwipe!
+ let t_F2 = save_F2
+endfunc
diff --git a/src/version.c b/src/version.c
index 1d0f90dd1..5b1676032 100644
--- a/src/version.c
+++ b/src/version.c
@@ -780,6 +780,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 1003,
+/**/
1002,
/**/
1001,