patch 8.1.0140: recording into a register has focus events

Problem:    Recording into a register has focus events. (Michael Naumann)
Solution:   Don't record K_FOCUSGAINED and K_FOCUSLOST. (closes #3143)
This commit is contained in:
Bram Moolenaar
2018-07-03 14:48:15 +02:00
parent a8a60d0c6b
commit 972bfddc6b
2 changed files with 31 additions and 13 deletions

View File

@ -1247,26 +1247,42 @@ del_typebuf(int len, int offset)
gotchars(char_u *chars, int len)
{
char_u *s = chars;
int c;
char_u buf[2];
int i;
static char_u buf[4];
static int buflen = 0;
int todo = len;
/* remember how many chars were last recorded */
if (reg_recording != 0)
last_recorded_len += len;
buf[1] = NUL;
while (todo--)
{
buf[buflen++] = *s++;
// When receiving a special key sequence, store it until we have all
// the bytes and we can decide what to do with it.
if (buflen == 1 && buf[0] == K_SPECIAL)
continue;
if (buflen == 2)
continue;
if (buflen == 3 && buf[1] == KS_EXTRA
&& (buf[2] == KE_FOCUSGAINED || buf[2] == KE_FOCUSLOST))
{
// Drop K_FOCUSGAINED and K_FOCUSLOST, they are not useful in a
// recording.
buflen = 0;
continue;
}
/* Handle one byte at a time; no translation to be done. */
c = *s++;
updatescript(c);
for (i = 0; i < buflen; ++i)
updatescript(buf[i]);
if (reg_recording != 0)
{
buf[0] = c;
add_buff(&recordbuff, buf, 1L);
buf[buflen] = NUL;
add_buff(&recordbuff, buf, (long)buflen);
/* remember how many chars were last recorded */
last_recorded_len += buflen;
}
buflen = 0;
}
may_sync_undo();

View File

@ -789,6 +789,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
140,
/**/
139,
/**/