aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFrédéric Péters <fpeters@0d.be>2009-09-19 15:56:11 +0800
committerFrédéric Péters <fpeters@0d.be>2009-09-22 17:27:43 +0800
commitf279bbf2de2896f39ef08e52961e8638b9f1a29b (patch)
tree91a425669c7b8b24e891c1aff142574ccc5be6ef
parent91b7e21ec5570e1638d4116767dfe48aa0349e30 (diff)
downloadgsoc2013-epiphany-f279bbf2de2896f39ef08e52961e8638b9f1a29b.tar
gsoc2013-epiphany-f279bbf2de2896f39ef08e52961e8638b9f1a29b.tar.gz
gsoc2013-epiphany-f279bbf2de2896f39ef08e52961e8638b9f1a29b.tar.bz2
gsoc2013-epiphany-f279bbf2de2896f39ef08e52961e8638b9f1a29b.tar.lz
gsoc2013-epiphany-f279bbf2de2896f39ef08e52961e8638b9f1a29b.tar.xz
gsoc2013-epiphany-f279bbf2de2896f39ef08e52961e8638b9f1a29b.tar.zst
gsoc2013-epiphany-f279bbf2de2896f39ef08e52961e8638b9f1a29b.zip
Add back support for the "direction up" navigation (GNOME bug 595653)
-rw-r--r--embed/ephy-web-view.c70
-rw-r--r--src/ephy-navigation-action.c2
2 files changed, 68 insertions, 4 deletions
diff --git a/embed/ephy-web-view.c b/embed/ephy-web-view.c
index 3eb8b4da1..4e93733ab 100644
--- a/embed/ephy-web-view.c
+++ b/embed/ephy-web-view.c
@@ -1643,15 +1643,30 @@ ephy_web_view_set_icon_address (EphyWebView *view,
* @view: an #EphyWebView
*
* Returns whether @view can travel to a higher-level directory on the server.
- * For example, for http://www.example.com/subdir/index.html, returns %TRUE; for
- * http://www.example.com/index.html, returns %FALSE.
+ * For example, for http://www.example.com/subdir/foo.html, returns %TRUE; for
+ * http://www.example.com/, returns %FALSE.
*
* Return value: %TRUE if @view can browse to a higher-level directory
**/
gboolean
ephy_web_view_can_go_up (EphyWebView *view)
{
- return FALSE;
+ SoupURI *uri;
+ gboolean result;
+
+ uri = soup_uri_new (ephy_web_view_get_address (view));
+ if (uri == NULL)
+ return FALSE;
+
+ if (strcmp (uri->scheme, "about") == 0 || strcmp (uri->scheme, "data") == 0) {
+ soup_uri_free (uri);
+ return FALSE;
+ }
+
+ result = (uri->fragment || uri->query || strlen (uri->path) > 1);
+ soup_uri_free (uri);
+
+ return result;
}
/**
@@ -2071,7 +2086,54 @@ ephy_web_view_print_preview_navigate (EphyWebView *view,
GSList *
ephy_web_view_get_go_up_list (EphyWebView *view)
{
- return NULL;
+ SoupURI *uri;
+ GSList *result = NULL;
+ char *t1, *t2;
+
+ uri = soup_uri_new (ephy_web_view_get_address (view));
+ if (uri == NULL)
+ return NULL;
+
+ if (strcmp (uri->scheme, "about") == 0 || strcmp (uri->scheme, "data") == 0) {
+ soup_uri_free (uri);
+ return NULL;
+ }
+
+ /* remove fragment, then query, then go up path */
+ if (uri->fragment) {
+ soup_uri_set_fragment (uri, NULL);
+ result = g_slist_prepend (result, soup_uri_to_string (uri, FALSE));
+ }
+
+ if (uri->query) {
+ soup_uri_set_query (uri, NULL);
+ result = g_slist_prepend (result, soup_uri_to_string (uri, FALSE));
+ }
+
+ if (uri->path[strlen(uri->path)-1] != '/') {
+ /* not a trailing slash, remove "file" part */
+ t1 = strrchr (uri->path, '/');
+ t2 = g_strndup (uri->path, t1-uri->path+1);
+ soup_uri_set_path (uri, t2);
+ g_free (t2);
+ result = g_slist_prepend (result, soup_uri_to_string (uri, FALSE));
+ }
+
+ while (strcmp(uri->path, "/") != 0) {
+ /* chop trailing / */
+ uri->path[strlen (uri->path)-1] = 0;
+ t1 = strrchr (uri->path, '/');
+ t2 = g_strndup (uri->path, t1-uri->path+1);
+ soup_uri_set_path (uri, t2);
+ g_free (t2);
+ result = g_slist_prepend (result, soup_uri_to_string (uri, FALSE));
+ }
+
+ result = g_slist_reverse (result);
+
+ soup_uri_free (uri);
+
+ return result;
}
/**
diff --git a/src/ephy-navigation-action.c b/src/ephy-navigation-action.c
index bfbae85d5..972f86d30 100644
--- a/src/ephy-navigation-action.c
+++ b/src/ephy-navigation-action.c
@@ -318,6 +318,7 @@ build_up_menu (EphyNavigationAction *action)
}
/* the list data has been consumed */
+ g_slist_foreach (list, (GFunc) g_free, NULL);
g_slist_free (list);
return GTK_WIDGET (menu);
@@ -434,6 +435,7 @@ ephy_navigation_action_activate (GtkAction *gtk_action)
up_list->data,
NULL,
ephy_gui_is_middle_click () ? EPHY_LINK_NEW_TAB : 0);
+ g_slist_foreach (up_list, (GFunc) g_free, NULL);
g_slist_free (up_list);
}
}