From: Bram Moolenaar Date: Wed, 5 Feb 2014 13:02:27 +0000 (+0100) Subject: updated for version 7.4.164 X-Git-Tag: v7.4.164 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=dd415a6c5acf5c7c054a16331b34f6b84f9c004d;p=vim updated for version 7.4.164 Problem: Problem with event handling on Windows 8. Solution: Ignore duplicate WINDOW_BUFFER_SIZE_EVENTs. (Nobuhiro Takasaki) --- diff --git a/src/os_win32.c b/src/os_win32.c index bfd5f4a2e..a468bbe74 100644 --- a/src/os_win32.c +++ b/src/os_win32.c @@ -253,6 +253,9 @@ read_console_input( static DWORD s_dwIndex = 0; static DWORD s_dwMax = 0; DWORD dwEvents; + int head; + int tail; + int i; if (!win8_or_later) { @@ -274,7 +277,29 @@ read_console_input( *lpEvents = 0; return TRUE; } + + if (s_dwMax > 1) + { + head = 0; + tail = s_dwMax - 1; + while (head != tail) + { + if (s_irCache[head].EventType == WINDOW_BUFFER_SIZE_EVENT + && s_irCache[head + 1].EventType + == WINDOW_BUFFER_SIZE_EVENT) + { + /* Remove duplicate event to avoid flicker. */ + for (i = head; i < tail; ++i) + s_irCache[i] = s_irCache[i + 1]; + --tail; + continue; + } + head++; + } + s_dwMax = tail + 1; + } } + *lpBuffer = s_irCache[s_dwIndex]; if (nLength != -1 && ++s_dwIndex >= s_dwMax) s_dwMax = 0; diff --git a/src/version.c b/src/version.c index a6acd9a36..312653ea3 100644 --- a/src/version.c +++ b/src/version.c @@ -738,6 +738,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ +/**/ + 164, /**/ 163, /**/