| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  | /* GIO - GLib Input, Output and Streaming Library
 | 
					
						
							| 
									
										
										
										
											2008-09-02 19:05:58 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  |  * Copyright (C) 2006-2007 Red Hat, Inc. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2022-05-18 09:12:45 +01:00
										 |  |  |  * SPDX-License-Identifier: LGPL-2.1-or-later | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  |  * This library is free software; you can redistribute it and/or | 
					
						
							|  |  |  |  * modify it under the terms of the GNU Lesser General Public | 
					
						
							|  |  |  |  * License as published by the Free Software Foundation; either | 
					
						
							| 
									
										
										
										
											2017-05-27 18:21:30 +02:00
										 |  |  |  * version 2.1 of the License, or (at your option) any later version. | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * This library is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | 
					
						
							|  |  |  |  * Lesser General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU Lesser General | 
					
						
							| 
									
										
										
										
											2014-01-23 12:58:29 +01:00
										 |  |  |  * Public License along with this library; if not, see <http://www.gnu.org/licenses/>.
 | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * Author: Alexander Larsson <alexl@redhat.com> | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-27 23:43:14 -05:00
										 |  |  | #ifndef __G_VFS_H__
 | 
					
						
							|  |  |  | #define __G_VFS_H__
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-12-14 10:35:24 +00:00
										 |  |  | #if !defined (__GIO_GIO_H_INSIDE__) && !defined (GIO_COMPILATION)
 | 
					
						
							|  |  |  | #error "Only <gio/gio.h> can be included directly."
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-01 06:32:35 +00:00
										 |  |  | #include <gio/giotypes.h>
 | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | G_BEGIN_DECLS | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define G_TYPE_VFS         (g_vfs_get_type ())
 | 
					
						
							|  |  |  | #define G_VFS(o)           (G_TYPE_CHECK_INSTANCE_CAST ((o), G_TYPE_VFS, GVfs))
 | 
					
						
							|  |  |  | #define G_VFS_CLASS(k)     (G_TYPE_CHECK_CLASS_CAST((k), G_TYPE_VFS, GVfsClass))
 | 
					
						
							|  |  |  | #define G_VFS_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), G_TYPE_VFS, GVfsClass))
 | 
					
						
							|  |  |  | #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))
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-20 11:42:56 -07:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * GVfsFileLookupFunc: | 
					
						
							|  |  |  |  * @vfs: a #GVfs | 
					
						
							| 
									
										
										
										
											2019-04-26 12:12:31 +01:00
										 |  |  |  * @identifier: the identifier to look up a #GFile for. This can either | 
					
						
							| 
									
										
										
										
											2024-04-01 10:54:59 +00:00
										 |  |  |  *     be a URI or a parse name as returned by g_file_get_parse_name() | 
					
						
							| 
									
										
										
										
											2024-12-12 21:52:32 +00:00
										 |  |  |  * @user_data: (nullable): user data passed to the function, or %NULL | 
					
						
							| 
									
										
										
										
											2016-06-20 11:42:56 -07:00
										 |  |  |  * | 
					
						
							|  |  |  |  * This function type is used by g_vfs_register_uri_scheme() to make it | 
					
						
							| 
									
										
										
										
											2024-04-01 10:54:59 +00:00
										 |  |  |  * possible for a client to associate a URI scheme to a different #GFile | 
					
						
							| 
									
										
										
										
											2016-06-20 11:42:56 -07:00
										 |  |  |  * implementation. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The client should return a reference to the new file that has been | 
					
						
							|  |  |  |  * created for @uri, or %NULL to continue with the default implementation. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2024-12-12 21:52:32 +00:00
										 |  |  |  * Returns: (nullable) (transfer full): a #GFile for @identifier. | 
					
						
							| 
									
										
										
										
											2016-06-20 11:42:56 -07:00
										 |  |  |  * | 
					
						
							|  |  |  |  * Since: 2.50 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | typedef GFile * (* GVfsFileLookupFunc) (GVfs       *vfs, | 
					
						
							|  |  |  |                                         const char *identifier, | 
					
						
							|  |  |  |                                         gpointer    user_data); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-11 07:17:48 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * G_VFS_EXTENSION_POINT_NAME: | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-09-02 19:05:58 +00:00
										 |  |  |  * Extension point for #GVfs functionality. | 
					
						
							| 
									
										
										
										
											2025-01-28 21:05:26 +02:00
										 |  |  |  * See [Extending GIO](overview.html#extending-gio). | 
					
						
							| 
									
										
										
										
											2008-02-11 07:17:48 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2008-01-28 19:43:10 +00:00
										 |  |  | #define G_VFS_EXTENSION_POINT_NAME "gio-vfs"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  | typedef struct _GVfsClass    GVfsClass; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-02 19:05:58 +00:00
										 |  |  | struct _GVfs | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2007-12-12 14:33:20 +00:00
										 |  |  |   GObject parent_instance; | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct _GVfsClass | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   GObjectClass parent_class; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* Virtual Table */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-02 19:05:58 +00:00
										 |  |  |   gboolean              (* is_active)                 (GVfs       *vfs); | 
					
						
							|  |  |  |   GFile               * (* get_file_for_path)         (GVfs       *vfs, | 
					
						
							|  |  |  |                                                        const char *path); | 
					
						
							|  |  |  |   GFile               * (* get_file_for_uri)          (GVfs       *vfs, | 
					
						
							|  |  |  |                                                        const char *uri); | 
					
						
							|  |  |  |   const gchar * const * (* get_supported_uri_schemes) (GVfs       *vfs); | 
					
						
							|  |  |  |   GFile               * (* parse_name)                (GVfs       *vfs, | 
					
						
							|  |  |  |                                                        const char *parse_name); | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-11-27 14:00:13 +00:00
										 |  |  |   /*< private >*/ | 
					
						
							| 
									
										
										
										
											2009-06-18 09:05:27 +02:00
										 |  |  |   void                  (* local_file_add_info)       (GVfs       *vfs, | 
					
						
							|  |  |  | 						       const char *filename, | 
					
						
							|  |  |  | 						       guint64     device, | 
					
						
							|  |  |  | 						       GFileAttributeMatcher *attribute_matcher, | 
					
						
							|  |  |  | 						       GFileInfo  *info, | 
					
						
							|  |  |  | 						       GCancellable *cancellable, | 
					
						
							|  |  |  | 						       gpointer   *extra_data, | 
					
						
							|  |  |  | 						       GDestroyNotify *free_extra_data); | 
					
						
							|  |  |  |   void                  (* add_writable_namespaces)   (GVfs       *vfs, | 
					
						
							|  |  |  | 						       GFileAttributeInfoList *list); | 
					
						
							|  |  |  |   gboolean              (* local_file_set_attributes) (GVfs       *vfs, | 
					
						
							|  |  |  | 						       const char *filename, | 
					
						
							|  |  |  | 						       GFileInfo  *info, | 
					
						
							|  |  |  |                                                        GFileQueryInfoFlags flags, | 
					
						
							|  |  |  |                                                        GCancellable *cancellable, | 
					
						
							|  |  |  | 						       GError    **error); | 
					
						
							|  |  |  |   void                  (* local_file_removed)        (GVfs       *vfs, | 
					
						
							|  |  |  | 						       const char *filename); | 
					
						
							|  |  |  |   void                  (* local_file_moved)          (GVfs       *vfs, | 
					
						
							|  |  |  | 						       const char *source, | 
					
						
							|  |  |  | 						       const char *dest); | 
					
						
							| 
									
										
										
										
											2013-04-20 18:50:21 -04:00
										 |  |  |   GIcon *               (* deserialize_icon)          (GVfs       *vfs, | 
					
						
							|  |  |  |                                                        GVariant   *value); | 
					
						
							| 
									
										
										
										
											2009-07-05 22:35:55 -04:00
										 |  |  |   /* Padding for future expansion */ | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  |   void (*_g_reserved1) (void); | 
					
						
							|  |  |  |   void (*_g_reserved2) (void); | 
					
						
							|  |  |  |   void (*_g_reserved3) (void); | 
					
						
							|  |  |  |   void (*_g_reserved4) (void); | 
					
						
							|  |  |  |   void (*_g_reserved5) (void); | 
					
						
							|  |  |  |   void (*_g_reserved6) (void); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-05 13:39:21 -04:00
										 |  |  | GIO_AVAILABLE_IN_ALL | 
					
						
							| 
									
										
										
										
											2008-09-02 19:05:58 +00:00
										 |  |  | GType                 g_vfs_get_type                  (void) G_GNUC_CONST; | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-05 13:39:21 -04:00
										 |  |  | GIO_AVAILABLE_IN_ALL | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  | gboolean              g_vfs_is_active                 (GVfs       *vfs); | 
					
						
							| 
									
										
										
										
											2022-10-05 13:39:21 -04:00
										 |  |  | GIO_AVAILABLE_IN_ALL | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  | GFile *               g_vfs_get_file_for_path         (GVfs       *vfs, | 
					
						
							| 
									
										
										
										
											2008-09-02 19:05:58 +00:00
										 |  |  |                                                        const char *path); | 
					
						
							| 
									
										
										
										
											2022-10-05 13:39:21 -04:00
										 |  |  | GIO_AVAILABLE_IN_ALL | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  | GFile *               g_vfs_get_file_for_uri          (GVfs       *vfs, | 
					
						
							| 
									
										
										
										
											2008-09-02 19:05:58 +00:00
										 |  |  |                                                        const char *uri); | 
					
						
							| 
									
										
										
										
											2022-10-05 13:39:21 -04:00
										 |  |  | GIO_AVAILABLE_IN_ALL | 
					
						
							| 
									
										
										
										
											2008-09-02 19:05:58 +00:00
										 |  |  | const gchar* const * g_vfs_get_supported_uri_schemes  (GVfs       *vfs); | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-05 13:39:21 -04:00
										 |  |  | GIO_AVAILABLE_IN_ALL | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  | GFile *               g_vfs_parse_name                (GVfs       *vfs, | 
					
						
							| 
									
										
										
										
											2008-09-02 19:05:58 +00:00
										 |  |  |                                                        const char *parse_name); | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-05 13:39:21 -04:00
										 |  |  | GIO_AVAILABLE_IN_ALL | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  | GVfs *                g_vfs_get_default               (void); | 
					
						
							| 
									
										
										
										
											2022-10-05 13:39:21 -04:00
										 |  |  | GIO_AVAILABLE_IN_ALL | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  | GVfs *                g_vfs_get_local                 (void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-05 13:39:21 -04:00
										 |  |  | GIO_AVAILABLE_IN_2_50 | 
					
						
							| 
									
										
										
										
											2016-06-20 11:42:56 -07:00
										 |  |  | gboolean              g_vfs_register_uri_scheme       (GVfs               *vfs, | 
					
						
							|  |  |  |                                                        const char         *scheme, | 
					
						
							|  |  |  |                                                        GVfsFileLookupFunc  uri_func, | 
					
						
							|  |  |  |                                                        gpointer            uri_data, | 
					
						
							|  |  |  |                                                        GDestroyNotify      uri_destroy, | 
					
						
							|  |  |  |                                                        GVfsFileLookupFunc  parse_name_func, | 
					
						
							|  |  |  |                                                        gpointer            parse_name_data, | 
					
						
							|  |  |  |                                                        GDestroyNotify      parse_name_destroy); | 
					
						
							| 
									
										
										
										
											2022-10-05 13:39:21 -04:00
										 |  |  | GIO_AVAILABLE_IN_2_50 | 
					
						
							| 
									
										
										
										
											2016-06-20 11:42:56 -07:00
										 |  |  | gboolean              g_vfs_unregister_uri_scheme     (GVfs               *vfs, | 
					
						
							|  |  |  |                                                        const char         *scheme); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  | G_END_DECLS | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* __G_VFS_H__ */
 |