aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorChristian Persch <chpe@cvs.gnome.org>2004-03-04 03:54:36 +0800
committerChristian Persch <chpe@src.gnome.org>2004-03-04 03:54:36 +0800
commita65777247b2c4a412ee1972cab884f462dc19276 (patch)
treeb0dce97cad625aaf16e0da55459d178a579b64de /lib
parentade55d6a9658567dcefb18fc0d536a7e3eed0c8c (diff)
downloadgsoc2013-epiphany-a65777247b2c4a412ee1972cab884f462dc19276.tar.gz
gsoc2013-epiphany-a65777247b2c4a412ee1972cab884f462dc19276.tar.zst
gsoc2013-epiphany-a65777247b2c4a412ee1972cab884f462dc19276.zip
Copy and modify gnome_vfs_uri_list_parse() so that we get a list of string
2004-03-03 Christian Persch <chpe@cvs.gnome.org> * lib/widgets/ephy-node-view.c: (uri_list_parse), (drag_data_received_cb): Copy and modify gnome_vfs_uri_list_parse() so that we get a list of string uris instead of GnomeVFSURIs. Change signature of ::node-dropped accordingly. Fixes bug #120231. * src/bookmarks/ephy-bookmarks-editor.c: (node_dropped_cb): Adapt to the changed ::node-dropped signal signature.
Diffstat (limited to 'lib')
-rw-r--r--lib/widgets/ephy-node-view.c59
-rw-r--r--lib/widgets/ephy-node-view.h2
2 files changed, 57 insertions, 4 deletions
diff --git a/lib/widgets/ephy-node-view.c b/lib/widgets/ephy-node-view.c
index 6949bb404..f5e35d4b0 100644
--- a/lib/widgets/ephy-node-view.c
+++ b/lib/widgets/ephy-node-view.c
@@ -428,6 +428,58 @@ drag_leave_cb (GtkWidget *widget,
remove_scroll_timeout (view);
}
+/* taken from libgnomevfs/gnome-vfs-uri.c */
+static GList*
+uri_list_parse (const gchar* uri_list)
+{
+ /* Note that this is mostly very stolen from old libgnome/gnome-mime.c */
+
+ const gchar *p, *q;
+ gchar *retval;
+ GList *result = NULL;
+
+ g_return_val_if_fail (uri_list != NULL, NULL);
+
+ p = uri_list;
+
+ /* We don't actually try to validate the URI according to RFC
+ * 2396, or even check for allowed characters - we just ignore
+ * comments and trim whitespace off the ends. We also
+ * allow LF delimination as well as the specified CRLF.
+ */
+ while (p != NULL) {
+ if (*p != '#') {
+ while (g_ascii_isspace (*p))
+ p++;
+
+ q = p;
+ while ((*q != '\0')
+ && (*q != '\n')
+ && (*q != '\r'))
+ q++;
+
+ if (q > p) {
+ q--;
+ while (q > p
+ && g_ascii_isspace (*q))
+ q--;
+
+ retval = g_malloc (q - p + 2);
+ strncpy (retval, p, q - p + 1);
+ retval[q - p + 1] = '\0';
+
+ if (retval[0] != '\0')
+ result = g_list_prepend (result, retval);
+ }
+ }
+ p = strchr (p, '\n');
+ if (p != NULL)
+ p++;
+ }
+
+ return g_list_reverse (result);
+}
+
static void
drag_data_received_cb (GtkWidget *widget,
GdkDragContext *context,
@@ -468,15 +520,16 @@ drag_data_received_cb (GtkWidget *widget,
node = get_node_from_path (view, path);
- uris = gnome_vfs_uri_list_parse (selection_data->data);
-
+ uris = uri_list_parse (selection_data->data);
+
if (uris != NULL)
{
/* FIXME fill success */
g_signal_emit (G_OBJECT (view),
ephy_node_view_signals[NODE_DROPPED], 0,
node, uris);
- gnome_vfs_uri_list_free (uris);
+ g_list_foreach (uris, (GFunc) g_free, NULL);
+ g_list_free (uris);
}
view->priv->drop_occurred = FALSE;
diff --git a/lib/widgets/ephy-node-view.h b/lib/widgets/ephy-node-view.h
index 5d82dfbaf..9af56e8a5 100644
--- a/lib/widgets/ephy-node-view.h
+++ b/lib/widgets/ephy-node-view.h
@@ -67,7 +67,7 @@ typedef struct
void (*node_activated) (EphyNodeView *view, EphyNode *node);
void (*node_selected) (EphyNodeView *view, EphyNode *node);
- void (*node_dropped) (EphyNodeView *view, EphyNode *node, GList *nodes);
+ void (*node_dropped) (EphyNodeView *view, EphyNode *node, GList *uris);
void (*show_popup) (EphyNodeView *view);
} EphyNodeViewClass;