]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 9.1.1583: gvim window lost its icons v9.1.1583
authorOlaf Seibert <rhialto@falu.nl>
Wed, 23 Jul 2025 17:35:59 +0000 (19:35 +0200)
committerChristian Brabandt <cb@256bit.org>
Wed, 23 Jul 2025 17:35:59 +0000 (19:35 +0200)
Problem:  Since patch 9.1.1199 the gvim window no longer had _NET_WM_ICON
          nor WM_HINTS icon information, for example when not using a
  Gnome or KDE desktop (after v9.1.1199)
Solution: Check if the icon theme as used in patch 1199 contains a gvim
          icon. If so, set the window's icon from that. Otherwise
  use the previous method (Olaf Seibert)

fixes: #17703
closes: #17814

Signed-off-by: Olaf Seibert <rhialto@falu.nl>
Signed-off-by: Christian Brabandt <cb@256bit.org>
src/gui_gtk_x11.c
src/version.c

index c000a1181f74019823a2ae809e61c49a7bebaaf6..49ed4271d72646df46efda31f8c1c8ad29908900 100644 (file)
@@ -2704,6 +2704,10 @@ global_event_filter(GdkXEvent *xev,
     static void
 mainwin_realize(GtkWidget *widget UNUSED, gpointer data UNUSED)
 {
+#include "../runtime/vim16x16.xpm"
+#include "../runtime/vim32x32.xpm"
+#include "../runtime/vim48x48.xpm"
+
     GdkWindow * const mainwin_win = gtk_widget_get_window(gui.mainwin);
 
     // When started with "--echo-wid" argument, write window ID on stdout.
@@ -2718,10 +2722,32 @@ mainwin_realize(GtkWidget *widget UNUSED, gpointer data UNUSED)
 
     if (vim_strchr(p_go, GO_ICON) != NULL)
     {
-       /*
-        * Add an icon to the main window. For fun and convenience of the user.
-        */
-       gtk_window_set_icon_name(GTK_WINDOW(gui.mainwin), "gvim");
+       GtkIconTheme *icon_theme;
+
+       icon_theme = gtk_icon_theme_get_default();
+
+       if (icon_theme && gtk_icon_theme_has_icon(icon_theme, "gvim"))
+       {
+           gtk_window_set_icon_name(GTK_WINDOW(gui.mainwin), "gvim");
+       }
+       else
+       {
+           /*
+            * Add an icon to the main window. For fun and convenience of the user.
+            */
+           GList *icons = NULL;
+
+           icons = g_list_prepend(icons, gdk_pixbuf_new_from_xpm_data((const char **)vim16x16));
+           icons = g_list_prepend(icons, gdk_pixbuf_new_from_xpm_data((const char **)vim32x32));
+           icons = g_list_prepend(icons, gdk_pixbuf_new_from_xpm_data((const char **)vim48x48));
+
+           gtk_window_set_icon_list(GTK_WINDOW(gui.mainwin), icons);
+
+           // TODO: is this type cast OK?
+           g_list_foreach(icons, (GFunc)(void *)&g_object_unref, NULL);
+           g_list_free(icons);
+       }
+       g_object_unref(icon_theme);
     }
 
 #if !defined(USE_GNOME_SESSION)
index 68bd2f6390b82653e18f6b6d6b44758f360ba327..440ad944458c8fbde9de0d9051ae4104305e8f19 100644 (file)
@@ -719,6 +719,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1583,
 /**/
     1582,
 /**/