forked from aniani/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)
This commit is contained in:
@@ -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
|
||||
|
||||
Reference in New Issue
Block a user