diff options
author | Alejandro G. Castro <alex@igalia.com> | 2010-04-30 01:25:29 +0800 |
---|---|---|
committer | Alejandro G. Castro <alex@igalia.com> | 2010-05-03 18:50:41 +0800 |
commit | d60afa35bed002f98996fbdeb6a34ad01cc5b2cf (patch) | |
tree | 8a157809046533a3a9de04cbe19b8e5d4a52c087 | |
parent | 4e914078cd832490b1d31804836f3ac2274fdaf0 (diff) | |
download | gsoc2013-epiphany-d60afa35bed002f98996fbdeb6a34ad01cc5b2cf.tar gsoc2013-epiphany-d60afa35bed002f98996fbdeb6a34ad01cc5b2cf.tar.gz gsoc2013-epiphany-d60afa35bed002f98996fbdeb6a34ad01cc5b2cf.tar.bz2 gsoc2013-epiphany-d60afa35bed002f98996fbdeb6a34ad01cc5b2cf.tar.lz gsoc2013-epiphany-d60afa35bed002f98996fbdeb6a34ad01cc5b2cf.tar.xz gsoc2013-epiphany-d60afa35bed002f98996fbdeb6a34ad01cc5b2cf.tar.zst gsoc2013-epiphany-d60afa35bed002f98996fbdeb6a34ad01cc5b2cf.zip |
Refactored the load status callback of ephy-web-view.c
This patch uses the ephy-embed.c callback code and refactors it in
just one method in the ephy-web-view that handles all the status
changes for this object.
Bug #593743
-rw-r--r-- | embed/ephy-embed.c | 70 | ||||
-rw-r--r-- | embed/ephy-web-view.c | 241 | ||||
-rw-r--r-- | embed/ephy-web-view.h | 3 |
3 files changed, 113 insertions, 201 deletions
diff --git a/embed/ephy-embed.c b/embed/ephy-embed.c index 878cd36f1..87db4ffe2 100644 --- a/embed/ephy-embed.c +++ b/embed/ephy-embed.c @@ -62,7 +62,6 @@ struct EphyEmbedPrivate WebKitWebView *web_view; EphyHistory *history; GtkWidget *inspector_window; - char *loading_uri; guint is_setting_zoom : 1; GSList *destroy_on_transition_list; }; @@ -196,87 +195,20 @@ load_status_changed_cb (WebKitWebView *view, GParamSpec *spec, EphyEmbed *embed) { - EphyEmbedPrivate *priv = embed->priv; WebKitLoadStatus status = webkit_web_view_get_load_status (view); if (status == WEBKIT_LOAD_COMMITTED) { const gchar* uri; - EphyWebViewSecurityLevel security_level; uri = webkit_web_view_get_uri (view); ephy_embed_destroy_top_widgets (embed); - if (g_strcmp0 (uri, priv->loading_uri) != 0) { - g_free (priv->loading_uri); - priv->loading_uri = g_strdup (uri); - } - - ephy_web_view_location_changed (EPHY_WEB_VIEW (view), - uri); restore_zoom_level (embed, uri); ephy_history_add_page (embed->priv->history, uri, FALSE, FALSE); - -#ifdef GTLS_SYSTEM_CA_FILE - if (uri && g_str_has_prefix (uri, "https")) { - WebKitWebFrame *frame; - WebKitWebDataSource *source; - WebKitNetworkRequest *request; - SoupMessage *message; - - frame = webkit_web_view_get_main_frame (view); - source = webkit_web_frame_get_data_source (frame); - request = webkit_web_data_source_get_request (source); - message = webkit_network_request_get_message (request); - - if (message && - (soup_message_get_flags (message) & SOUP_MESSAGE_CERTIFICATE_TRUSTED)) - security_level = EPHY_WEB_VIEW_STATE_IS_SECURE_HIGH; - else - security_level = EPHY_WEB_VIEW_STATE_IS_BROKEN; - } else - security_level = EPHY_WEB_VIEW_STATE_IS_UNKNOWN; -#else - security_level = EPHY_WEB_VIEW_STATE_IS_UNKNOWN; -#endif - - ephy_web_view_set_security_level (EPHY_WEB_VIEW (view), security_level); - } else if (status == WEBKIT_LOAD_PROVISIONAL || status == WEBKIT_LOAD_FINISHED) { - char *loading_uri = NULL; - - if (status == WEBKIT_LOAD_PROVISIONAL) { - WebKitWebFrame *frame; - WebKitWebDataSource *source; - WebKitNetworkRequest *request; - - frame = webkit_web_view_get_main_frame (view); - source = webkit_web_frame_get_provisional_data_source (frame); - request = webkit_web_data_source_get_initial_request (source); - loading_uri = g_strdup (webkit_network_request_get_uri (request)); - - /* We also store the URI we are currently loading here, because - * we will want to use it in WEBKIT_LOAD_FINISHED, because if a - * load fails we may never get to committed */ - priv->loading_uri = g_strdup (loading_uri); - - g_signal_emit_by_name (EPHY_WEB_VIEW (view), "new-document-now", loading_uri); - } else if (status == WEBKIT_LOAD_FINISHED) { - loading_uri = priv->loading_uri; - - /* Will be freed below */ - priv->loading_uri = NULL; - - } - - ephy_web_view_update_from_net_state (EPHY_WEB_VIEW (view), - loading_uri, - status); - - g_free (loading_uri); - } } @@ -347,8 +279,6 @@ ephy_embed_finalize (GObject *object) EphyEmbed *embed = EPHY_EMBED (object); GSList *list; - g_free (embed->priv->loading_uri); - list = embed->priv->destroy_on_transition_list; for (; list; list = list->next) { GtkWidget *widget = GTK_WIDGET (list->data); diff --git a/embed/ephy-web-view.c b/embed/ephy-web-view.c index 26c5f3dd5..4fa85d126 100644 --- a/embed/ephy-web-view.c +++ b/embed/ephy-web-view.c @@ -1894,19 +1894,129 @@ mime_type_policy_decision_requested_cb (WebKitWebView *web_view, } static void +update_navigation_flags (EphyWebView *view) +{ + EphyWebViewPrivate *priv = view->priv; + guint flags = 0; + WebKitWebView *web_view = WEBKIT_WEB_VIEW (view); + + if (ephy_web_view_can_go_up (view)) + flags |= EPHY_WEB_VIEW_NAV_UP; + + if (webkit_web_view_can_go_back (web_view)) + flags |= EPHY_WEB_VIEW_NAV_BACK; + + if (webkit_web_view_can_go_forward (web_view)) + flags |= EPHY_WEB_VIEW_NAV_FORWARD; + + if (priv->nav_flags != (EphyWebViewNavigationFlags)flags) { + priv->nav_flags = (EphyWebViewNavigationFlags)flags; + + g_object_notify (G_OBJECT (view), "navigation"); + } +} + +static void load_status_cb (WebKitWebView *web_view, GParamSpec *pspec, gpointer user_data) { WebKitLoadStatus status = webkit_web_view_get_load_status (web_view); + EphyWebView *view = EPHY_WEB_VIEW (web_view); + EphyWebViewPrivate *priv = view->priv; + GObject *object = G_OBJECT (web_view); + + g_object_freeze_notify (object); + + switch (status) + { + /* FIXME: add REDIRECTING and NEGOTIATING states to WebKitGTK */ + case WEBKIT_LOAD_PROVISIONAL: + { + const gchar *loading_uri = NULL; + WebKitWebFrame *frame; + + WebKitWebDataSource *source; + WebKitNetworkRequest *request; + + frame = webkit_web_view_get_main_frame (web_view); + + source = webkit_web_frame_get_provisional_data_source (frame); + request = webkit_web_data_source_get_initial_request (source); + loading_uri = webkit_network_request_get_uri (request); + + g_signal_emit_by_name (view, "new-document-now", loading_uri); + + if ((priv->address == NULL || priv->address[0] == '\0') && + priv->expire_address_now == TRUE) + ephy_web_view_set_address (view, loading_uri); + + g_free (priv->status_message); + priv->status_message = g_strdup (priv->loading_title); + g_object_notify (object, "status-message"); + + ephy_web_view_set_title (view, NULL); + ephy_web_view_set_loading_title (view, loading_uri, TRUE); + priv->expire_address_now = TRUE; + } + break; + case WEBKIT_LOAD_COMMITTED: + { + const gchar* uri; + EphyWebViewSecurityLevel security_level; + + uri = webkit_web_view_get_uri (web_view); + ephy_web_view_location_changed (view, + uri); + + ephy_web_view_set_title (view, NULL); + +#ifdef GTLS_SYSTEM_CA_FILE + if (uri && g_str_has_prefix (uri, "https")) { + WebKitWebFrame *frame; + WebKitWebDataSource *source; + WebKitNetworkRequest *request; + SoupMessage *message; + + frame = webkit_web_view_get_main_frame (WEBKIT_WEB_VIEW(view)); + source = webkit_web_frame_get_data_source (frame); + request = webkit_web_data_source_get_request (source); + message = webkit_network_request_get_message (request); + + if (message && + (soup_message_get_flags (message) & SOUP_MESSAGE_CERTIFICATE_TRUSTED)) + security_level = EPHY_WEB_VIEW_STATE_IS_SECURE_HIGH; + else + security_level = EPHY_WEB_VIEW_STATE_IS_BROKEN; + } else + security_level = EPHY_WEB_VIEW_STATE_IS_UNKNOWN; +#else + security_level = EPHY_WEB_VIEW_STATE_IS_UNKNOWN; +#endif + + ephy_web_view_set_security_level (EPHY_WEB_VIEW (web_view), security_level); + } + break; + case WEBKIT_LOAD_FINISHED: + g_free (priv->status_message); + priv->status_message = NULL; + g_object_notify (object, "status-message"); + ephy_web_view_set_loading_title (view, NULL, FALSE); + + if (ephy_web_view_get_is_blank (view)) + g_object_notify (object, "embed-title"); - if (status == WEBKIT_LOAD_FINISHED) { if (ephy_has_private_profile () == FALSE && eel_gconf_get_boolean (CONF_PRIVACY_REMEMBER_PASSWORDS)) - _ephy_web_view_hook_into_forms (EPHY_WEB_VIEW (web_view)); + _ephy_web_view_hook_into_forms (view); - _ephy_web_view_hook_into_links (EPHY_WEB_VIEW (web_view)); + _ephy_web_view_hook_into_links (view); + break; + default: + break; } + + g_object_thaw_notify (object); } static gboolean @@ -2045,32 +2155,6 @@ normalize_or_autosearch_url (EphyWebView *view, const char *url) return effective_url; } -static void -update_navigation_flags (EphyWebView *view) -{ - EphyWebViewPrivate *priv = view->priv; - guint flags = 0; - WebKitWebView *web_view = WEBKIT_WEB_VIEW (view); - - if (ephy_web_view_can_go_up (view)) { - flags |= EPHY_WEB_VIEW_NAV_UP; - } - - if (webkit_web_view_can_go_back (web_view)) { - flags |= EPHY_WEB_VIEW_NAV_BACK; - } - - if (webkit_web_view_can_go_forward (web_view)) { - flags |= EPHY_WEB_VIEW_NAV_FORWARD; - } - - if (priv->nav_flags != (EphyWebViewNavigationFlags)flags) { - priv->nav_flags = (EphyWebViewNavigationFlags)flags; - - g_object_notify (G_OBJECT (view), "navigation"); - } -} - /** * ephy_web_view_load_request: * @view: the #EphyWebView in which to load the request @@ -2323,105 +2407,6 @@ ephy_web_view_get_title (EphyWebView *view) return view->priv->title; } -static void -ensure_page_info (EphyWebView *view, const char *address) -{ - EphyWebViewPrivate *priv = view->priv; - - if ((priv->address == NULL || priv->address[0] == '\0') && - priv->expire_address_now == TRUE) { - ephy_web_view_set_address (view, address); - } - - /* FIXME huh?? */ - if (priv->title == NULL || priv->title[0] == '\0') { - ephy_web_view_set_title (view, NULL); - } -} - -static void -update_net_state_message (EphyWebView *view, const char *uri, WebKitLoadStatus status) -{ - const char *msg = NULL; - char *host = NULL; - - if (uri != NULL) - host = ephy_string_get_host_name (uri); - - if (host == NULL) goto out; - - /* FIXME: add REDIRECTING and NEGOTIATING states to WebKitGTK */ - if (status == WEBKIT_LOAD_PROVISIONAL) { - msg = _ ("Loading ā%sāā¦"); - } - - if (status == WEBKIT_LOAD_FINISHED) { - g_free (view->priv->status_message); - view->priv->status_message = NULL; - g_object_notify (G_OBJECT (view), "status-message"); - - } else if (msg != NULL) { - g_free (view->priv->status_message); - g_free (view->priv->loading_title); - view->priv->status_message = g_strdup_printf (msg, host); - view->priv->loading_title = g_strdup_printf (msg, host); - g_object_notify (G_OBJECT (view), "status-message"); - g_object_notify (G_OBJECT (view), "embed-title"); - } - - out: - g_free (host); -} - -/** - * ephy_web_view_update_from_net_state: - * @view: an #EphyWebView - * @uri: the uri associated with @view - * @state: a #WebKitLoadStatus - * - * Update @view at @uri with info from @state. - **/ -void -ephy_web_view_update_from_net_state (EphyWebView *view, - const char *uri, - WebKitLoadStatus status) -{ - EphyWebViewPrivate *priv = view->priv; - - update_net_state_message (view, uri, status); - - if (status == WEBKIT_LOAD_PROVISIONAL || status == WEBKIT_LOAD_FINISHED) { - if (status == WEBKIT_LOAD_PROVISIONAL) { - GObject *object = G_OBJECT (view); - - g_object_freeze_notify (object); - - ensure_page_info (view, uri); - - priv->expire_address_now = TRUE; - - g_object_notify (object, "embed-title"); - - g_object_thaw_notify (object); - } else if (status == WEBKIT_LOAD_FINISHED) { - GObject *object = G_OBJECT (view); - - g_object_freeze_notify (object); - - g_free (priv->loading_title); - priv->loading_title = NULL; - - priv->expire_address_now = TRUE; - - g_object_notify (object, "embed-title"); - - g_object_thaw_notify (object); - } - - update_navigation_flags (view); - } -} - /** * ephy_web_view_set_loading_title: * @view: an #EphyWebView diff --git a/embed/ephy-web-view.h b/embed/ephy-web-view.h index 4079ebd4c..b3ffb538b 100644 --- a/embed/ephy-web-view.h +++ b/embed/ephy-web-view.h @@ -180,9 +180,6 @@ const char * ephy_web_view_get_title_composite (EphyWebView /* These should be private */ void ephy_web_view_set_address (EphyWebView *view, const char *address); -void ephy_web_view_update_from_net_state (EphyWebView *view, - const char *uri, - WebKitLoadStatus state); void ephy_web_view_location_changed (EphyWebView *view, const char *location); void ephy_web_view_set_loading_title (EphyWebView *view, |