[glib/wip/jstpierre/gvfs: 2/2] gvfs: additional schemes
- From: Jasper St. Pierre <jstpierre src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [glib/wip/jstpierre/gvfs: 2/2] gvfs: additional schemes
- Date: Fri, 10 Jun 2016 20:53:09 +0000 (UTC)
commit 5a66e961abac2084311064fef232f18d6fb1cf7b
Author: Jasper St. Pierre <jstpierre mecheye net>
Date: Fri Jun 10 13:40:12 2016 -0700
gvfs: additional schemes
gio/gvfs.c | 71 ++++++++++++++++++++++++++++++++++++++++++++++++++++-------
gio/gvfs.h | 8 ++++++
2 files changed, 70 insertions(+), 9 deletions(-)
---
diff --git a/gio/gvfs.c b/gio/gvfs.c
index 2390b7c..60e82f9 100644
--- a/gio/gvfs.c
+++ b/gio/gvfs.c
@@ -37,16 +37,43 @@
*
*/
-G_DEFINE_TYPE (GVfs, g_vfs, G_TYPE_OBJECT);
+struct _GVfsPrivate {
+ GHashTable *additional_schemes;
+};
+
+G_DEFINE_TYPE_WITH_PRIVATE (GVfs, g_vfs, G_TYPE_OBJECT);
+
+static void
+g_vfs_dispose (GObject *object)
+{
+ GVfs *vfs = G_VFS (object);
+ GVfsPrivate *priv = g_vfs_get_instance_private (vfs);
+
+ g_clear_pointer (&priv->additional_schemes, g_hash_table_destroy);
+
+ G_OBJECT_CLASS (g_vfs_parent_class)->dispose (object);
+}
static void
g_vfs_class_init (GVfsClass *klass)
{
+ GObjectClass *object_class = G_OBJECT_CLASS (klass);
+ object_class->dispose = g_vfs_dispose;
+}
+
+static GFile *
+resource_get_file_for_uri (GVfs *vfs, const char *uri)
+{
+ return _g_resource_file_new (uri);
}
static void
g_vfs_init (GVfs *vfs)
{
+ GVfsPrivate *priv = g_vfs_get_instance_private (vfs);
+ priv->additional_schemes = g_hash_table_new (g_str_hash, g_str_equal);
+
+ g_vfs_register_uri_scheme (vfs, "resource", resource_get_file_for_uri);
}
/**
@@ -70,7 +97,6 @@ g_vfs_is_active (GVfs *vfs)
return (* class->is_active) (vfs);
}
-
/**
* g_vfs_get_file_for_path:
* @vfs: a #GVfs.
@@ -95,6 +121,26 @@ g_vfs_get_file_for_path (GVfs *vfs,
return (* class->get_file_for_path) (vfs, path);
}
+static GFile *
+get_file_for_uri_internal (GVfs *vfs, const char *uri)
+{
+ GVfsPrivate *priv = g_vfs_get_instance_private (vfs);
+ GFile *ret = NULL;
+ char *scheme;
+ GVfsURILookupFunc func;
+
+ scheme = g_uri_parse_scheme (uri);
+ if (scheme == NULL)
+ return NULL;
+
+ func = g_hash_table_lookup (priv->additional_schemes, scheme);
+ if (func)
+ ret = func (vfs, uri);
+
+ g_free (scheme);
+ return ret;
+}
+
/**
* g_vfs_get_file_for_uri:
* @vfs: a#GVfs.
@@ -114,19 +160,16 @@ g_vfs_get_file_for_uri (GVfs *vfs,
const char *uri)
{
GVfsClass *class;
+ GFile *ret;
g_return_val_if_fail (G_IS_VFS (vfs), NULL);
g_return_val_if_fail (uri != NULL, NULL);
class = G_VFS_GET_CLASS (vfs);
- /* This is an unfortunate placement, but we really
- * need to check this before chaining to the vfs,
- * because we want to support resource uris for
- * all vfs:es, even those that predate resources.
- */
- if (g_str_has_prefix (uri, "resource:"))
- return _g_resource_file_new (uri);
+ ret = get_file_for_uri_internal (vfs, uri);
+ if (ret)
+ return ret;
return (* class->get_file_for_uri) (vfs, uri);
}
@@ -216,3 +259,13 @@ g_vfs_get_local (void)
return G_VFS (vfs);
}
+
+void
+g_vfs_register_uri_scheme (GVfs *vfs,
+ const char *scheme,
+ GVfsURILookupFunc func)
+{
+ GVfsPrivate *priv = g_vfs_get_instance_private (vfs);
+ g_hash_table_replace (priv->additional_schemes, (gpointer) scheme, func);
+}
+
diff --git a/gio/gvfs.h b/gio/gvfs.h
index e67e2d9..12934e5 100644
--- a/gio/gvfs.h
+++ b/gio/gvfs.h
@@ -36,6 +36,8 @@ G_BEGIN_DECLS
#define G_IS_VFS(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), G_TYPE_VFS))
#define G_IS_VFS_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), G_TYPE_VFS))
+typedef GFile * (* GVfsURILookupFunc) (GVfs *vfs, const char *uri);
+
/**
* G_VFS_EXTENSION_POINT_NAME:
*
@@ -50,6 +52,7 @@ G_BEGIN_DECLS
* Virtual File System object.
**/
typedef struct _GVfsClass GVfsClass;
+typedef struct _GVfsPrivate GVfsPrivate;
struct _GVfs
{
@@ -127,6 +130,11 @@ GVfs * g_vfs_get_default (void);
GLIB_AVAILABLE_IN_ALL
GVfs * g_vfs_get_local (void);
+GLIB_AVAILABLE_IN_2_50
+void g_vfs_register_uri_scheme (GVfs *vfs,
+ const char *scheme,
+ GVfsURILookupFunc func);
+
G_END_DECLS
#endif /* __G_VFS_H__ */
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]