summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/os_win32.c20
-rw-r--r--src/version.c2
2 files changed, 19 insertions, 3 deletions
diff --git a/src/os_win32.c b/src/os_win32.c
index d7b563459..627d515dd 100644
--- a/src/os_win32.c
+++ b/src/os_win32.c
@@ -214,7 +214,6 @@ static void standend(void);
static void visual_bell(void);
static void cursor_visible(BOOL fVisible);
static DWORD write_chars(char_u *pchBuf, DWORD cbToWrite);
-static WCHAR tgetch(int *pmodifiers, WCHAR *pch2);
static void create_conin(void);
static int s_cursor_visible = TRUE;
static int did_create_conin = FALSE;
@@ -1502,6 +1501,21 @@ WaitForChar(long msec)
&& (msec < 0 || (long)dwWaitTime > p_mzq))
dwWaitTime = p_mzq; /* don't wait longer than 'mzquantum' */
#endif
+#ifdef FEAT_TIMERS
+ {
+ long due_time;
+
+ /* When waiting very briefly don't trigger timers. */
+ if (dwWaitTime > 10)
+ {
+ /* Trigger timers and then get the time in msec until the
+ * next one is due. Wait up to that time. */
+ due_time = check_due_timer();
+ if (due_time > 0 && dwWaitTime > (DWORD)due_time)
+ dwWaitTime = due_time;
+ }
+ }
+#endif
#ifdef FEAT_CLIENTSERVER
/* Wait for either an event on the console input or a message in
* the client-server window. */
@@ -1604,7 +1618,7 @@ create_conin(void)
}
/*
- * Get a keystroke or a mouse event
+ * Get a keystroke or a mouse event, use a blocking wait.
*/
static WCHAR
tgetch(int *pmodifiers, WCHAR *pch2)
@@ -6074,7 +6088,7 @@ mch_write(
/*
- * Delay for half a second.
+ * Delay for "msec" milliseconds.
*/
/*ARGSUSED*/
void
diff --git a/src/version.c b/src/version.c
index 20f3e071c..ae550bcb5 100644
--- a/src/version.c
+++ b/src/version.c
@@ -749,6 +749,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 1584,
+/**/
1583,
/**/
1582,