Mercurial > projects > package-update-indicator
changeset 35:c4b8785d0b75
Back out fallback icon support which does not work as intended
The fallback icon support does not work as intended since it depends on
gtk_icon_theme_has_icon() in order to determine whether an icon exists in the
current icon theme. Contrary to the documentation GtkIconTheme not only falls
back to the "hicolor" theme but also to the "Adwaita" and "gnome" themes when
looking for icons. The Adwaita theme provides the "system-software-update",
"software-update-available", and "software-update-urgent" icons so the fallback
will never be used even if the current theme does not provide these icons. SNI
host implementations such as the one in KDE Plasma Shell will only look for
icon names in the current theme and do not fall back to the "Adwaita" and
"gnome" themes.
author | Guido Berhoerster <guido+pui@berhoerster.name> |
---|---|
date | Fri, 06 Sep 2019 13:49:54 +0200 |
parents | cf7c73dfdac0 |
children | 47f93d8de713 |
files | pui-application.c |
diffstat | 1 files changed, 12 insertions(+), 30 deletions(-) [+] |
line wrap: on
line diff
--- a/pui-application.c Fri Aug 30 13:34:00 2019 +0200 +++ b/pui-application.c Fri Sep 06 13:49:54 2019 +0200 @@ -62,19 +62,14 @@ static GParamSpec *properties[PROP_LAST] = { NULL }; -static gchar *icon_names[PUI_STATE_LAST][2] = { - [PUI_STATE_INITIAL] = { "system-software-update", "update-none" }, - [PUI_STATE_UP_TO_DATE] = { "system-software-update", "update-none" }, - [PUI_STATE_NORMAL_UPDATES_AVAILABLE] = { "software-update-available", - "update-medium" }, - [PUI_STATE_IMPORTANT_UPDATES_AVAILABLE] = { "software-update-urgent", - "update-high" }, - [PUI_STATE_SESSION_RESTART_REQUIRED] = { "system-log-out", - "system-log-out" }, - [PUI_STATE_SYSTEM_RESTART_REQUIRED] = { "system-reboot", - "system-reboot" }, - [PUI_STATE_ERROR] = { "dialog-warning", - "dialog-warning" } +static const gchar *icon_names[PUI_STATE_LAST] = { + [PUI_STATE_INITIAL] = "system-software-update", + [PUI_STATE_UP_TO_DATE] = "system-software-update", + [PUI_STATE_NORMAL_UPDATES_AVAILABLE] = "software-update-available", + [PUI_STATE_IMPORTANT_UPDATES_AVAILABLE] = "software-update-urgent", + [PUI_STATE_SESSION_RESTART_REQUIRED] = "system-log-out", + [PUI_STATE_SYSTEM_RESTART_REQUIRED] = "system-reboot", + [PUI_STATE_ERROR] = "dialog-warning" }; static const GOptionEntry cmd_options[] = { @@ -201,9 +196,6 @@ guint normal_updates = 0; gchar *title = NULL; gchar *body = NULL; - GtkIconTheme *icon_theme; - const gchar * const *icon_namep; - const gchar *icon_name; GApplication *application = G_APPLICATION(self); GNotification *notification = NULL; @@ -309,18 +301,8 @@ APP_INDICATOR_STATUS_ACTIVE); break; } - - /* determine icon name using fallbacks if necessary */ - icon_theme = gtk_icon_theme_get_default(); - for (icon_namep = - g_themed_icon_get_names(G_THEMED_ICON(self->icons[self->state])), - icon_name = *icon_namep; *icon_namep != NULL; icon_namep++) { - if (gtk_icon_theme_has_icon(icon_theme, *icon_namep)) { - icon_name = *icon_namep; - break; - } - } - app_indicator_set_icon_full(self->indicator, icon_name, title); + app_indicator_set_icon_full(self->indicator, icon_names[self->state], + title); /* notification */ switch (self->state) { @@ -356,7 +338,7 @@ } g_debug("indicator icon: %s, notification title: \"%s\", " - "notification body: \"%s\"", icon_name, title, body); + "notification body: \"%s\"", icon_names[self->state], title, body); g_free(body); g_free(title); @@ -493,7 +475,7 @@ /* load icons */ for (i = 0; i < G_N_ELEMENTS(self->icons); i++) { - self->icons[i] = g_themed_icon_new_from_names(icon_names[i], 2); + self->icons[i] = g_themed_icon_new(icon_names[i]); } /* create settings */