aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--embed/ephy-web-view.c128
1 files changed, 66 insertions, 62 deletions
diff --git a/embed/ephy-web-view.c b/embed/ephy-web-view.c
index 68ecd91f1..885c72541 100644
--- a/embed/ephy-web-view.c
+++ b/embed/ephy-web-view.c
@@ -33,6 +33,7 @@
#include "ephy-embed-type-builtins.h"
#include "ephy-embed-utils.h"
#include "ephy-embed.h"
+#include "ephy-favicon-helpers.h"
#include "ephy-file-helpers.h"
#include "ephy-file-monitor.h"
#include "ephy-history-service.h"
@@ -652,7 +653,6 @@ find_username_and_password_elements (WebKitDOMNode *form_node,
g_object_unref(elements);
}
-#endif
typedef struct {
EphyEmbed *embed;
@@ -801,9 +801,6 @@ should_store_cb (GnomeKeyringResult retval,
request_decision_on_storing (store_data);
}
-#ifdef HAVE_WEBKIT2
-/* TODO: DOM bindings */
-#else
static gboolean
form_submitted_cb (WebKitDOMHTMLFormElement *dom_form,
WebKitDOMEvent *dom_event,
@@ -1086,6 +1083,52 @@ ephy_web_view_history_cleared_cb (EphyHistoryService *history_service,
}
static void
+_ephy_web_view_update_icon (EphyWebView *view)
+{
+ GObject *object = G_OBJECT (view);
+ EphyWebViewPrivate *priv = view->priv;
+
+ if (priv->icon != NULL) {
+ g_object_unref (priv->icon);
+ priv->icon = NULL;
+ }
+
+ if (priv->address) {
+#ifdef HAVE_WEBKIT2
+ cairo_surface_t *icon_surface = webkit_web_view_get_favicon (WEBKIT_WEB_VIEW (view));
+ if (icon_surface)
+ priv->icon = ephy_pixbuf_get_from_surface_scaled (icon_surface, FAVICON_SIZE, FAVICON_SIZE);
+#else
+ priv->icon = webkit_favicon_database_try_get_favicon_pixbuf (webkit_get_favicon_database (),
+ webkit_web_view_get_uri (WEBKIT_WEB_VIEW (view)),
+ FAVICON_SIZE, FAVICON_SIZE);
+#endif
+ }
+
+ g_object_notify (G_OBJECT (view), "icon");
+}
+
+#ifdef HAVE_WEBKIT2
+static void
+icon_changed_cb (EphyWebView *view,
+ GParamSpec *pspec,
+ gpointer user_data)
+{
+ _ephy_web_view_update_icon (view);
+}
+
+#else
+
+static void
+icon_loaded_cb (EphyWebView *view,
+ const char *address,
+ gpointer user_data)
+{
+ _ephy_web_view_update_icon (view);
+}
+#endif
+
+static void
ephy_web_view_finalize (GObject *object)
{
EphyWebViewPrivate *priv = EPHY_WEB_VIEW (object)->priv;
@@ -1094,6 +1137,10 @@ ephy_web_view_finalize (GObject *object)
ephy_web_view_history_cleared_cb,
EPHY_WEB_VIEW (object));
+#ifdef HAVE_WEBKIT2
+ g_signal_handlers_disconnect_by_func (object, icon_changed_cb, NULL);
+#endif
+
if (priv->non_search_regex) {
g_regex_unref (priv->non_search_regex);
priv->non_search_regex = NULL;
@@ -1178,6 +1225,7 @@ title_changed_cb (WebKitWebView *web_view,
const char *uri;
char *title;
EphyHistoryService *history = EPHY_WEB_VIEW (web_view)->priv->history_service;
+
#ifndef HAVE_WEBKIT2
WebKitWebFrame *frame;
@@ -1292,6 +1340,7 @@ ephy_web_view_constructed (GObject *object)
* have both enabled at the same time in WebKit now (although our
* API does not reflect this atm). See r67274 in WebKit. */
#ifndef HAVE_WEBKIT2
+
/* This is the default behaviour in WebKit2 */
webkit_web_view_set_full_content_zoom (WEBKIT_WEB_VIEW (object), TRUE);
#endif
@@ -1682,52 +1731,6 @@ ephy_web_view_class_init (EphyWebViewClass *klass)
g_type_class_add_private (gobject_class, sizeof (EphyWebViewPrivate));
}
-#ifdef HAVE_WEBKIT2
-/* TODO: Favicons */
-#else
-static void
-_ephy_web_view_load_icon (EphyWebView *view)
-{
- EphyWebViewPrivate *priv = view->priv;
- const char* uri;
-
- if (priv->icon != NULL)
- return;
-
- uri = webkit_web_view_get_uri (WEBKIT_WEB_VIEW (view));
- priv->icon = webkit_favicon_database_try_get_favicon_pixbuf (webkit_get_favicon_database (), uri,
- FAVICON_SIZE, FAVICON_SIZE);
-
- g_object_notify (G_OBJECT (view), "icon");
-}
-
-static void
-_ephy_web_view_set_icon_address (EphyWebView *view,
- const char *icon_address)
-{
- GObject *object = G_OBJECT (view);
- EphyWebViewPrivate *priv = view->priv;
-
- if (priv->icon != NULL) {
- g_object_unref (priv->icon);
- priv->icon = NULL;
-
- g_object_notify (object, "icon");
- }
-
- if (icon_address && priv->address)
- _ephy_web_view_load_icon (view);
-}
-
-static void
-favicon_cb (EphyWebView *view,
- const char *address,
- gpointer user_data)
-{
- _ephy_web_view_set_icon_address (view, address);
-}
-#endif
-
static void
new_window_cb (EphyWebView *view,
EphyWebView *new_view,
@@ -2085,11 +2088,8 @@ ephy_web_view_location_changed (EphyWebView *view,
}
ephy_web_view_set_link_message (view, NULL);
-#ifdef HAVE_WEBKIT2
- /* TODO: Favicons */
-#else
- _ephy_web_view_set_icon_address (view, NULL);
-#endif
+
+ _ephy_web_view_update_icon (view);
update_navigation_flags (view);
@@ -2252,6 +2252,9 @@ load_changed_cb (WebKitWebView *web_view,
if (uri)
soup_uri_free (uri);
+ /* Ensure we load the icon for this web view, if available. */
+ _ephy_web_view_update_icon (view);
+
/* Reset visit type. */
priv->visit_type = EPHY_PAGE_VISIT_NONE;
@@ -2532,11 +2535,8 @@ ephy_web_view_load_error_page (EphyWebView *view,
g_file_get_contents (html_file, &template, NULL, NULL);
ephy_web_view_set_title (view, page_title);
-#ifdef HAVE_WEBKIT2
- /* TODO: Favicons */
-#else
- _ephy_web_view_set_icon_address (view, NULL);
-#endif
+
+ _ephy_web_view_update_icon (view);
g_string_printf (html, template,
lang, lang,
@@ -2840,10 +2840,12 @@ ephy_web_view_init (EphyWebView *web_view)
#endif
#ifdef HAVE_WEBKIT2
- /* TODO: Favicons */
+ g_signal_connect (web_view, "notify::favicon",
+ G_CALLBACK (icon_changed_cb),
+ NULL);
#else
g_signal_connect (web_view, "icon-loaded",
- G_CALLBACK (favicon_cb),
+ G_CALLBACK (icon_loaded_cb),
NULL);
#endif
@@ -3009,6 +3011,7 @@ ephy_web_view_load_request (EphyWebView *view,
#endif
}
+#ifndef HAVE_WEBKIT2
typedef struct {
EphyWebView *view;
char *original_uri;
@@ -3048,6 +3051,7 @@ effective_url_head_cb (SoupSession *session,
g_free (data->original_uri);
g_slice_free (HEADAttemptData, data);
}
+#endif
/**
* ephy_web_view_load_url: