From: zeertzjq Date: Sat, 9 Apr 2022 16:58:49 +0000 (+0100) Subject: patch 8.2.4722: ending recording with mapping records too much X-Git-Tag: v8.2.4722 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=81b46a6ccd818609e1ca8cd410e26a58428c30ba;p=vim 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) --- diff --git a/src/getchar.c b/src/getchar.c index 29ad56e6a..fb7f00a95 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 diff --git a/src/testdir/test_registers.vim b/src/testdir/test_registers.vim index 51543c00c..352264981 100644 --- a/src/testdir/test_registers.vim +++ b/src/testdir/test_registers.vim @@ -759,6 +759,27 @@ func Test_record_in_select_mode() bwipe! endfunc +" mapping that ends macro recording should be removed from recorded macro +func Test_end_record_using_mapping() + call setline(1, 'aaa') + nnoremap s q + call feedkeys('safas', 'tx') + call assert_equal('fa', @a) + nunmap s + + nnoremap xx q + call feedkeys('0xxafaxx', 'tx') + call assert_equal('fa', @a) + nunmap xx + + nnoremap xsx q + call feedkeys('0qafaxsx', 'tx') + call assert_equal('fa', @a) + nunmap xsx + + bwipe! +endfunc + func Test_end_reg_executing() nnoremap s let @a = 's' diff --git a/src/version.c b/src/version.c index 1b2a1886b..410fe2aa5 100644 --- a/src/version.c +++ b/src/version.c @@ -746,6 +746,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ +/**/ + 4722, /**/ 4721, /**/