[Xfce4-commits] <midori:master> Don't queue thumbs already waiting, 5 seconds timeout
Christian Dywan
noreply at xfce.org
Mon Oct 31 04:04:01 CET 2011
Updating branch refs/heads/master
to 55227d2a3bc2330783757948553fa0ca901d3311 (commit)
from 6ea98c6569b31d72b3162d237f192529fa83541f (commit)
commit 55227d2a3bc2330783757948553fa0ca901d3311
Author: Christian Dywan <christian at twotoasts.de>
Date: Mon Oct 31 03:56:02 2011 +0100
Don't queue thumbs already waiting, 5 seconds timeout
midori/midori-view.c | 52 +++++++++++++++++++++++++++++++++++++++++++++++--
1 files changed, 49 insertions(+), 3 deletions(-)
diff --git a/midori/midori-view.c b/midori/midori-view.c
index ca0d611..3f73dfb 100644
--- a/midori/midori-view.c
+++ b/midori/midori-view.c
@@ -69,6 +69,9 @@ midori_view_speed_dial_get_thumb (MidoriView* view,
gchar* dial_id,
gchar* url);
+static void
+midori_view_speed_dial_thumb_apply (MidoriView* view);
+
struct _MidoriView
{
GtkVBox parent_instance;
@@ -195,6 +198,7 @@ static guint signals[LAST_SIGNAL];
static gchar* speeddial_markup = NULL;
static GtkWidget* thumb_view = NULL;
static GList* thumb_queue = NULL;
+static guint thumb_timeout = 0;
static void
midori_view_finalize (GObject* object);
@@ -5346,6 +5350,22 @@ thumb_view_load_status_cb (WebKitWebView* thumb_view_,
GParamSpec* pspec,
MidoriView* view)
{
+ if (webkit_web_view_get_load_status (thumb_view_) != WEBKIT_LOAD_FINISHED)
+ return;
+
+ midori_view_speed_dial_thumb_apply (view);
+}
+
+static void
+midori_view_speed_dial_thumb_timeout (MidoriView* view)
+{
+ webkit_web_view_stop_loading (WEBKIT_WEB_VIEW (thumb_view));
+ midori_view_speed_dial_thumb_apply (view);
+}
+
+static void
+midori_view_speed_dial_thumb_apply (MidoriView* view)
+{
GdkPixbuf* img;
#if HAVE_OFFSCREEN
GdkPixbuf* pixbuf_scaled;
@@ -5359,8 +5379,8 @@ thumb_view_load_status_cb (WebKitWebView* thumb_view_,
GKeyFile* key_file;
const gchar* title;
- if (webkit_web_view_get_load_status (thumb_view_) != WEBKIT_LOAD_FINISHED)
- return;
+ if (thumb_timeout > 0)
+ g_source_remove (thumb_timeout);
spec = g_object_get_data (G_OBJECT (thumb_view), "spec");
url = strstr (spec, "|") + 1;
@@ -5398,6 +5418,10 @@ thumb_view_load_status_cb (WebKitWebView* thumb_view_,
thumb_queue = g_list_remove (thumb_queue, spec);
if (thumb_queue != NULL)
{
+ /* At best wait 5 seconds for a single thumbnail to load */
+ thumb_timeout = g_timeout_add_seconds (5,
+ (GSourceFunc)midori_view_speed_dial_thumb_timeout, view);
+
g_object_set_data_full (G_OBJECT (thumb_view), "spec",
thumb_queue->data, (GDestroyNotify)g_free);
webkit_web_view_open (WEBKIT_WEB_VIEW (thumb_view),
@@ -5408,6 +5432,14 @@ thumb_view_load_status_cb (WebKitWebView* thumb_view_,
thumb_view, thumb_view_load_status_cb, view);
}
+static gint
+midori_view_speed_dial_thumb_cf (gconstpointer spec1,
+ gconstpointer spec2)
+{
+ /* Compare URL without dial id */
+ return strcmp (strstr (spec1, "|") + 1, strstr (spec2, "|") + 1);
+}
+
/**
* midori_view_speed_dial_get_thumb
* @view: a #MidoriView
@@ -5421,6 +5453,7 @@ midori_view_speed_dial_get_thumb (MidoriView* view,
{
WebKitWebSettings* settings;
GtkWidget* browser;
+ gchar* spec;
#if !HAVE_OFFSCREEN
GtkWidget* notebook;
GtkWidget* label;
@@ -5470,10 +5503,23 @@ midori_view_speed_dial_get_thumb (MidoriView* view,
g_object_unref (notebook);
#endif
- thumb_queue = g_list_append (thumb_queue, g_strconcat (dial_id, "|", url, NULL));
+ spec = g_strconcat (dial_id, "|", url, NULL);
+ /* If spec is already queued, there's nothing to be done */
+ if (g_list_find_custom (thumb_queue, spec, midori_view_speed_dial_thumb_cf))
+ {
+ g_free (spec);
+ return;
+ }
+ thumb_queue = g_list_append (thumb_queue, spec);
if (g_list_nth_data (thumb_queue, 1) != NULL)
return;
+ /* At best wait 5 seconds for a single thumbnail to load */
+ if (thumb_timeout > 0)
+ g_source_remove (thumb_timeout);
+ thumb_timeout = g_timeout_add_seconds (5,
+ (GSourceFunc)midori_view_speed_dial_thumb_timeout, view);
+
g_object_set_data_full (G_OBJECT (thumb_view), "spec",
thumb_queue->data, (GDestroyNotify)g_free);
g_signal_connect (thumb_view, "notify::load-status",
More information about the Xfce4-commits
mailing list