diff options
author | Xan Lopez <xan@gnome.org> | 2009-06-14 18:45:23 +0800 |
---|---|---|
committer | Xan Lopez <xan@gnome.org> | 2009-06-14 18:45:23 +0800 |
commit | d8d990befed09551e63d6d80703665e8216e4093 (patch) | |
tree | 78ef76a93ac21301ae80e79d788fa16e4fad37d5 | |
parent | f86a9e936f34722026a141cffa4d5379f21b1fe1 (diff) | |
download | gsoc2013-epiphany-d8d990befed09551e63d6d80703665e8216e4093.tar gsoc2013-epiphany-d8d990befed09551e63d6d80703665e8216e4093.tar.gz gsoc2013-epiphany-d8d990befed09551e63d6d80703665e8216e4093.tar.bz2 gsoc2013-epiphany-d8d990befed09551e63d6d80703665e8216e4093.tar.lz gsoc2013-epiphany-d8d990befed09551e63d6d80703665e8216e4093.tar.xz gsoc2013-epiphany-d8d990befed09551e63d6d80703665e8216e4093.tar.zst gsoc2013-epiphany-d8d990befed09551e63d6d80703665e8216e4093.zip |
ephy-web-view.c: use 'load-status' property from WebKitWebView also internally.
Get rid of our 'load-status' property, and just keep the API semantics
of the ephy_web_view_get_load_status function using the
WebKitWebView's 'load-status' property.
-rw-r--r-- | embed/ephy-web-view.c | 43 |
1 files changed, 7 insertions, 36 deletions
diff --git a/embed/ephy-web-view.c b/embed/ephy-web-view.c index bde2e017e..befd65a6b 100644 --- a/embed/ephy-web-view.c +++ b/embed/ephy-web-view.c @@ -61,7 +61,6 @@ struct _EphyWebViewPrivate { /* Flags */ guint is_blank : 1; - guint is_loading : 1; guint visibility : 1; char *address; @@ -99,7 +98,6 @@ enum { PROP_ICON, PROP_ICON_ADDRESS, PROP_LINK_MESSAGE, - PROP_LOAD_STATUS, PROP_NAVIGATION, PROP_POPUPS_ALLOWED, PROP_SECURITY, @@ -384,9 +382,6 @@ ephy_web_view_get_property (GObject *object, case PROP_ADDRESS: g_value_set_string (value, priv->address); break; - case PROP_LOAD_STATUS: - g_value_set_boolean (value, priv->is_loading); - break; case PROP_EMBED_TITLE: g_value_set_string (value, priv->title); break; @@ -453,7 +448,6 @@ ephy_web_view_set_property (GObject *object, case PROP_HIDDEN_POPUP_COUNT: case PROP_ICON: case PROP_LINK_MESSAGE: - case PROP_LOAD_STATUS: case PROP_NAVIGATION: case PROP_SECURITY: case PROP_STATUS_MESSAGE: @@ -569,13 +563,6 @@ ephy_web_view_class_init (EphyWebViewClass *klass) G_PARAM_READABLE | G_PARAM_STATIC_NAME | G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB)); g_object_class_install_property (gobject_class, - PROP_LOAD_STATUS, - g_param_spec_boolean ("load-status", - "Load status", - "The view's load status", - FALSE, - G_PARAM_READABLE | G_PARAM_STATIC_NAME | G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB)); - g_object_class_install_property (gobject_class, PROP_NAVIGATION, g_param_spec_flags ("navigation", "Navigation flags", @@ -1137,7 +1124,7 @@ ephy_web_view_set_address (EphyWebView *view, priv->is_blank = address == NULL || strcmp (address, "about:blank") == 0; - if (priv->is_loading && + if (ephy_web_view_get_load_status (view) && priv->address_expire == EPHY_WEB_VIEW_ADDRESS_EXPIRE_NOW && priv->typed_address != NULL) { g_free (priv->typed_address); @@ -1316,21 +1303,6 @@ update_navigation_flags (EphyWebView *view) } } -static void -ephy_web_view_set_load_status (EphyWebView *view, gboolean status) -{ - EphyWebViewPrivate *priv = view->priv; - guint is_loading; - - is_loading = status != FALSE; - - if (is_loading != priv->is_loading) { - priv->is_loading = is_loading; - - g_object_notify (G_OBJECT (view), "load-status"); - } -} - void ephy_web_view_update_from_net_state (EphyWebView *view, const char *uri, @@ -1349,8 +1321,6 @@ ephy_web_view_update_from_net_state (EphyWebView *view, priv->total_requests = 0; priv->cur_requests = 0; - ephy_web_view_set_load_status (view, TRUE); - ensure_page_info (view, uri); g_object_notify (object, "embed-title"); @@ -1361,8 +1331,6 @@ ephy_web_view_update_from_net_state (EphyWebView *view, g_object_freeze_notify (object); - ephy_web_view_set_load_status (view, FALSE); - g_free (priv->loading_title); priv->loading_title = NULL; @@ -1414,7 +1382,7 @@ ephy_web_view_file_monitor_reload_cb (EphyWebView *view) return TRUE; } - if (priv->is_loading) { + if (ephy_web_view_get_load_status (view)) { /* Wait a bit to reload if we're still loading! */ priv->reload_delay_ticks = RELOAD_DELAY_MAX_TICKS / 2; @@ -1645,7 +1613,10 @@ ephy_web_view_can_go_up (EphyWebView *view) gboolean ephy_web_view_get_load_status (EphyWebView *view) { - return view->priv->is_loading; + WebKitLoadStatus status; + + status = webkit_web_view_get_load_status (WEBKIT_WEB_VIEW (view)); + return status != WEBKIT_LOAD_FINISHED; } const char * @@ -1870,7 +1841,7 @@ ephy_web_view_set_typed_address (EphyWebView *view, priv->typed_address = g_strdup (address); if (expire == EPHY_WEB_VIEW_ADDRESS_EXPIRE_CURRENT && - !priv->is_loading) { + !ephy_web_view_get_load_status (view)) { priv->address_expire = EPHY_WEB_VIEW_ADDRESS_EXPIRE_NOW; } else { priv->address_expire = expire; |