1 /* GTK - The GIMP Toolkit
2 * gtkfilesystem.c: Abstract file system interfaces
3 * Copyright (C) 2003, Red Hat, Inc.
5 * This library is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU Lesser General Public
7 * License as published by the Free Software Foundation; either
8 * version 2 of the License, or (at your option) any later version.
10 * This library is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * Lesser General Public License for more details.
15 * You should have received a copy of the GNU Lesser General Public
16 * License along with this library; if not, write to the
17 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
18 * Boston, MA 02111-1307, USA.
21 #include "gtkfilesystem.h"
25 GtkFileTime modification_time;
34 static void gtk_file_system_base_init (gpointer g_class);
35 static void gtk_file_folder_base_init (gpointer g_class);
38 gtk_file_system_error_quark (void)
40 static GQuark quark = 0;
42 quark = g_quark_from_static_string ("gtk-file-system-error-quark");
46 /*****************************************
48 *****************************************/
50 gtk_file_info_get_type (void)
52 static GType our_type = 0;
55 our_type = g_boxed_type_register_static ("GtkFileInfo",
56 (GBoxedCopyFunc) gtk_file_info_copy,
57 (GBoxedFreeFunc) gtk_file_info_free);
63 gtk_file_info_new (void)
67 info = g_new0 (GtkFileInfo, 1);
73 gtk_file_info_copy (GtkFileInfo *info)
75 GtkFileInfo *new_info;
77 g_return_val_if_fail (info != NULL, NULL);
79 new_info = g_memdup (info, sizeof (GtkFileInfo));
80 if (new_info->display_name)
81 new_info->display_name = g_strdup (new_info->display_name);
82 if (new_info->mime_type)
83 new_info->mime_type = g_strdup (new_info->mime_type);
85 g_object_ref (new_info->icon);
91 gtk_file_info_free (GtkFileInfo *info)
93 g_return_if_fail (info != NULL);
95 if (info->display_name)
96 g_free (info->display_name);
98 g_free (info->mime_type);
100 g_object_unref (info->icon);
103 G_CONST_RETURN gchar *
104 gtk_file_info_get_display_name (const GtkFileInfo *info)
106 g_return_val_if_fail (info != NULL, NULL);
108 return info->display_name;
112 gtk_file_info_set_display_name (GtkFileInfo *info,
113 const gchar *display_name)
115 g_return_if_fail (info != NULL);
117 if (info->display_name)
118 g_free (info->display_name);
120 info->display_name = g_strdup (display_name);
124 gtk_file_info_get_is_folder (const GtkFileInfo *info)
126 g_return_val_if_fail (info != NULL, FALSE);
128 return info->is_folder;
132 gtk_file_info_set_is_folder (GtkFileInfo *info,
135 g_return_if_fail (info != NULL);
137 info->is_folder = is_folder != FALSE;
141 gtk_file_info_get_is_hidden (const GtkFileInfo *info)
143 g_return_val_if_fail (info != NULL, FALSE);
145 return info->is_hidden;
149 gtk_file_info_set_is_hidden (GtkFileInfo *info,
152 g_return_if_fail (info != NULL);
154 info->is_hidden = is_hidden != FALSE;
157 G_CONST_RETURN gchar *
158 gtk_file_info_get_mime_type (const GtkFileInfo *info)
160 g_return_val_if_fail (info != NULL, NULL);
162 return info->mime_type;
166 gtk_file_info_set_mime_type (GtkFileInfo *info,
167 const gchar *mime_type)
169 g_return_if_fail (info != NULL);
172 g_free (info->mime_type);
174 info->mime_type = g_strdup (mime_type);
178 gtk_file_info_get_modification_time (const GtkFileInfo *info)
180 g_return_val_if_fail (info != NULL, 0);
182 return info->modification_time;
186 gtk_file_info_set_modification_time (GtkFileInfo *info,
187 GtkFileTime modification_time)
189 g_return_if_fail (info != NULL);
191 info->modification_time = modification_time;
195 gtk_file_info_get_size (const GtkFileInfo *info)
197 g_return_val_if_fail (info != NULL, 0);
203 gtk_file_info_set_size (GtkFileInfo *info,
206 g_return_if_fail (info != NULL);
207 g_return_if_fail (size >= 0);
213 gtk_file_info_get_icon (const GtkFileInfo *info)
215 g_return_val_if_fail (info != NULL, NULL);
221 gtk_file_info_set_icon (GtkFileInfo *info,
224 g_return_if_fail (info != NULL);
225 g_return_if_fail (icon == NULL || GDK_IS_PIXBUF (icon));
227 if (icon != info->icon)
230 g_object_unref (info->icon);
235 g_object_ref (info->icon);
239 /*****************************************
241 *****************************************/
243 gtk_file_system_get_type (void)
245 static GType file_system_type = 0;
247 if (!file_system_type)
249 static const GTypeInfo file_system_info =
251 sizeof (GtkFileSystemIface), /* class_size */
252 gtk_file_system_base_init, /* base_init */
253 NULL, /* base_finalize */
256 file_system_type = g_type_register_static (G_TYPE_INTERFACE,
258 &file_system_info, 0);
261 return file_system_type;
265 gtk_file_system_base_init (gpointer g_class)
267 static gboolean initialized = FALSE;
271 GType iface_type = G_TYPE_FROM_INTERFACE (g_class);
273 g_signal_new ("roots_changed",
276 G_STRUCT_OFFSET (GtkFileSystemIface, roots_changed),
278 g_cclosure_marshal_VOID__VOID,
286 gtk_file_system_list_roots (GtkFileSystem *file_system)
288 g_return_val_if_fail (GTK_IS_FILE_SYSTEM (file_system), NULL);
290 return GTK_FILE_SYSTEM_GET_IFACE (file_system)->list_roots (file_system);
294 gtk_file_system_get_root_info (GtkFileSystem *file_system,
296 GtkFileInfoType types,
299 g_return_val_if_fail (GTK_IS_FILE_SYSTEM (file_system), NULL);
300 g_return_val_if_fail (uri != NULL, NULL);
301 g_return_val_if_fail (error == NULL || *error == NULL, NULL);
303 return GTK_FILE_SYSTEM_GET_IFACE (file_system)->get_root_info (file_system, uri, types, error);
307 gtk_file_system_get_folder (GtkFileSystem *file_system,
309 GtkFileInfoType types,
312 g_return_val_if_fail (GTK_IS_FILE_SYSTEM (file_system), NULL);
313 g_return_val_if_fail (uri != NULL, NULL);
314 g_return_val_if_fail (error == NULL || *error == NULL, NULL);
316 return GTK_FILE_SYSTEM_GET_IFACE (file_system)->get_folder (file_system, uri, types, error);
320 gtk_file_system_create_folder(GtkFileSystem *file_system,
324 g_return_val_if_fail (GTK_IS_FILE_SYSTEM (file_system), FALSE);
325 g_return_val_if_fail (uri != NULL, FALSE);
326 g_return_val_if_fail (error == NULL || *error == NULL, FALSE);
328 return GTK_FILE_SYSTEM_GET_IFACE (file_system)->create_folder (file_system, uri, error);
332 gtk_file_system_get_parent (GtkFileSystem *file_system,
337 gchar *tmp_parent = NULL;
340 g_return_val_if_fail (GTK_IS_FILE_SYSTEM (file_system), FALSE);
341 g_return_val_if_fail (uri != NULL, FALSE);
342 g_return_val_if_fail (error == NULL || *error == NULL, FALSE);
344 result = GTK_FILE_SYSTEM_GET_IFACE (file_system)->get_parent (file_system, uri, &tmp_parent, error);
345 g_assert (result || tmp_parent == NULL);
348 *parent = tmp_parent;
356 gtk_file_system_make_uri (GtkFileSystem *file_system,
357 const gchar *base_uri,
358 const gchar *display_name,
361 g_return_val_if_fail (GTK_IS_FILE_SYSTEM (file_system), NULL);
362 g_return_val_if_fail (base_uri != NULL, NULL);
363 g_return_val_if_fail (display_name != NULL, NULL);
364 g_return_val_if_fail (error == NULL || *error == NULL, FALSE);
366 return GTK_FILE_SYSTEM_GET_IFACE (file_system)->make_uri (file_system, base_uri, display_name, error);
370 * gtk_file_system_parse:
371 * @file_system: a #GtkFileSystem
372 * @base_uri: reference folder with respect to which relative
373 * paths should be interpreted.
374 * @str: the string to parse
375 * @folder: location to store folder portion of result, or %NULL
376 * @file_part: location to store file portion of result, or %NULL
377 * @error: location to store error, or %NULL
379 * Given a string entered by a user, parse it (possibly using
380 * heuristics) into a folder URI and a UTF-8 encoded
381 * filename part. (Suitable for passing to gtk_file_system_make_uri())
383 * Note that the returned filename point may point to a subfolder
384 * of the returned folder. Adding a trailing path separator is needed
385 * to enforce the interpretation as a folder name.
387 * If parsing fails because the syntax of @str is not understood,
388 * and error of type GTK_FILE_SYSTEM_ERROR_BAD_FILENAME will
389 * be set in @error and %FALSE returned.
391 * If parsing fails because a path was encountered that doesn't
392 * exist on the filesystem, then an error of type
393 * %GTK_FILE_SYSTEM_ERROR_NONEXISTANT will be set in @error
394 * and %FALSE returned. (This only applies to parsing relative paths,
395 * not to interpretation of @file_part. No check is made as
396 * to whether @file_part exists.)
398 * Return value: %TRUE if the parsing succeeds, otherwise, %FALSE.
401 gtk_file_system_parse (GtkFileSystem *file_system,
402 const gchar *base_uri,
408 gchar *tmp_folder = NULL;
409 gchar *tmp_file_part = NULL;
412 g_return_val_if_fail (GTK_IS_FILE_SYSTEM (file_system), FALSE);
413 g_return_val_if_fail (base_uri != NULL, FALSE);
414 g_return_val_if_fail (error == NULL || *error == NULL, FALSE);
417 result = GTK_FILE_SYSTEM_GET_IFACE (file_system)->parse (file_system, base_uri, str,
418 &tmp_folder, &tmp_file_part,
420 g_assert (result || (tmp_folder == NULL && tmp_file_part == NULL));
423 *folder = tmp_folder;
428 *file_part = tmp_file_part;
430 g_free (tmp_file_part);
435 /*****************************************
437 *****************************************/
439 gtk_file_folder_get_type (void)
441 static GType file_folder_type = 0;
443 if (!file_folder_type)
445 static const GTypeInfo file_folder_info =
447 sizeof (GtkFileFolderIface), /* class_size */
448 gtk_file_folder_base_init, /* base_init */
449 NULL, /* base_finalize */
452 file_folder_type = g_type_register_static (G_TYPE_INTERFACE,
454 &file_folder_info, 0);
457 return file_folder_type;
461 gtk_file_folder_base_init (gpointer g_class)
463 static gboolean initialized = FALSE;
467 GType iface_type = G_TYPE_FROM_INTERFACE (g_class);
469 g_signal_new ("deleted",
472 G_STRUCT_OFFSET (GtkFileFolderIface, deleted),
474 g_cclosure_marshal_VOID__VOID,
476 g_signal_new ("file_added",
479 G_STRUCT_OFFSET (GtkFileFolderIface, file_added),
481 g_cclosure_marshal_VOID__STRING,
483 g_signal_new ("file_changed",
486 G_STRUCT_OFFSET (GtkFileFolderIface, file_changed),
488 g_cclosure_marshal_VOID__STRING,
490 g_signal_new ("file_removed",
493 G_STRUCT_OFFSET (GtkFileFolderIface, file_removed),
495 g_cclosure_marshal_VOID__STRING,
503 gtk_file_folder_list_children (GtkFileFolder *folder,
508 GSList *tmp_children = NULL;
510 g_return_val_if_fail (GTK_IS_FILE_FOLDER (folder), FALSE);
511 g_return_val_if_fail (error == NULL || *error == NULL, FALSE);
513 result = GTK_FILE_FOLDER_GET_IFACE (folder)->list_children (folder, &tmp_children, error);
514 g_assert (result || tmp_children == NULL);
517 *children = tmp_children;
520 g_slist_foreach (tmp_children, (GFunc)g_free, NULL);
521 g_slist_free (tmp_children);
528 gtk_file_folder_get_info (GtkFileFolder *folder,
532 g_return_val_if_fail (GTK_IS_FILE_FOLDER (folder), NULL);
533 g_return_val_if_fail (uri != NULL, NULL);
534 g_return_val_if_fail (error == NULL || *error == NULL, NULL);
536 return GTK_FILE_FOLDER_GET_IFACE (folder)->get_info (folder, uri, error);