diff options
-rw-r--r-- | ChangeLog | 8 | ||||
-rw-r--r-- | src/bookmarks/ephy-bookmark-action.c | 30 |
2 files changed, 37 insertions, 1 deletions
@@ -1,3 +1,11 @@ +2004-03-03 Christian Persch <chpe@cvs.gnome.org> + + * src/bookmarks/ephy-bookmark-action.c: (favicon_cache_changed_cb), + (ephy_bookmark_action_sync_icon), (ephy_bookmark_action_init): + + If the favicon isn't ready when we need it, connect to the favicon + cache's ::changed signal to show it when we have it. Fixes bug #135855. + 2004-03-02 Marco Pesenti Gritti <marco@gnome.org> * src/ephy-tab.c: (ephy_tab_destroy_brsr_cb): diff --git a/src/bookmarks/ephy-bookmark-action.c b/src/bookmarks/ephy-bookmark-action.c index 68bad78fd..ebaf2c5a5 100644 --- a/src/bookmarks/ephy-bookmark-action.c +++ b/src/bookmarks/ephy-bookmark-action.c @@ -33,6 +33,8 @@ #include "ephy-string.h" #include "ephy-debug.h" +#include <string.h> + #define MAX_LABEL_LENGTH 32 static void ephy_bookmark_action_init (EphyBookmarkAction *action); @@ -46,6 +48,7 @@ struct EphyBookmarkActionPrivate char *location; gboolean smart_url; char *icon; + guint cache_connection; }; enum @@ -159,13 +162,28 @@ ephy_bookmark_action_sync_smart_url (GtkAction *action, GParamSpec *pspec, GtkWi } static void +favicon_cache_changed_cb (EphyFaviconCache *cache, + const char *icon, + EphyBookmarkAction *action) +{ + if (action->priv->icon && strcmp (icon, action->priv->icon) == 0) + { + g_signal_handler_disconnect (cache, action->priv->cache_connection); + action->priv->cache_connection = 0; + + g_object_notify (G_OBJECT (action), "icon"); + } +} + +static void ephy_bookmark_action_sync_icon (GtkAction *action, GParamSpec *pspec, GtkWidget *proxy) { + EphyBookmarkAction *bma = EPHY_BOOKMARK_ACTION (action); char *icon_location; EphyFaviconCache *cache; GdkPixbuf *pixbuf = NULL; - icon_location = EPHY_BOOKMARK_ACTION (action)->priv->icon; + icon_location = bma->priv->icon; cache = EPHY_FAVICON_CACHE (ephy_embed_shell_get_favicon_cache (EPHY_EMBED_SHELL (ephy_shell))); @@ -173,6 +191,15 @@ ephy_bookmark_action_sync_icon (GtkAction *action, GParamSpec *pspec, GtkWidget if (icon_location) { pixbuf = ephy_favicon_cache_get (cache, icon_location); + + if (pixbuf == NULL && bma->priv->cache_connection == 0) + { + bma->priv->cache_connection = + g_signal_connect_object + (cache, "changed", + G_CALLBACK (favicon_cache_changed_cb), + action, 0); + } } if (pixbuf == NULL) return; @@ -557,6 +584,7 @@ ephy_bookmark_action_init (EphyBookmarkAction *action) action->priv->location = NULL; action->priv->icon = NULL; + action->priv->cache_connection = 0; bookmarks = ephy_shell_get_bookmarks (ephy_shell); node = ephy_bookmarks_get_bookmarks (bookmarks); |