From 81b46a6ccd818609e1ca8cd410e26a58428c30ba Mon Sep 17 00:00:00 2001 From: zeertzjq Date: Sat, 9 Apr 2022 17:58:49 +0100 Subject: patch 8.2.4722: ending recording with mapping records too much Problem: When a recording is ended with a mapped key that key is also recorded. Solution: Remember the previous last_recorded_len. (closes #10122) --- src/getchar.c | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) (limited to 'src/getchar.c') diff --git a/src/getchar.c b/src/getchar.c index 29ad56e6a1..fb7f00a95f 100644 --- a/src/getchar.c +++ b/src/getchar.c @@ -1705,10 +1705,16 @@ vgetc(void) } else { + // number of characters recorded from the last vgetc() call + static int last_vgetc_recorded_len = 0; + mod_mask = 0; vgetc_mod_mask = 0; vgetc_char = 0; - last_recorded_len = 0; + + // last_recorded_len can be larger than last_vgetc_recorded_len + // if peeking records more + last_recorded_len -= last_vgetc_recorded_len; for (;;) // this is done twice if there are modifiers { @@ -1910,6 +1916,8 @@ vgetc(void) break; } + + last_vgetc_recorded_len = last_recorded_len; } #ifdef FEAT_EVAL -- cgit v1.2.3