]> granicus.if.org Git - vim/commitdiff
patch 8.0.1407: GUI: CursorHold may trigger before 'updatetime' v8.0.1407
authorBram Moolenaar <Bram@vim.org>
Tue, 19 Dec 2017 09:02:43 +0000 (10:02 +0100)
committerBram Moolenaar <Bram@vim.org>
Tue, 19 Dec 2017 09:02:43 +0000 (10:02 +0100)
Problem:    GUI: CursorHold may trigger before 'updatetime' when using timers.
Solution:   Check that 'updatetime' has passed.

src/gui.c
src/version.c

index 7026a11d0c967b33b069a441c01b89c04dac3adf..916c9befc6efaa40c536e92f2723e7b5c1c5ff58 100644 (file)
--- a/src/gui.c
+++ b/src/gui.c
@@ -2923,6 +2923,9 @@ gui_wait_for_chars_or_timer(long wtime)
 gui_wait_for_chars(long wtime, int tb_change_cnt)
 {
     int            retval;
+#if defined(ELAPSED_FUNC) && defined(FEAT_AUTOCMD)
+    ELAPSED_TYPE start_tv;
+#endif
 
 #ifdef FEAT_MENU
     /*
@@ -2952,6 +2955,10 @@ gui_wait_for_chars(long wtime, int tb_change_cnt)
        return retval;
     }
 
+#if defined(ELAPSED_FUNC) && defined(FEAT_AUTOCMD)
+    ELAPSED_INIT(start_tv);
+#endif
+
     /*
      * While we are waiting indefinitely for a character, blink the cursor.
      */
@@ -2966,7 +2973,11 @@ gui_wait_for_chars(long wtime, int tb_change_cnt)
     if (gui_wait_for_chars_or_timer(p_ut) == OK)
        retval = OK;
 #ifdef FEAT_AUTOCMD
-    else if (trigger_cursorhold() && typebuf.tb_change_cnt == tb_change_cnt)
+    else if (trigger_cursorhold()
+# ifdef ELAPSED_FUNC
+           && ELAPSED_FUNC(start_tv) >= p_ut
+# endif
+           && typebuf.tb_change_cnt == tb_change_cnt)
     {
        char_u  buf[3];
 
index a2336f8b1a33cdfd92cb6457d20961f23f4b9bd1..c384ff008abe064f8457400cec1b46901e0bf4ec 100644 (file)
@@ -771,6 +771,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1407,
 /**/
     1406,
 /**/