|  |  |  | GIO Reference Manual |  | 
|---|---|---|---|---|
#include <gio.h>
                    GVolumeMonitor;
GVolumeMonitor*     g_volume_monitor_get                (void);
GList*              g_volume_monitor_get_connected_drives
                                                        (GVolumeMonitor *volume_monitor);
GList*              g_volume_monitor_get_volumes        (GVolumeMonitor *volume_monitor);
GList*              g_volume_monitor_get_mounts         (GVolumeMonitor *volume_monitor);
GVolume*            g_volume_monitor_adopt_orphan_mount (GMount *mount);
GMount*             g_volume_monitor_get_mount_for_uuid (GVolumeMonitor *volume_monitor,
                                                         const char *uuid);
GVolume*            g_volume_monitor_get_volume_for_uuid
                                                        (GVolumeMonitor *volume_monitor,
                                                         const char *uuid);
"drive-changed" : Run Last "drive-connected" : Run Last "drive-disconnected" : Run Last "mount-added" : Run Last "mount-changed" : Run Last "mount-pre-unmount" : Run Last "mount-removed" : Run Last "volume-added" : Run Last "volume-changed" : Run Last "volume-removed" : Run Last
GVolumeMonitor is for listing the user interesting devices and volumes on the computer. In other words, what a file selector or file manager would show in a sidebar.
typedef struct _GVolumeMonitor GVolumeMonitor;
A Volume Monitor that watches for volume events.
GVolumeMonitor* g_volume_monitor_get (void);
Gets the volume monitor used by gio.
| Returns : | a reference to the GVolumeMonitor used by gio. Call g_object_unref()when done with it. | 
GList* g_volume_monitor_get_connected_drives (GVolumeMonitor *volume_monitor);
Gets a list of drives connected to the system.
The returned list should be freed with g_list_free(), but
its elements need not be freed.
| 
 | a GVolumeMonitor. | 
| Returns : | a GList of connected GDrives - free with g_list_free(). | 
GList* g_volume_monitor_get_volumes (GVolumeMonitor *volume_monitor);
Gets a list of the volumes on the system.
The returned list should be freed with g_list_free(), but
its elements need not be freed.
| 
 | a GVolumeMonitor. | 
| Returns : | a GList of GVolume - free with g_list_free(). | 
GList* g_volume_monitor_get_mounts (GVolumeMonitor *volume_monitor);
Gets a list of the mounts on the system.
The returned list should be freed with g_list_free(), but
its elements need not be freed.
| 
 | a GVolumeMonitor. | 
| Returns : | a GList of GMount - free with g_list_free(). | 
GVolume* g_volume_monitor_adopt_orphan_mount (GMount *mount);
This function should be called by any GVolumeMonitor
implementation when a new GMount object is created that is not
associated with a GVolume object. It must be called just before
emitting the mount_added signal.
If the return value is not NULL, the caller must associate the
returned GVolume object with the GMount. This involves returning
it in it's g_mount_get_volume() implementation. The caller must
also listen for the "removed" signal on the returned object
and give up it's reference when handling that signal
Similary, if implementing g_volume_monitor_adopt_orphan_mount(),
the implementor must take a reference to mount and return it in
it's g_volume_get_mount() implemented. Also, the implementor must
listen for the "unmounted" signal on mount and give up it's
reference upon handling that signal.
There are two main use cases for this function.
One is when implementing a user space file system driver that reads blocks of a block device that is already represented by the native volume monitor (for example a CD Audio file system driver). Such a driver will generate it's own GMount object that needs to be assoicated with the GVolume object that represents the volume.
The other is for implementing a GVolumeMonitor whose sole purpose is to return GVolume objects representing entries in the users "favorite servers" list or similar.
GMount* g_volume_monitor_get_mount_for_uuid (GVolumeMonitor *volume_monitor, const char *uuid);
Finds a GMount object by it's UUID (see g_mount_get_uuid())
| 
 | a GVolumeMonitor. | 
| 
 | the UUID to look for | 
| Returns : | a GMount or NULLif no such mount is available. | 
GVolume* g_volume_monitor_get_volume_for_uuid (GVolumeMonitor *volume_monitor, const char *uuid);
Finds a GVolume object by it's UUID (see g_volume_get_uuid())
| 
 | a GVolumeMonitor. | 
| 
 | the UUID to look for | 
| Returns : | a GVolume or NULLif no such volume is available. | 
"drive-changed" signalvoid user_function (GVolumeMonitor *volume_monitor, GDrive *drive, gpointer user_data) : Run Last
Emitted when a drive changes.
| 
 | The volume monitor emitting the signal. | 
| 
 | the drive that changed | 
| 
 | user data set when the signal handler was connected. | 
"drive-connected" signalvoid user_function (GVolumeMonitor *volume_monitor, GDrive *drive, gpointer user_data) : Run Last
Emitted when a drive is connected to the system.
| 
 | The volume monitor emitting the signal. | 
| 
 | a GDrive that was connected. | 
| 
 | user data set when the signal handler was connected. | 
"drive-disconnected" signalvoid user_function (GVolumeMonitor *volume_monitor, GDrive *drive, gpointer user_data) : Run Last
Emitted when a drive is disconnected from the system.
| 
 | The volume monitor emitting the signal. | 
| 
 | a GDrive that was disconnected. | 
| 
 | user data set when the signal handler was connected. | 
"mount-added" signalvoid user_function (GVolumeMonitor *volume_monitor, GMount *mount, gpointer user_data) : Run Last
Emitted when a mount is added.
| 
 | The volume monitor emitting the signal. | 
| 
 | a GMount that was added. | 
| 
 | user data set when the signal handler was connected. | 
"mount-changed" signalvoid user_function (GVolumeMonitor *volume_monitor, GMount *mount, gpointer user_data) : Run Last
Emitted when a mount changes.
| 
 | The volume monitor emitting the signal. | 
| 
 | a GMount that changed. | 
| 
 | user data set when the signal handler was connected. | 
"mount-pre-unmount" signalvoid user_function (GVolumeMonitor *volume_monitor, GMount *mount, gpointer user_data) : Run Last
Emitted when a mount is about to be removed.
| 
 | The volume monitor emitting the signal. | 
| 
 | a GMount that is being unmounted. | 
| 
 | user data set when the signal handler was connected. | 
"mount-removed" signalvoid user_function (GVolumeMonitor *volume_monitor, GMount *mount, gpointer user_data) : Run Last
Emitted when a mount is removed.
| 
 | The volume monitor emitting the signal. | 
| 
 | a GMount that was removed. | 
| 
 | user data set when the signal handler was connected. | 
"volume-added" signalvoid user_function (GVolumeMonitor *volume_monitor, GVolume *volume, gpointer user_data) : Run Last
Emitted when a mountable volume is added to the system.
| 
 | The volume monitor emitting the signal. | 
| 
 | a GVolume that was added. | 
| 
 | user data set when the signal handler was connected. | 
"volume-changed" signalvoid user_function (GVolumeMonitor *volume_monitor, GVolume *volume, gpointer user_data) : Run Last
Emitted when mountable volume is changed.
| 
 | The volume monitor emitting the signal. | 
| 
 | a GVolume that changed. | 
| 
 | user data set when the signal handler was connected. | 
"volume-removed" signalvoid user_function (GVolumeMonitor *volume_monitor, GVolume *volume, gpointer user_data) : Run Last
Emitted when a mountable volume is removed from the system.
| 
 | The volume monitor emitting the signal. | 
| 
 | a GVolume that was removed. | 
| 
 | user data set when the signal handler was connected. |