]> spindle.queued.net Git - midori/commitdiff
Refactor icons handling. Reducing strdups, improve memory cache usage
authorAlexander Butenko <a.butenka@gmail.com>
Thu, 15 Dec 2011 02:06:17 +0000 (22:06 -0400)
committerChristian Dywan <christian@twotoasts.de>
Thu, 15 Dec 2011 23:55:07 +0000 (00:55 +0100)
midori/midori-view.c

index 98fd913a186968ec3c43b4e398b87794de6e8810..0fa485dfda95657bacdc4f9bfb047d7a0da564e7 100644 (file)
@@ -703,7 +703,6 @@ midori_view_mime_icon (MidoriView*   view,
         return FALSE;
     }
 
-    g_object_ref (icon);
     midori_view_apply_icon (view, icon, icon_name);
     g_free (icon_name);
     return TRUE;
@@ -819,17 +818,11 @@ katze_net_icon_transfer_cb (KatzeNetRequest*  request,
                 g_warning ("Error writing to file %s "
                            "in  katze_net_icon_transfer_cb()", priv->icon_file);
             }
-            pixbuf = gdk_pixbuf_new_from_file (priv->icon_file, NULL);
         }
-        else
-            pixbuf = katze_pixbuf_new_from_buffer ((guchar*)request->data,
+        pixbuf = katze_pixbuf_new_from_buffer ((guchar*)request->data,
                             request->length, request->mime_type, NULL);
-
-        if (pixbuf)
-            g_object_ref (pixbuf);
-
         g_hash_table_insert (priv->view->memory,
-                g_strdup (priv->icon_file), pixbuf);
+                             g_strdup (priv->icon_uri), g_object_ref (pixbuf));
     }
 
     if (!pixbuf)
@@ -842,10 +835,8 @@ katze_net_icon_transfer_cb (KatzeNetRequest*  request,
     settings = gtk_widget_get_settings (priv->view->web_view);
     gtk_icon_size_lookup_for_settings (settings, GTK_ICON_SIZE_MENU, &icon_width, &icon_height);
     pixbuf_scaled = gdk_pixbuf_scale_simple (pixbuf, icon_width, icon_height, GDK_INTERP_BILINEAR);
-
     g_object_unref (pixbuf);
 
-    katze_assign (priv->view->icon_uri, g_strdup (priv->icon_uri));
     midori_view_update_icon (priv->view, pixbuf_scaled);
     katze_net_icon_priv_free (priv);
 }
@@ -863,8 +854,7 @@ _midori_web_view_load_icon (MidoriView* view)
 
     if (midori_uri_is_http (view->icon_uri) || midori_uri_is_http (view->uri))
     {
-        gchar* icon_uri = g_strdup (view->icon_uri);
-        if (!icon_uri)
+        if (!view->icon_uri)
         {
             guint i = 8;
             while (view->uri[i] != '\0' && view->uri[i] != '/')
@@ -872,28 +862,22 @@ _midori_web_view_load_icon (MidoriView* view)
             if (view->uri[i] == '/')
             {
                 gchar* path = g_strndup (view->uri, i);
-                icon_uri = g_strdup_printf ("%s/favicon.ico", path);
+                view->icon_uri = g_strdup_printf ("%s/favicon.ico", path);
                 g_free (path);
             }
             else
-                icon_uri = g_strdup_printf ("%s/favicon.ico", view->uri);
+                view->icon_uri = g_strdup_printf ("%s/favicon.ico", view->uri);
         }
 
-        icon_file = katze_net_get_cached_path (NULL, icon_uri, "icons");
-        if (g_hash_table_lookup_extended (view->memory,
-                                          icon_file, NULL, (gpointer)&pixbuf))
-        {
-            g_free (icon_file);
-            if (pixbuf)
-            {
-                g_object_ref (pixbuf);
-                katze_assign (view->icon_uri, icon_uri);
-            }
-        }
-        else if ((pixbuf = gdk_pixbuf_new_from_file (icon_file, NULL)))
+        if ((pixbuf = g_hash_table_lookup (view->memory, view->icon_uri)))
+            goto process_pixbuf;
+
+        icon_file = katze_net_get_cached_path (NULL, view->icon_uri, "icons");
+        if ((pixbuf = gdk_pixbuf_new_from_file (icon_file, NULL)))
         {
+            g_hash_table_insert (view->memory,
+                                 g_strdup (view->icon_uri), g_object_ref (pixbuf));
             g_free (icon_file);
-            katze_assign (view->icon_uri, icon_uri);
         }
         else if (!view->special)
         {
@@ -901,15 +885,16 @@ _midori_web_view_load_icon (MidoriView* view)
 
             priv = g_slice_new (KatzeNetIconPriv);
             priv->icon_file = icon_file;
-            priv->icon_uri = icon_uri;
+            priv->icon_uri = g_strdup (view->icon_uri);
             priv->view = view;
 
-            katze_net_load_uri (NULL, icon_uri,
+            katze_net_load_uri (NULL, priv->icon_uri,
                 (KatzeNetStatusCb)katze_net_icon_status_cb,
                 (KatzeNetTransferCb)katze_net_icon_transfer_cb, priv);
         }
     }
 
+process_pixbuf:
     if (pixbuf)
     {
         settings = gtk_widget_get_settings (view->web_view);