mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-08-01 23:13:40 +02:00
Rework how volumes, drives and volume monitoring is done. Previosly the
2007-12-11 David Zeuthen <davidz@redhat.com> Rework how volumes, drives and volume monitoring is done. Previosly the model was GDrive <1-1> GVolume where a GDrive instance represented a mount point and a GVolume instance represented a mounted file system. This patch changes it the model to GDrive <1-N> GVolume <1-1> GMount where GMount now serves the purpose of the old GVolume and the new GVolume serves the purpose of the old GDrive. In addition the new GDrive interface is used to represent a collection of GVolume instances (typically partitions) and also contains utility to query the state of the physical drive the GDrive object represents (such as checking for media, polling the drive, ejecting the media etc.). Also implement mounting and unmounting in the Unix volume monitor backend. A subquent patch will introduce GDrive support for ejection of media. * Makefile.am: * gdrive.c: (g_drive_is_media_check_automatic), (g_drive_is_media_removable), (g_drive_has_media), (g_drive_can_poll_for_media), (g_drive_eject), (g_drive_eject_finish), (g_drive_poll_for_media), (g_drive_poll_for_media_finish): * gdrive.h: * gfile.c: (g_file_find_enclosing_mount): * gfile.h: * gio.symbols: * glocaldirectorymonitor.c: (g_local_directory_monitor_constructor), (mounts_changed): * glocalfile.c: (get_mount_info), (g_local_file_find_enclosing_mount), (g_local_file_file_iface_init): * gnativevolumemonitor.h: * gunionvolumemonitor.c: (get_mounts), (get_volumes), (get_connected_drives), (g_union_volume_monitor_class_init), (child_volume_added), (child_volume_removed), (child_volume_changed), (child_mount_added), (child_mount_removed), (child_mount_pre_unmount), (child_mount_changed), (child_drive_changed), (g_union_volume_monitor_add_monitor), (g_union_volume_monitor_remove_monitor), (_g_mount_get_for_mount_path): * gunixmounts.c: (g_unix_is_mount_path_system_internal), (guess_system_internal), (_g_get_unix_mounts), (_g_get_unix_mount_points), (g_get_unix_mount_at), (g_unix_mount_free), (g_unix_mount_compare), (g_unix_mount_get_mount_path), (g_unix_mount_get_device_path), (g_unix_mount_get_fs_type), (g_unix_mount_is_readonly), (g_unix_mount_is_system_internal), (g_unix_mount_guess_type), (type_to_icon), (g_unix_mount_guess_name), (g_unix_mount_guess_icon), (g_unix_mount_point_guess_name), (g_unix_mount_point_guess_icon), (_canonicalize_filename), (_resolve_symlink), (_resolve_dev_root): * gunixmounts.h: * gunixvolume.c: (g_unix_volume_finalize), (_g_unix_volume_new), (_g_unix_volume_disconnected), (_g_unix_volume_set_mount), (_g_unix_volume_unset_mount), (g_unix_volume_get_icon), (g_unix_volume_get_name), (g_unix_volume_can_mount), (g_unix_volume_get_drive), (g_unix_volume_get_mount), (_g_unix_volume_has_mount_path), (mount_cb), (mount_read_error), (g_unix_volume_mount), (g_unix_volume_mount_finish), (g_unix_volume_volume_iface_init): * gunixvolume.h: * gunixvolumemonitor.c: (g_unix_volume_monitor_finalize), (get_mounts), (get_volumes), (get_connected_drives), (get_mount_for_mount_path), (g_unix_volume_monitor_class_init), (mountpoints_changed), (mounts_changed), (g_unix_volume_monitor_init), (_g_unix_volume_monitor_lookup_volume_for_mount_path), (find_mount_by_mountpath), (update_volumes), (update_mounts): * gunixvolumemonitor.h: * gvolume.c: (g_volume_get_mount), (g_volume_can_mount), (g_volume_mount), (g_volume_mount_finish): * gvolume.h: * gvolumemonitor.c: (g_volume_monitor_class_init), (g_volume_monitor_get_connected_drives), (g_volume_monitor_get_volumes), (g_volume_monitor_get_mounts): * gvolumemonitor.h: svn path=/trunk/; revision=6095
This commit is contained in:
committed by
David Zeuthen
parent
c2643afd24
commit
3ca9fd4dbb
205
gio/gdrive.c
205
gio/gdrive.c
@@ -18,6 +18,7 @@
|
||||
* Boston, MA 02111-1307, USA.
|
||||
*
|
||||
* Author: Alexander Larsson <alexl@redhat.com>
|
||||
* David Zeuthen <davidz@redhat.com>
|
||||
*/
|
||||
|
||||
#include <config.h>
|
||||
@@ -32,9 +33,19 @@
|
||||
* @short_description: Virtual File System drive management
|
||||
* @include: gio/gdrive.h
|
||||
*
|
||||
* #GDrive manages drive operations from GVFS, including volume mounting
|
||||
* and ejecting, and getting the drive's name and icon.
|
||||
*
|
||||
* #GDrive is a container class for #GVolume objects that stem from
|
||||
* the same piece of media. As such, #GDrive abstracts a drive with
|
||||
* (or without) removable media and provides operations for querying
|
||||
* whether media is available, determing whether media change is
|
||||
* automatically detected and ejecting the media.
|
||||
*
|
||||
* If the #GDrive reports that media isn't automatically detected, one
|
||||
* can poll for media; typically one should not do this periodically
|
||||
* as a poll for media operation is potententially expensive and may
|
||||
* spin up the drive creating noise.
|
||||
*
|
||||
* For porting from GnomeVFS note that there is no equivalent of
|
||||
* #GDrive in that API.
|
||||
**/
|
||||
|
||||
static void g_drive_base_init (gpointer g_class);
|
||||
@@ -148,9 +159,9 @@ g_drive_get_icon (GDrive *drive)
|
||||
* g_drive_has_volumes:
|
||||
* @drive: a #GDrive.
|
||||
*
|
||||
* Checks if a drive has any volumes.
|
||||
* Check if @drive has any mountable volumes.
|
||||
*
|
||||
* Returns: %TRUE if @drive contains volumes, %FALSE otherwise.
|
||||
* Returns: %TRUE if the @drive contains volumes, %FALSE otherwise.
|
||||
**/
|
||||
gboolean
|
||||
g_drive_has_volumes (GDrive *drive)
|
||||
@@ -168,10 +179,9 @@ g_drive_has_volumes (GDrive *drive)
|
||||
* g_drive_get_volumes:
|
||||
* @drive: a #GDrive.
|
||||
*
|
||||
* Gets a list of volumes for a drive.
|
||||
* Get a list of mountable volumes for @drive.
|
||||
*
|
||||
* Returns: #GList containing any #GVolume<!---->s on the given @drive.
|
||||
* <!-- NOTE: Fact-check this. -->
|
||||
**/
|
||||
GList *
|
||||
g_drive_get_volumes (GDrive *drive)
|
||||
@@ -186,15 +196,15 @@ g_drive_get_volumes (GDrive *drive)
|
||||
}
|
||||
|
||||
/**
|
||||
* g_drive_is_automounted:
|
||||
* g_drive_is_media_check_automatic:
|
||||
* @drive: a #GDrive.
|
||||
*
|
||||
* Checks if a drive was automatically mounted, e.g. by HAL.
|
||||
* Checks if @drive is capabable of automatically detecting media changes.
|
||||
*
|
||||
* Returns: %TRUE if the drive was automounted. %FALSE otherwise.
|
||||
* Returns: %TRUE if the @drive is capabable of automatically detecting media changes, %FALSE otherwise.
|
||||
**/
|
||||
gboolean
|
||||
g_drive_is_automounted (GDrive *drive)
|
||||
g_drive_is_media_check_automatic (GDrive *drive)
|
||||
{
|
||||
GDriveIface *iface;
|
||||
|
||||
@@ -202,19 +212,19 @@ g_drive_is_automounted (GDrive *drive)
|
||||
|
||||
iface = G_DRIVE_GET_IFACE (drive);
|
||||
|
||||
return (* iface->is_automounted) (drive);
|
||||
return (* iface->is_media_check_automatic) (drive);
|
||||
}
|
||||
|
||||
/**
|
||||
* g_drive_can_mount:
|
||||
* g_drive_is_media_removable:
|
||||
* @drive: a #GDrive.
|
||||
*
|
||||
* Checks if a drive can be mounted.
|
||||
* Checks if the @drive supports removable media.
|
||||
*
|
||||
* Returns: %TRUE if the @drive can be mounted. %FALSE otherwise.
|
||||
* Returns: %TRUE if @drive supports removable media, %FALSE otherwise.
|
||||
**/
|
||||
gboolean
|
||||
g_drive_can_mount (GDrive *drive)
|
||||
g_drive_is_media_removable (GDrive *drive)
|
||||
{
|
||||
GDriveIface *iface;
|
||||
|
||||
@@ -222,10 +232,29 @@ g_drive_can_mount (GDrive *drive)
|
||||
|
||||
iface = G_DRIVE_GET_IFACE (drive);
|
||||
|
||||
if (iface->can_mount == NULL)
|
||||
return FALSE;
|
||||
return (* iface->is_media_removable) (drive);
|
||||
}
|
||||
|
||||
return (* iface->can_mount) (drive);
|
||||
/**
|
||||
* g_drive_has_media:
|
||||
* @drive: a #GDrive.
|
||||
*
|
||||
* Checks if the @drive has media. Note that the OS may not be polling
|
||||
* the drive for media changes; see g_drive_is_media_check_automatic()
|
||||
* for more details.
|
||||
*
|
||||
* Returns: %TRUE if @drive has media, %FALSE otherwise.
|
||||
**/
|
||||
gboolean
|
||||
g_drive_has_media (GDrive *drive)
|
||||
{
|
||||
GDriveIface *iface;
|
||||
|
||||
g_return_val_if_fail (G_IS_DRIVE (drive), FALSE);
|
||||
|
||||
iface = G_DRIVE_GET_IFACE (drive);
|
||||
|
||||
return (* iface->has_media) (drive);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -252,74 +281,26 @@ g_drive_can_eject (GDrive *drive)
|
||||
}
|
||||
|
||||
/**
|
||||
* g_drive_mount:
|
||||
* g_drive_can_poll_for_media:
|
||||
* @drive: a #GDrive.
|
||||
* @mount_operation: a #GMountOperation.
|
||||
* @cancellable: optional #GCancellable object, %NULL to ignore.
|
||||
* @callback: a #GAsyncReadyCallback.
|
||||
* @user_data: a #gpointer.
|
||||
*
|
||||
* Mounts a drive.
|
||||
**/
|
||||
void
|
||||
g_drive_mount (GDrive *drive,
|
||||
GMountOperation *mount_operation,
|
||||
GCancellable *cancellable,
|
||||
GAsyncReadyCallback callback,
|
||||
gpointer user_data)
|
||||
{
|
||||
GDriveIface *iface;
|
||||
|
||||
g_return_if_fail (G_IS_DRIVE (drive));
|
||||
g_return_if_fail (G_IS_MOUNT_OPERATION (mount_operation));
|
||||
|
||||
iface = G_DRIVE_GET_IFACE (drive);
|
||||
|
||||
if (iface->mount_fn == NULL)
|
||||
{
|
||||
g_simple_async_report_error_in_idle (G_OBJECT (drive), callback, user_data,
|
||||
G_IO_ERROR, G_IO_ERROR_NOT_SUPPORTED,
|
||||
_("drive doesn't implement mount"));
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
(* iface->mount_fn) (drive, mount_operation, cancellable, callback, user_data);
|
||||
}
|
||||
|
||||
/**
|
||||
* g_drive_mount_finish:
|
||||
* @drive: a #GDrive.
|
||||
* @result: a #GAsyncResult.
|
||||
* @error: a #GError.
|
||||
* Checks if a drive can be polled for media changes.
|
||||
*
|
||||
* Finishes mounting a drive.
|
||||
*
|
||||
* If the @drive's interface does not implement the mount operation, @error will
|
||||
* be set to %G_IO_ERROR_NOT_SUPPORTED and %FALSE will be returned.
|
||||
*
|
||||
* Returns: %TRUE if the mount was finished successfully,
|
||||
* %FALSE if operation failed.
|
||||
* Returns: %TRUE if the @drive can be polled for media changes. %FALSE otherwise.
|
||||
**/
|
||||
gboolean
|
||||
g_drive_mount_finish (GDrive *drive,
|
||||
GAsyncResult *result,
|
||||
GError **error)
|
||||
g_drive_can_poll_for_media (GDrive *drive)
|
||||
{
|
||||
GDriveIface *iface;
|
||||
|
||||
g_return_val_if_fail (G_IS_DRIVE (drive), FALSE);
|
||||
g_return_val_if_fail (G_IS_ASYNC_RESULT (result), FALSE);
|
||||
|
||||
if (G_IS_SIMPLE_ASYNC_RESULT (result))
|
||||
{
|
||||
GSimpleAsyncResult *simple = G_SIMPLE_ASYNC_RESULT (result);
|
||||
if (g_simple_async_result_propagate_error (simple, error))
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
iface = G_DRIVE_GET_IFACE (drive);
|
||||
return (* iface->mount_finish) (drive, result, error);
|
||||
|
||||
if (iface->poll_for_media == NULL)
|
||||
return FALSE;
|
||||
|
||||
return (* iface->can_poll_for_media) (drive);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -363,9 +344,6 @@ g_drive_eject (GDrive *drive,
|
||||
* @error: a #GError.
|
||||
*
|
||||
* Finishes ejecting a drive.
|
||||
*
|
||||
* If @drive's interface does not implement the eject operation, @error will
|
||||
* be set to %G_IO_ERROR_NOT_SUPPORTED and %FALSE will be returned.
|
||||
*
|
||||
* Returns: %TRUE if the drive has been ejected successfully,
|
||||
* %FALSE otherwise.
|
||||
@@ -389,7 +367,74 @@ g_drive_eject_finish (GDrive *drive,
|
||||
|
||||
iface = G_DRIVE_GET_IFACE (drive);
|
||||
|
||||
return (* iface->mount_finish) (drive, result, error);
|
||||
return (* iface->eject_finish) (drive, result, error);
|
||||
}
|
||||
|
||||
/**
|
||||
* g_drive_poll_for_media:
|
||||
* @drive: a #GDrive.
|
||||
* @cancellable: optional #GCancellable object, %NULL to ignore.
|
||||
* @callback: a #GAsyncReadyCallback.
|
||||
* @user_data: a #gpointer.
|
||||
*
|
||||
* Polls @drive to see if media has been inserted or removed.
|
||||
*
|
||||
**/
|
||||
void
|
||||
g_drive_poll_for_media (GDrive *drive,
|
||||
GCancellable *cancellable,
|
||||
GAsyncReadyCallback callback,
|
||||
gpointer user_data)
|
||||
{
|
||||
GDriveIface *iface;
|
||||
|
||||
g_return_if_fail (G_IS_DRIVE (drive));
|
||||
|
||||
iface = G_DRIVE_GET_IFACE (drive);
|
||||
|
||||
if (iface->poll_for_media == NULL)
|
||||
{
|
||||
g_simple_async_report_error_in_idle (G_OBJECT (drive), callback, user_data,
|
||||
G_IO_ERROR, G_IO_ERROR_NOT_SUPPORTED,
|
||||
_("drive doesn't implement polling for media"));
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
(* iface->poll_for_media) (drive, cancellable, callback, user_data);
|
||||
}
|
||||
|
||||
/**
|
||||
* g_drive_poll_for_media_finish
|
||||
* @drive: a #GDrive.
|
||||
* @result: a #GAsyncResult.
|
||||
* @error: a #GError.
|
||||
*
|
||||
* Finishes poll_for_mediaing a drive.
|
||||
*
|
||||
* Returns: %TRUE if the drive has been poll_for_mediaed successfully,
|
||||
* %FALSE otherwise.
|
||||
**/
|
||||
gboolean
|
||||
g_drive_poll_for_media_finish (GDrive *drive,
|
||||
GAsyncResult *result,
|
||||
GError **error)
|
||||
{
|
||||
GDriveIface *iface;
|
||||
|
||||
g_return_val_if_fail (G_IS_DRIVE (drive), FALSE);
|
||||
g_return_val_if_fail (G_IS_ASYNC_RESULT (result), FALSE);
|
||||
|
||||
if (G_IS_SIMPLE_ASYNC_RESULT (result))
|
||||
{
|
||||
GSimpleAsyncResult *simple = G_SIMPLE_ASYNC_RESULT (result);
|
||||
if (g_simple_async_result_propagate_error (simple, error))
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
iface = G_DRIVE_GET_IFACE (drive);
|
||||
|
||||
return (* iface->poll_for_media_finish) (drive, result, error);
|
||||
}
|
||||
|
||||
#define __G_DRIVE_C__
|
||||
|
Reference in New Issue
Block a user