summaryrefslogtreecommitdiffstats
path: root/src/gui_gtk_x11.c
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2016-03-05 22:40:52 +0100
committerBram Moolenaar <Bram@vim.org>2016-03-05 22:40:52 +0100
commit0ecbe33718b06a3771fd2c65b331c8c9504657d7 (patch)
tree2feaf227ba894d6b9203511c3dde1332987ba1c8 /src/gui_gtk_x11.c
parenta96909cfaf21dbbf033e904ccdcda9905799f0fc (diff)
patch 7.4.1497v7.4.1497
Problem: Cursor drawing problem with GTK 3. Solution: Handle blinking differently. (Kazunobu Kuriyama)
Diffstat (limited to 'src/gui_gtk_x11.c')
-rw-r--r--src/gui_gtk_x11.c33
1 files changed, 24 insertions, 9 deletions
diff --git a/src/gui_gtk_x11.c b/src/gui_gtk_x11.c
index d43191cc3d..3ee2957709 100644
--- a/src/gui_gtk_x11.c
+++ b/src/gui_gtk_x11.c
@@ -617,9 +617,9 @@ visibility_event(GtkWidget *widget UNUSED,
*/
#if GTK_CHECK_VERSION(3,0,0)
static gboolean is_key_pressed = FALSE;
+static gboolean blink_mode = TRUE;
static gboolean gui_gtk_is_blink_on(void);
-static gboolean gui_gtk_is_no_blink(void);
static void gui_gtk_window_clear(GdkWindow *win);
static void
@@ -649,7 +649,6 @@ gui_gtk3_should_draw_cursor(void)
cond |= gui_gtk_is_blink_on();
cond |= is_key_pressed;
cond |= gui.in_focus == FALSE;
- cond |= gui_gtk_is_no_blink();
return cond;
}
@@ -681,7 +680,10 @@ draw_event(GtkWidget *widget,
for (i = 0; i < list->num_rectangles; i++)
{
const cairo_rectangle_t rect = list->rectangles[i];
- gui_gtk3_redraw(rect.x, rect.y, rect.width, rect.height);
+ if (blink_mode)
+ gui_gtk3_redraw(rect.x, rect.y, rect.width, rect.height);
+ else
+ gui_redraw(rect.x, rect.y, rect.width, rect.height);
}
}
cairo_rectangle_list_destroy(list);
@@ -790,20 +792,33 @@ gui_gtk_is_blink_on(void)
{
return blink_state == BLINK_ON;
}
-
- static gboolean
-gui_gtk_is_no_blink(void)
-{
- return blink_waittime == 0 || blink_ontime == 0 || blink_offtime == 0;
-}
#endif
void
gui_mch_set_blinking(long waittime, long on, long off)
{
+#if GTK_CHECK_VERSION(3,0,0)
+ if (waittime == 0 || on == 0 || off == 0)
+ {
+ blink_mode = FALSE;
+
+ blink_waittime = 700;
+ blink_ontime = 400;
+ blink_offtime = 250;
+ }
+ else
+ {
+ blink_mode = TRUE;
+
+ blink_waittime = waittime;
+ blink_ontime = on;
+ blink_offtime = off;
+ }
+#else
blink_waittime = waittime;
blink_ontime = on;
blink_offtime = off;
+#endif
}
/*