]> granicus.if.org Git - vim/commitdiff
patch 9.0.0984: GUI: remote_foreground() does not always work v9.0.0984
authorBram Moolenaar <Bram@vim.org>
Thu, 1 Dec 2022 19:40:55 +0000 (19:40 +0000)
committerBram Moolenaar <Bram@vim.org>
Thu, 1 Dec 2022 19:40:55 +0000 (19:40 +0000)
Problem:    GUI: remote_foreground() does not always work. (Ron Aaron)
Solution:   For GTK use gtk_window_set_keep_above(). (issue #11641)

src/gui_gtk_x11.c
src/version.c

index 8b75ba8c3ee43ff38d5a4f8d624a7f72f87f4146..ea76e3370aca3573002481c506b21afd0ec80953 100644 (file)
@@ -780,7 +780,8 @@ draw_event(GtkWidget *widget UNUSED,
            for (i = 0; i < list->num_rectangles; i++)
            {
                const cairo_rectangle_t *rect = &list->rectangles[i];
-               cairo_rectangle(cr, rect->x, rect->y, rect->width, rect->height);
+               cairo_rectangle(cr, rect->x, rect->y,
+                                                   rect->width, rect->height);
                cairo_fill(cr);
            }
        }
@@ -6313,7 +6314,17 @@ gui_mch_iconify(void)
     void
 gui_mch_set_foreground(void)
 {
+    // Just calling gtk_window_present() used to work in the past, but now this
+    // sequence appears to be needed:
+    // - Show the window on top of others.
+    // - Present the window (also shows it above others).
+    // - Do not the window on top of others (otherwise it would be stuck there).
+    gtk_window_set_keep_above(GTK_WINDOW(gui.mainwin), TRUE);
+    gui_may_flush();
     gtk_window_present(GTK_WINDOW(gui.mainwin));
+    gui_may_flush();
+    gtk_window_set_keep_above(GTK_WINDOW(gui.mainwin), FALSE);
+    gui_may_flush();
 }
 #endif
 
index e78e71fda9e7e38ade615f15414c04366ad9616e..6f303d1dd0b4967376fde6b1bfdd4671731e08e7 100644 (file)
@@ -695,6 +695,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    984,
 /**/
     983,
 /**/