diff options
Diffstat (limited to 'src/nautilus-vfs-file.c')
-rw-r--r-- | src/nautilus-vfs-file.c | 1192 |
1 files changed, 626 insertions, 566 deletions
diff --git a/src/nautilus-vfs-file.c b/src/nautilus-vfs-file.c index 0a37be573..0fff497f3 100644 --- a/src/nautilus-vfs-file.c +++ b/src/nautilus-vfs-file.c @@ -1,24 +1,24 @@ /* - nautilus-vfs-file.c: Subclass of NautilusFile to help implement the - virtual trash directory. - - Copyright (C) 1999, 2000, 2001 Eazel, Inc. - - This program is free software; you can redistribute it and/or - modify it under the terms of the GNU General Public License as - published by the Free Software Foundation; either version 2 of the - License, or (at your option) any later version. - - This program 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 - General Public License for more details. - - You should have received a copy of the GNU General Public - License along with this program; if not, see <http://www.gnu.org/licenses/>. - - Author: Darin Adler <darin@bentspoon.com> -*/ + * nautilus-vfs-file.c: Subclass of NautilusFile to help implement the + * virtual trash directory. + * + * Copyright (C) 1999, 2000, 2001 Eazel, Inc. + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License as + * published by the Free Software Foundation; either version 2 of the + * License, or (at your option) any later version. + * + * This program 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 + * General Public License for more details. + * + * You should have received a copy of the GNU General Public + * License along with this program; if not, see <http://www.gnu.org/licenses/>. + * + * Author: Darin Adler <darin@bentspoon.com> + */ #include <config.h> #include "nautilus-vfs-file.h" @@ -30,640 +30,700 @@ G_DEFINE_TYPE (NautilusVFSFile, nautilus_vfs_file, NAUTILUS_TYPE_FILE); -static void -vfs_file_monitor_add (NautilusFile *file, - gconstpointer client, - NautilusFileAttributes attributes) -{ - nautilus_directory_monitor_add_internal - (file->details->directory, file, - client, TRUE, attributes, NULL, NULL); -} - static void -vfs_file_monitor_remove (NautilusFile *file, - gconstpointer client) +vfs_file_monitor_add (NautilusFile *file, + gconstpointer client, + NautilusFileAttributes attributes) { - nautilus_directory_monitor_remove_internal - (file->details->directory, file, client); -} + nautilus_directory_monitor_add_internal + (file->details->directory, file, + client, TRUE, attributes, NULL, NULL); +} static void -vfs_file_call_when_ready (NautilusFile *file, - NautilusFileAttributes file_attributes, - NautilusFileCallback callback, - gpointer callback_data) +vfs_file_monitor_remove (NautilusFile *file, + gconstpointer client) +{ + nautilus_directory_monitor_remove_internal + (file->details->directory, file, client); +} +static void +vfs_file_call_when_ready (NautilusFile *file, + NautilusFileAttributes file_attributes, + NautilusFileCallback callback, + gpointer callback_data) { - nautilus_directory_call_when_ready_internal - (file->details->directory, file, - file_attributes, FALSE, NULL, callback, callback_data); + nautilus_directory_call_when_ready_internal + (file->details->directory, file, + file_attributes, FALSE, NULL, callback, callback_data); } static void -vfs_file_cancel_call_when_ready (NautilusFile *file, - NautilusFileCallback callback, - gpointer callback_data) +vfs_file_cancel_call_when_ready (NautilusFile *file, + NautilusFileCallback callback, + gpointer callback_data) { - nautilus_directory_cancel_callback_internal - (file->details->directory, file, - NULL, callback, callback_data); + nautilus_directory_cancel_callback_internal + (file->details->directory, file, + NULL, callback, callback_data); } static gboolean -vfs_file_check_if_ready (NautilusFile *file, - NautilusFileAttributes file_attributes) +vfs_file_check_if_ready (NautilusFile *file, + NautilusFileAttributes file_attributes) { - return nautilus_directory_check_if_ready_internal - (file->details->directory, file, - file_attributes); + return nautilus_directory_check_if_ready_internal + (file->details->directory, file, + file_attributes); } static void -set_metadata_get_info_callback (GObject *source_object, - GAsyncResult *res, - gpointer callback_data) +set_metadata_get_info_callback (GObject *source_object, + GAsyncResult *res, + gpointer callback_data) { - NautilusFile *file; - GFileInfo *new_info; - GError *error; - - file = callback_data; - - error = NULL; - new_info = g_file_query_info_finish (G_FILE (source_object), res, &error); - if (new_info != NULL) { - if (nautilus_file_update_info (file, new_info)) { - nautilus_file_changed (file); - } - g_object_unref (new_info); - } - nautilus_file_unref (file); - if (error) { - g_error_free (error); - } + NautilusFile *file; + GFileInfo *new_info; + GError *error; + + file = callback_data; + + error = NULL; + new_info = g_file_query_info_finish (G_FILE (source_object), res, &error); + if (new_info != NULL) + { + if (nautilus_file_update_info (file, new_info)) + { + nautilus_file_changed (file); + } + g_object_unref (new_info); + } + nautilus_file_unref (file); + if (error) + { + g_error_free (error); + } } static void -set_metadata_callback (GObject *source_object, - GAsyncResult *result, - gpointer callback_data) +set_metadata_callback (GObject *source_object, + GAsyncResult *result, + gpointer callback_data) { - NautilusFile *file; - GError *error; - gboolean res; - - file = callback_data; - - error = NULL; - res = g_file_set_attributes_finish (G_FILE (source_object), - result, - NULL, - &error); - - if (res) { - g_file_query_info_async (G_FILE (source_object), - NAUTILUS_FILE_DEFAULT_ATTRIBUTES, - 0, - G_PRIORITY_DEFAULT, - NULL, - set_metadata_get_info_callback, file); - } else { - nautilus_file_unref (file); - g_error_free (error); - } + NautilusFile *file; + GError *error; + gboolean res; + + file = callback_data; + + error = NULL; + res = g_file_set_attributes_finish (G_FILE (source_object), + result, + NULL, + &error); + + if (res) + { + g_file_query_info_async (G_FILE (source_object), + NAUTILUS_FILE_DEFAULT_ATTRIBUTES, + 0, + G_PRIORITY_DEFAULT, + NULL, + set_metadata_get_info_callback, file); + } + else + { + nautilus_file_unref (file); + g_error_free (error); + } } static void -vfs_file_set_metadata (NautilusFile *file, - const char *key, - const char *value) +vfs_file_set_metadata (NautilusFile *file, + const char *key, + const char *value) { - GFileInfo *info; - GFile *location; - char *gio_key; - - info = g_file_info_new (); - - gio_key = g_strconcat ("metadata::", key, NULL); - if (value != NULL) { - g_file_info_set_attribute_string (info, gio_key, value); - } else { - /* Unset the key */ - g_file_info_set_attribute (info, gio_key, - G_FILE_ATTRIBUTE_TYPE_INVALID, - NULL); - } - g_free (gio_key); - - location = nautilus_file_get_location (file); - g_file_set_attributes_async (location, - info, - 0, - G_PRIORITY_DEFAULT, - NULL, - set_metadata_callback, - nautilus_file_ref (file)); - g_object_unref (location); - g_object_unref (info); + GFileInfo *info; + GFile *location; + char *gio_key; + + info = g_file_info_new (); + + gio_key = g_strconcat ("metadata::", key, NULL); + if (value != NULL) + { + g_file_info_set_attribute_string (info, gio_key, value); + } + else + { + /* Unset the key */ + g_file_info_set_attribute (info, gio_key, + G_FILE_ATTRIBUTE_TYPE_INVALID, + NULL); + } + g_free (gio_key); + + location = nautilus_file_get_location (file); + g_file_set_attributes_async (location, + info, + 0, + G_PRIORITY_DEFAULT, + NULL, + set_metadata_callback, + nautilus_file_ref (file)); + g_object_unref (location); + g_object_unref (info); } static void -vfs_file_set_metadata_as_list (NautilusFile *file, - const char *key, - char **value) +vfs_file_set_metadata_as_list (NautilusFile *file, + const char *key, + char **value) { - GFile *location; - GFileInfo *info; - char *gio_key; - - info = g_file_info_new (); - - gio_key = g_strconcat ("metadata::", key, NULL); - g_file_info_set_attribute_stringv (info, gio_key, value); - g_free (gio_key); - - location = nautilus_file_get_location (file); - g_file_set_attributes_async (location, - info, - 0, - G_PRIORITY_DEFAULT, - NULL, - set_metadata_callback, - nautilus_file_ref (file)); - g_object_unref (info); - g_object_unref (location); + GFile *location; + GFileInfo *info; + char *gio_key; + + info = g_file_info_new (); + + gio_key = g_strconcat ("metadata::", key, NULL); + g_file_info_set_attribute_stringv (info, gio_key, value); + g_free (gio_key); + + location = nautilus_file_get_location (file); + g_file_set_attributes_async (location, + info, + 0, + G_PRIORITY_DEFAULT, + NULL, + set_metadata_callback, + nautilus_file_ref (file)); + g_object_unref (info); + g_object_unref (location); } static gboolean -vfs_file_get_item_count (NautilusFile *file, - guint *count, - gboolean *count_unreadable) +vfs_file_get_item_count (NautilusFile *file, + guint *count, + gboolean *count_unreadable) { - if (count_unreadable != NULL) { - *count_unreadable = file->details->directory_count_failed; - } - if (!file->details->got_directory_count) { - if (count != NULL) { - *count = 0; - } - return FALSE; - } - if (count != NULL) { - *count = file->details->directory_count; - } - return TRUE; + if (count_unreadable != NULL) + { + *count_unreadable = file->details->directory_count_failed; + } + if (!file->details->got_directory_count) + { + if (count != NULL) + { + *count = 0; + } + return FALSE; + } + if (count != NULL) + { + *count = file->details->directory_count; + } + return TRUE; } static NautilusRequestStatus vfs_file_get_deep_counts (NautilusFile *file, - guint *directory_count, - guint *file_count, - guint *unreadable_directory_count, - goffset *total_size) + guint *directory_count, + guint *file_count, + guint *unreadable_directory_count, + goffset *total_size) { - GFileType type; - - if (directory_count != NULL) { - *directory_count = 0; - } - if (file_count != NULL) { - *file_count = 0; - } - if (unreadable_directory_count != NULL) { - *unreadable_directory_count = 0; - } - if (total_size != NULL) { - *total_size = 0; - } - - if (!nautilus_file_is_directory (file)) { - return NAUTILUS_REQUEST_DONE; - } - - if (file->details->deep_counts_status != NAUTILUS_REQUEST_NOT_STARTED) { - if (directory_count != NULL) { - *directory_count = file->details->deep_directory_count; - } - if (file_count != NULL) { - *file_count = file->details->deep_file_count; - } - if (unreadable_directory_count != NULL) { - *unreadable_directory_count = file->details->deep_unreadable_count; - } - if (total_size != NULL) { - *total_size = file->details->deep_size; - } - return file->details->deep_counts_status; - } - - /* For directories, or before we know the type, we haven't started. */ - type = nautilus_file_get_file_type (file); - if (type == G_FILE_TYPE_UNKNOWN - || type == G_FILE_TYPE_DIRECTORY) { - return NAUTILUS_REQUEST_NOT_STARTED; - } - - /* For other types, we are done, and the zeros are permanent. */ - return NAUTILUS_REQUEST_DONE; + GFileType type; + + if (directory_count != NULL) + { + *directory_count = 0; + } + if (file_count != NULL) + { + *file_count = 0; + } + if (unreadable_directory_count != NULL) + { + *unreadable_directory_count = 0; + } + if (total_size != NULL) + { + *total_size = 0; + } + + if (!nautilus_file_is_directory (file)) + { + return NAUTILUS_REQUEST_DONE; + } + + if (file->details->deep_counts_status != NAUTILUS_REQUEST_NOT_STARTED) + { + if (directory_count != NULL) + { + *directory_count = file->details->deep_directory_count; + } + if (file_count != NULL) + { + *file_count = file->details->deep_file_count; + } + if (unreadable_directory_count != NULL) + { + *unreadable_directory_count = file->details->deep_unreadable_count; + } + if (total_size != NULL) + { + *total_size = file->details->deep_size; + } + return file->details->deep_counts_status; + } + + /* For directories, or before we know the type, we haven't started. */ + type = nautilus_file_get_file_type (file); + if (type == G_FILE_TYPE_UNKNOWN + || type == G_FILE_TYPE_DIRECTORY) + { + return NAUTILUS_REQUEST_NOT_STARTED; + } + + /* For other types, we are done, and the zeros are permanent. */ + return NAUTILUS_REQUEST_DONE; } static gboolean -vfs_file_get_date (NautilusFile *file, - NautilusDateType date_type, - time_t *date) +vfs_file_get_date (NautilusFile *file, + NautilusDateType date_type, + time_t *date) { - switch (date_type) { - case NAUTILUS_DATE_TYPE_ACCESSED: - /* Before we have info on a file, the date is unknown. */ - if (file->details->atime == 0) { - return FALSE; - } - if (date != NULL) { - *date = file->details->atime; - } - return TRUE; - case NAUTILUS_DATE_TYPE_MODIFIED: - /* Before we have info on a file, the date is unknown. */ - if (file->details->mtime == 0) { - return FALSE; - } - if (date != NULL) { - *date = file->details->mtime; - } - return TRUE; - case NAUTILUS_DATE_TYPE_TRASHED: - /* Before we have info on a file, the date is unknown. */ - if (file->details->trash_time == 0) { - return FALSE; - } - if (date != NULL) { - *date = file->details->trash_time; - } - return TRUE; - } - return FALSE; + switch (date_type) + { + case NAUTILUS_DATE_TYPE_ACCESSED: + { + /* Before we have info on a file, the date is unknown. */ + if (file->details->atime == 0) + { + return FALSE; + } + if (date != NULL) + { + *date = file->details->atime; + } + return TRUE; + } + + case NAUTILUS_DATE_TYPE_MODIFIED: + { + /* Before we have info on a file, the date is unknown. */ + if (file->details->mtime == 0) + { + return FALSE; + } + if (date != NULL) + { + *date = file->details->mtime; + } + return TRUE; + } + + case NAUTILUS_DATE_TYPE_TRASHED: + /* Before we have info on a file, the date is unknown. */ + if (file->details->trash_time == 0) + { + return FALSE; + } + if (date != NULL) + { + *date = file->details->trash_time; + } + return TRUE; + } + return FALSE; } static char * vfs_file_get_where_string (NautilusFile *file) { - GFile *activation_location; - NautilusFile *location; - char *where_string; - - if (!nautilus_file_is_in_recent (file)) { - location = nautilus_file_ref (file); - } else { - activation_location = nautilus_file_get_activation_location (file); - location = nautilus_file_get (activation_location); - g_object_unref (activation_location); - } - - where_string = nautilus_file_get_parent_uri_for_display (location); - - nautilus_file_unref (location); - return where_string; + GFile *activation_location; + NautilusFile *location; + char *where_string; + + if (!nautilus_file_is_in_recent (file)) + { + location = nautilus_file_ref (file); + } + else + { + activation_location = nautilus_file_get_activation_location (file); + location = nautilus_file_get (activation_location); + g_object_unref (activation_location); + } + + where_string = nautilus_file_get_parent_uri_for_display (location); + + nautilus_file_unref (location); + return where_string; } static void -vfs_file_mount_callback (GObject *source_object, - GAsyncResult *res, - gpointer callback_data) +vfs_file_mount_callback (GObject *source_object, + GAsyncResult *res, + gpointer callback_data) { - NautilusFileOperation *op; - GFile *mounted_on; - GError *error; - - op = callback_data; - - error = NULL; - mounted_on = g_file_mount_mountable_finish (G_FILE (source_object), - res, &error); - nautilus_file_operation_complete (op, mounted_on, error); - if (mounted_on) { - g_object_unref (mounted_on); - } - if (error) { - g_error_free (error); - } + NautilusFileOperation *op; + GFile *mounted_on; + GError *error; + + op = callback_data; + + error = NULL; + mounted_on = g_file_mount_mountable_finish (G_FILE (source_object), + res, &error); + nautilus_file_operation_complete (op, mounted_on, error); + if (mounted_on) + { + g_object_unref (mounted_on); + } + if (error) + { + g_error_free (error); + } } static void -vfs_file_mount (NautilusFile *file, - GMountOperation *mount_op, - GCancellable *cancellable, - NautilusFileOperationCallback callback, - gpointer callback_data) +vfs_file_mount (NautilusFile *file, + GMountOperation *mount_op, + GCancellable *cancellable, + NautilusFileOperationCallback callback, + gpointer callback_data) { - NautilusFileOperation *op; - GError *error; - GFile *location; - - if (file->details->type != G_FILE_TYPE_MOUNTABLE) { - if (callback) { - error = NULL; - g_set_error_literal (&error, G_IO_ERROR, G_IO_ERROR_NOT_SUPPORTED, - _("This file cannot be mounted")); - callback (file, NULL, error, callback_data); - g_error_free (error); - } - return; - } - - op = nautilus_file_operation_new (file, callback, callback_data); - if (cancellable) { - g_object_unref (op->cancellable); - op->cancellable = g_object_ref (cancellable); - } - - location = nautilus_file_get_location (file); - g_file_mount_mountable (location, - 0, - mount_op, - op->cancellable, - vfs_file_mount_callback, - op); - g_object_unref (location); + NautilusFileOperation *op; + GError *error; + GFile *location; + + if (file->details->type != G_FILE_TYPE_MOUNTABLE) + { + if (callback) + { + error = NULL; + g_set_error_literal (&error, G_IO_ERROR, G_IO_ERROR_NOT_SUPPORTED, + _("This file cannot be mounted")); + callback (file, NULL, error, callback_data); + g_error_free (error); + } + return; + } + + op = nautilus_file_operation_new (file, callback, callback_data); + if (cancellable) + { + g_object_unref (op->cancellable); + op->cancellable = g_object_ref (cancellable); + } + + location = nautilus_file_get_location (file); + g_file_mount_mountable (location, + 0, + mount_op, + op->cancellable, + vfs_file_mount_callback, + op); + g_object_unref (location); } static void -vfs_file_unmount_callback (GObject *source_object, - GAsyncResult *res, - gpointer callback_data) +vfs_file_unmount_callback (GObject *source_object, + GAsyncResult *res, + gpointer callback_data) { - NautilusFileOperation *op; - gboolean unmounted; - GError *error; + NautilusFileOperation *op; + gboolean unmounted; + GError *error; + + op = callback_data; - op = callback_data; + error = NULL; + unmounted = g_file_unmount_mountable_with_operation_finish (G_FILE (source_object), + res, &error); - error = NULL; - unmounted = g_file_unmount_mountable_with_operation_finish (G_FILE (source_object), - res, &error); - if (!unmounted && - error->domain == G_IO_ERROR && - (error->code == G_IO_ERROR_FAILED_HANDLED || - error->code == G_IO_ERROR_CANCELLED)) { - g_error_free (error); - error = NULL; + error->domain == G_IO_ERROR && + (error->code == G_IO_ERROR_FAILED_HANDLED || + error->code == G_IO_ERROR_CANCELLED)) + { + g_error_free (error); + error = NULL; } nautilus_file_operation_complete (op, G_FILE (source_object), error); - if (error) { - g_error_free (error); - } + if (error) + { + g_error_free (error); + } } static void -vfs_file_unmount (NautilusFile *file, - GMountOperation *mount_op, - GCancellable *cancellable, - NautilusFileOperationCallback callback, - gpointer callback_data) +vfs_file_unmount (NautilusFile *file, + GMountOperation *mount_op, + GCancellable *cancellable, + NautilusFileOperationCallback callback, + gpointer callback_data) { - NautilusFileOperation *op; - GFile *location; - - op = nautilus_file_operation_new (file, callback, callback_data); - if (cancellable) { - g_object_unref (op->cancellable); - op->cancellable = g_object_ref (cancellable); - } - - location = nautilus_file_get_location (file); - g_file_unmount_mountable_with_operation (location, - G_MOUNT_UNMOUNT_NONE, - mount_op, - op->cancellable, - vfs_file_unmount_callback, - op); - g_object_unref (location); + NautilusFileOperation *op; + GFile *location; + + op = nautilus_file_operation_new (file, callback, callback_data); + if (cancellable) + { + g_object_unref (op->cancellable); + op->cancellable = g_object_ref (cancellable); + } + + location = nautilus_file_get_location (file); + g_file_unmount_mountable_with_operation (location, + G_MOUNT_UNMOUNT_NONE, + mount_op, + op->cancellable, + vfs_file_unmount_callback, + op); + g_object_unref (location); } static void -vfs_file_eject_callback (GObject *source_object, - GAsyncResult *res, - gpointer callback_data) +vfs_file_eject_callback (GObject *source_object, + GAsyncResult *res, + gpointer callback_data) { - NautilusFileOperation *op; - gboolean ejected; - GError *error; - - op = callback_data; - - error = NULL; - ejected = g_file_eject_mountable_with_operation_finish (G_FILE (source_object), - res, &error); - - if (!ejected && - error->domain == G_IO_ERROR && - (error->code == G_IO_ERROR_FAILED_HANDLED || - error->code == G_IO_ERROR_CANCELLED)) { - g_error_free (error); - error = NULL; - } - - nautilus_file_operation_complete (op, G_FILE (source_object), error); - if (error) { - g_error_free (error); - } + NautilusFileOperation *op; + gboolean ejected; + GError *error; + + op = callback_data; + + error = NULL; + ejected = g_file_eject_mountable_with_operation_finish (G_FILE (source_object), + res, &error); + + if (!ejected && + error->domain == G_IO_ERROR && + (error->code == G_IO_ERROR_FAILED_HANDLED || + error->code == G_IO_ERROR_CANCELLED)) + { + g_error_free (error); + error = NULL; + } + + nautilus_file_operation_complete (op, G_FILE (source_object), error); + if (error) + { + g_error_free (error); + } } static void -vfs_file_eject (NautilusFile *file, - GMountOperation *mount_op, - GCancellable *cancellable, - NautilusFileOperationCallback callback, - gpointer callback_data) +vfs_file_eject (NautilusFile *file, + GMountOperation *mount_op, + GCancellable *cancellable, + NautilusFileOperationCallback callback, + gpointer callback_data) { - NautilusFileOperation *op; - GFile *location; - - op = nautilus_file_operation_new (file, callback, callback_data); - if (cancellable) { - g_object_unref (op->cancellable); - op->cancellable = g_object_ref (cancellable); - } - - location = nautilus_file_get_location (file); - g_file_eject_mountable_with_operation (location, - G_MOUNT_UNMOUNT_NONE, - mount_op, - op->cancellable, - vfs_file_eject_callback, - op); - g_object_unref (location); + NautilusFileOperation *op; + GFile *location; + + op = nautilus_file_operation_new (file, callback, callback_data); + if (cancellable) + { + g_object_unref (op->cancellable); + op->cancellable = g_object_ref (cancellable); + } + + location = nautilus_file_get_location (file); + g_file_eject_mountable_with_operation (location, + G_MOUNT_UNMOUNT_NONE, + mount_op, + op->cancellable, + vfs_file_eject_callback, + op); + g_object_unref (location); } static void -vfs_file_start_callback (GObject *source_object, - GAsyncResult *res, - gpointer callback_data) +vfs_file_start_callback (GObject *source_object, + GAsyncResult *res, + gpointer callback_data) { - NautilusFileOperation *op; - gboolean started; - GError *error; - - op = callback_data; - - error = NULL; - started = g_file_start_mountable_finish (G_FILE (source_object), - res, &error); - - if (!started && - error->domain == G_IO_ERROR && - (error->code == G_IO_ERROR_FAILED_HANDLED || - error->code == G_IO_ERROR_CANCELLED)) { - g_error_free (error); - error = NULL; - } - - nautilus_file_operation_complete (op, G_FILE (source_object), error); - if (error) { - g_error_free (error); - } + NautilusFileOperation *op; + gboolean started; + GError *error; + + op = callback_data; + + error = NULL; + started = g_file_start_mountable_finish (G_FILE (source_object), + res, &error); + + if (!started && + error->domain == G_IO_ERROR && + (error->code == G_IO_ERROR_FAILED_HANDLED || + error->code == G_IO_ERROR_CANCELLED)) + { + g_error_free (error); + error = NULL; + } + + nautilus_file_operation_complete (op, G_FILE (source_object), error); + if (error) + { + g_error_free (error); + } } static void -vfs_file_start (NautilusFile *file, - GMountOperation *mount_op, - GCancellable *cancellable, - NautilusFileOperationCallback callback, - gpointer callback_data) +vfs_file_start (NautilusFile *file, + GMountOperation *mount_op, + GCancellable *cancellable, + NautilusFileOperationCallback callback, + gpointer callback_data) { - NautilusFileOperation *op; - GError *error; - GFile *location; - - if (file->details->type != G_FILE_TYPE_MOUNTABLE) { - if (callback) { - error = NULL; - g_set_error_literal (&error, G_IO_ERROR, G_IO_ERROR_NOT_SUPPORTED, - _("This file cannot be started")); - callback (file, NULL, error, callback_data); - g_error_free (error); - } - return; - } - - op = nautilus_file_operation_new (file, callback, callback_data); - if (cancellable) { - g_object_unref (op->cancellable); - op->cancellable = g_object_ref (cancellable); - } - - location = nautilus_file_get_location (file); - g_file_start_mountable (location, - 0, - mount_op, - op->cancellable, - vfs_file_start_callback, - op); - g_object_unref (location); + NautilusFileOperation *op; + GError *error; + GFile *location; + + if (file->details->type != G_FILE_TYPE_MOUNTABLE) + { + if (callback) + { + error = NULL; + g_set_error_literal (&error, G_IO_ERROR, G_IO_ERROR_NOT_SUPPORTED, + _("This file cannot be started")); + callback (file, NULL, error, callback_data); + g_error_free (error); + } + return; + } + + op = nautilus_file_operation_new (file, callback, callback_data); + if (cancellable) + { + g_object_unref (op->cancellable); + op->cancellable = g_object_ref (cancellable); + } + + location = nautilus_file_get_location (file); + g_file_start_mountable (location, + 0, + mount_op, + op->cancellable, + vfs_file_start_callback, + op); + g_object_unref (location); } static void -vfs_file_stop_callback (GObject *source_object, - GAsyncResult *res, - gpointer callback_data) +vfs_file_stop_callback (GObject *source_object, + GAsyncResult *res, + gpointer callback_data) { - NautilusFileOperation *op; - gboolean stopped; - GError *error; - - op = callback_data; - - error = NULL; - stopped = g_file_stop_mountable_finish (G_FILE (source_object), - res, &error); - - if (!stopped && - error->domain == G_IO_ERROR && - (error->code == G_IO_ERROR_FAILED_HANDLED || - error->code == G_IO_ERROR_CANCELLED)) { - g_error_free (error); - error = NULL; - } - - nautilus_file_operation_complete (op, G_FILE (source_object), error); - if (error) { - g_error_free (error); - } + NautilusFileOperation *op; + gboolean stopped; + GError *error; + + op = callback_data; + + error = NULL; + stopped = g_file_stop_mountable_finish (G_FILE (source_object), + res, &error); + + if (!stopped && + error->domain == G_IO_ERROR && + (error->code == G_IO_ERROR_FAILED_HANDLED || + error->code == G_IO_ERROR_CANCELLED)) + { + g_error_free (error); + error = NULL; + } + + nautilus_file_operation_complete (op, G_FILE (source_object), error); + if (error) + { + g_error_free (error); + } } static void -vfs_file_stop (NautilusFile *file, - GMountOperation *mount_op, - GCancellable *cancellable, - NautilusFileOperationCallback callback, - gpointer callback_data) +vfs_file_stop (NautilusFile *file, + GMountOperation *mount_op, + GCancellable *cancellable, + NautilusFileOperationCallback callback, + gpointer callback_data) { - NautilusFileOperation *op; - GFile *location; - - op = nautilus_file_operation_new (file, callback, callback_data); - if (cancellable) { - g_object_unref (op->cancellable); - op->cancellable = g_object_ref (cancellable); - } - - location = nautilus_file_get_location (file); - g_file_stop_mountable (location, - G_MOUNT_UNMOUNT_NONE, - mount_op, - op->cancellable, - vfs_file_stop_callback, - op); - g_object_unref (location); + NautilusFileOperation *op; + GFile *location; + + op = nautilus_file_operation_new (file, callback, callback_data); + if (cancellable) + { + g_object_unref (op->cancellable); + op->cancellable = g_object_ref (cancellable); + } + + location = nautilus_file_get_location (file); + g_file_stop_mountable (location, + G_MOUNT_UNMOUNT_NONE, + mount_op, + op->cancellable, + vfs_file_stop_callback, + op); + g_object_unref (location); } static void -vfs_file_poll_callback (GObject *source_object, - GAsyncResult *res, - gpointer callback_data) +vfs_file_poll_callback (GObject *source_object, + GAsyncResult *res, + gpointer callback_data) { - NautilusFileOperation *op; - gboolean stopped; - GError *error; - - op = callback_data; - - error = NULL; - stopped = g_file_poll_mountable_finish (G_FILE (source_object), - res, &error); - - if (!stopped && - error->domain == G_IO_ERROR && - (error->code == G_IO_ERROR_FAILED_HANDLED || - error->code == G_IO_ERROR_CANCELLED)) { - g_error_free (error); - error = NULL; - } - - nautilus_file_operation_complete (op, G_FILE (source_object), error); - if (error) { - g_error_free (error); - } + NautilusFileOperation *op; + gboolean stopped; + GError *error; + + op = callback_data; + + error = NULL; + stopped = g_file_poll_mountable_finish (G_FILE (source_object), + res, &error); + + if (!stopped && + error->domain == G_IO_ERROR && + (error->code == G_IO_ERROR_FAILED_HANDLED || + error->code == G_IO_ERROR_CANCELLED)) + { + g_error_free (error); + error = NULL; + } + + nautilus_file_operation_complete (op, G_FILE (source_object), error); + if (error) + { + g_error_free (error); + } } static void vfs_file_poll_for_media (NautilusFile *file) { - NautilusFileOperation *op; - GFile *location; + NautilusFileOperation *op; + GFile *location; - op = nautilus_file_operation_new (file, NULL, NULL); + op = nautilus_file_operation_new (file, NULL, NULL); - location = nautilus_file_get_location (file); - g_file_poll_mountable (location, - op->cancellable, - vfs_file_poll_callback, - op); - g_object_unref (location); + location = nautilus_file_get_location (file); + g_file_poll_mountable (location, + op->cancellable, + vfs_file_poll_callback, + op); + g_object_unref (location); } static void @@ -674,23 +734,23 @@ nautilus_vfs_file_init (NautilusVFSFile *file) static void nautilus_vfs_file_class_init (NautilusVFSFileClass *klass) { - NautilusFileClass *file_class = NAUTILUS_FILE_CLASS (klass); - - file_class->monitor_add = vfs_file_monitor_add; - file_class->monitor_remove = vfs_file_monitor_remove; - file_class->call_when_ready = vfs_file_call_when_ready; - file_class->cancel_call_when_ready = vfs_file_cancel_call_when_ready; - file_class->check_if_ready = vfs_file_check_if_ready; - file_class->get_item_count = vfs_file_get_item_count; - file_class->get_deep_counts = vfs_file_get_deep_counts; - file_class->get_date = vfs_file_get_date; - file_class->get_where_string = vfs_file_get_where_string; - file_class->set_metadata = vfs_file_set_metadata; - file_class->set_metadata_as_list = vfs_file_set_metadata_as_list; - file_class->mount = vfs_file_mount; - file_class->unmount = vfs_file_unmount; - file_class->eject = vfs_file_eject; - file_class->start = vfs_file_start; - file_class->stop = vfs_file_stop; - file_class->poll_for_media = vfs_file_poll_for_media; + NautilusFileClass *file_class = NAUTILUS_FILE_CLASS (klass); + + file_class->monitor_add = vfs_file_monitor_add; + file_class->monitor_remove = vfs_file_monitor_remove; + file_class->call_when_ready = vfs_file_call_when_ready; + file_class->cancel_call_when_ready = vfs_file_cancel_call_when_ready; + file_class->check_if_ready = vfs_file_check_if_ready; + file_class->get_item_count = vfs_file_get_item_count; + file_class->get_deep_counts = vfs_file_get_deep_counts; + file_class->get_date = vfs_file_get_date; + file_class->get_where_string = vfs_file_get_where_string; + file_class->set_metadata = vfs_file_set_metadata; + file_class->set_metadata_as_list = vfs_file_set_metadata_as_list; + file_class->mount = vfs_file_mount; + file_class->unmount = vfs_file_unmount; + file_class->eject = vfs_file_eject; + file_class->start = vfs_file_start; + file_class->stop = vfs_file_stop; + file_class->poll_for_media = vfs_file_poll_for_media; } |