summaryrefslogtreecommitdiff
path: root/src/gui_w32.c
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2019-09-04 13:53:21 +0200
committerBram Moolenaar <Bram@vim.org>2019-09-04 13:53:21 +0200
commit89c00033310a1cad89efd2a7fc873f8969dd4401 (patch)
treebb6b20a5f6be5441cb22df00665462f6e6db835f /src/gui_w32.c
parent1f3165bc34c6c608584a73f13faec27dd7c7e2fa (diff)
downloadvim-git-89c00033310a1cad89efd2a7fc873f8969dd4401.tar.gz
patch 8.1.1975: MS-Windows GUI responds slowly to timerv8.1.1975
Problem: MS-Windows GUI responds slowly to timer. Solution: Break out of wait loop when timer was added or input is available. (closes #4893)
Diffstat (limited to 'src/gui_w32.c')
-rw-r--r--src/gui_w32.c32
1 files changed, 17 insertions, 15 deletions
diff --git a/src/gui_w32.c b/src/gui_w32.c
index 5600ac0c2..c2371f405 100644
--- a/src/gui_w32.c
+++ b/src/gui_w32.c
@@ -2074,7 +2074,7 @@ gui_mch_wait_for_chars(int wtime)
focus = gui.in_focus;
while (!s_timed_out)
{
- /* Stop or start blinking when focus changes */
+ // Stop or start blinking when focus changes
if (gui.in_focus != focus)
{
if (gui.in_focus)
@@ -2094,29 +2094,31 @@ gui_mch_wait_for_chars(int wtime)
did_add_timer = FALSE;
#endif
#ifdef MESSAGE_QUEUE
- /* Check channel I/O while waiting for a message. */
+ // Check channel I/O while waiting for a message.
for (;;)
{
MSG msg;
parse_queued_messages();
-
+#ifdef FEAT_TIMERS
+ if (did_add_timer)
+ break;
+#endif
if (pPeekMessage(&msg, NULL, 0, 0, PM_NOREMOVE))
{
process_message();
break;
}
- else if (MsgWaitForMultipleObjects(0, NULL, FALSE, 100, QS_ALLINPUT)
- != WAIT_TIMEOUT)
+ else if (input_available()
+ || MsgWaitForMultipleObjects(0, NULL, FALSE, 100,
+ QS_ALLINPUT) != WAIT_TIMEOUT)
break;
}
#else
- /*
- * Don't use gui_mch_update() because then we will spin-lock until a
- * char arrives, instead we use GetMessage() to hang until an
- * event arrives. No need to check for input_buf_full because we are
- * returning as soon as it contains a single char -- webb
- */
+ // Don't use gui_mch_update() because then we will spin-lock until a
+ // char arrives, instead we use GetMessage() to hang until an
+ // event arrives. No need to check for input_buf_full because we are
+ // returning as soon as it contains a single char -- webb
process_message();
#endif
@@ -2125,9 +2127,9 @@ gui_mch_wait_for_chars(int wtime)
remove_any_timer();
allow_scrollbar = FALSE;
- /* Clear pending mouse button, the release event may have been
- * taken by the dialog window. But don't do this when getting
- * focus, we need the mouse-up event then. */
+ // Clear pending mouse button, the release event may have been
+ // taken by the dialog window. But don't do this when getting
+ // focus, we need the mouse-up event then.
if (!s_getting_focus)
s_button_pending = -1;
@@ -2137,7 +2139,7 @@ gui_mch_wait_for_chars(int wtime)
#ifdef FEAT_TIMERS
if (did_add_timer)
{
- /* Need to recompute the waiting time. */
+ // Need to recompute the waiting time.
remove_any_timer();
break;
}