Copyright | Will Thompson and Iñaki García Etxebarria |
---|---|
License | LGPL-2.1 |
Maintainer | Iñaki García Etxebarria |
Safe Haskell | None |
Language | Haskell2010 |
- Exported types
- Methods
- canEject
- canPollForMedia
- canStart
- canStartDegraded
- canStop
- eject
- ejectFinish
- ejectWithOperation
- ejectWithOperationFinish
- enumerateIdentifiers
- getIcon
- getIdentifier
- getName
- getSortKey
- getStartStopType
- getSymbolicIcon
- getVolumes
- hasMedia
- hasVolumes
- isMediaCheckAutomatic
- isMediaRemovable
- isRemovable
- pollForMedia
- pollForMediaFinish
- start
- startFinish
- stop
- stopFinish
- Signals
GDrive
represents a piece of hardware connected to the machine.
It’s generally only created for removable hardware or hardware with
removable media.
GDrive
is a container class for Volume
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, determining 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 potentially expensive and may
spin up the drive creating noise.
GDrive
supports starting and stopping drives with authentication
support for the former. This can be used to support a diverse set
of use cases including connecting/disconnecting iSCSI devices,
powering down external disk enclosures and starting/stopping
multi-disk devices such as RAID devices. Note that the actual
semantics and side-effects of starting/stopping a GDrive
may vary
according to implementation. To choose the correct verbs in e.g. a
file manager, use driveGetStartStopType
.
For porting from GnomeVFS note that there is no
equivalent of GDrive
in that API.
Synopsis
- newtype Drive = Drive (ManagedPtr Drive)
- class (GObject o, IsDescendantOf Drive o) => IsDrive o
- toDrive :: (MonadIO m, IsDrive o) => o -> m Drive
- driveCanEject :: (HasCallStack, MonadIO m, IsDrive a) => a -> m Bool
- driveCanPollForMedia :: (HasCallStack, MonadIO m, IsDrive a) => a -> m Bool
- driveCanStart :: (HasCallStack, MonadIO m, IsDrive a) => a -> m Bool
- driveCanStartDegraded :: (HasCallStack, MonadIO m, IsDrive a) => a -> m Bool
- driveCanStop :: (HasCallStack, MonadIO m, IsDrive a) => a -> m Bool
- driveEject :: (HasCallStack, MonadIO m, IsDrive a, IsCancellable b) => a -> [MountUnmountFlags] -> Maybe b -> Maybe AsyncReadyCallback -> m ()
- driveEjectFinish :: (HasCallStack, MonadIO m, IsDrive a, IsAsyncResult b) => a -> b -> m ()
- driveEjectWithOperation :: (HasCallStack, MonadIO m, IsDrive a, IsMountOperation b, IsCancellable c) => a -> [MountUnmountFlags] -> Maybe b -> Maybe c -> Maybe AsyncReadyCallback -> m ()
- driveEjectWithOperationFinish :: (HasCallStack, MonadIO m, IsDrive a, IsAsyncResult b) => a -> b -> m ()
- driveEnumerateIdentifiers :: (HasCallStack, MonadIO m, IsDrive a) => a -> m [Text]
- driveGetIcon :: (HasCallStack, MonadIO m, IsDrive a) => a -> m Icon
- driveGetIdentifier :: (HasCallStack, MonadIO m, IsDrive a) => a -> Text -> m (Maybe Text)
- driveGetName :: (HasCallStack, MonadIO m, IsDrive a) => a -> m Text
- driveGetSortKey :: (HasCallStack, MonadIO m, IsDrive a) => a -> m (Maybe Text)
- driveGetStartStopType :: (HasCallStack, MonadIO m, IsDrive a) => a -> m DriveStartStopType
- driveGetSymbolicIcon :: (HasCallStack, MonadIO m, IsDrive a) => a -> m Icon
- driveGetVolumes :: (HasCallStack, MonadIO m, IsDrive a) => a -> m [Volume]
- driveHasMedia :: (HasCallStack, MonadIO m, IsDrive a) => a -> m Bool
- driveHasVolumes :: (HasCallStack, MonadIO m, IsDrive a) => a -> m Bool
- driveIsMediaCheckAutomatic :: (HasCallStack, MonadIO m, IsDrive a) => a -> m Bool
- driveIsMediaRemovable :: (HasCallStack, MonadIO m, IsDrive a) => a -> m Bool
- driveIsRemovable :: (HasCallStack, MonadIO m, IsDrive a) => a -> m Bool
- drivePollForMedia :: (HasCallStack, MonadIO m, IsDrive a, IsCancellable b) => a -> Maybe b -> Maybe AsyncReadyCallback -> m ()
- drivePollForMediaFinish :: (HasCallStack, MonadIO m, IsDrive a, IsAsyncResult b) => a -> b -> m ()
- driveStart :: (HasCallStack, MonadIO m, IsDrive a, IsMountOperation b, IsCancellable c) => a -> [DriveStartFlags] -> Maybe b -> Maybe c -> Maybe AsyncReadyCallback -> m ()
- driveStartFinish :: (HasCallStack, MonadIO m, IsDrive a, IsAsyncResult b) => a -> b -> m ()
- driveStop :: (HasCallStack, MonadIO m, IsDrive a, IsMountOperation b, IsCancellable c) => a -> [MountUnmountFlags] -> Maybe b -> Maybe c -> Maybe AsyncReadyCallback -> m ()
- driveStopFinish :: (HasCallStack, MonadIO m, IsDrive a, IsAsyncResult b) => a -> b -> m ()
- type DriveChangedCallback = IO ()
- afterDriveChanged :: (IsDrive a, MonadIO m) => a -> ((?self :: a) => DriveChangedCallback) -> m SignalHandlerId
- onDriveChanged :: (IsDrive a, MonadIO m) => a -> ((?self :: a) => DriveChangedCallback) -> m SignalHandlerId
- type DriveDisconnectedCallback = IO ()
- afterDriveDisconnected :: (IsDrive a, MonadIO m) => a -> ((?self :: a) => DriveDisconnectedCallback) -> m SignalHandlerId
- onDriveDisconnected :: (IsDrive a, MonadIO m) => a -> ((?self :: a) => DriveDisconnectedCallback) -> m SignalHandlerId
- type DriveEjectButtonCallback = IO ()
- afterDriveEjectButton :: (IsDrive a, MonadIO m) => a -> ((?self :: a) => DriveEjectButtonCallback) -> m SignalHandlerId
- onDriveEjectButton :: (IsDrive a, MonadIO m) => a -> ((?self :: a) => DriveEjectButtonCallback) -> m SignalHandlerId
- type DriveStopButtonCallback = IO ()
- afterDriveStopButton :: (IsDrive a, MonadIO m) => a -> ((?self :: a) => DriveStopButtonCallback) -> m SignalHandlerId
- onDriveStopButton :: (IsDrive a, MonadIO m) => a -> ((?self :: a) => DriveStopButtonCallback) -> m SignalHandlerId
Exported types
Memory-managed wrapper type.
Instances
Eq Drive Source # | |
GObject Drive Source # | |
Defined in GI.Gio.Interfaces.Drive | |
ManagedPtrNewtype Drive Source # | |
Defined in GI.Gio.Interfaces.Drive toManagedPtr :: Drive -> ManagedPtr Drive # | |
TypedObject Drive Source # | |
Defined in GI.Gio.Interfaces.Drive | |
HasParentTypes Drive Source # | |
Defined in GI.Gio.Interfaces.Drive | |
IsGValue (Maybe Drive) Source # | Convert |
Defined in GI.Gio.Interfaces.Drive | |
type ParentTypes Drive Source # | |
Defined in GI.Gio.Interfaces.Drive type ParentTypes Drive = '[Object] |
Methods
Click to display all available methods, including inherited ones
Methods
bindProperty, bindPropertyFull, canEject, canPollForMedia, canStart, canStartDegraded, canStop, eject, ejectFinish, ejectWithOperation, ejectWithOperationFinish, enumerateIdentifiers, forceFloating, freezeNotify, getv, hasMedia, hasVolumes, isFloating, isMediaCheckAutomatic, isMediaRemovable, isRemovable, notify, notifyByPspec, pollForMedia, pollForMediaFinish, ref, refSink, runDispose, start, startFinish, stealData, stealQdata, stop, stopFinish, thawNotify, unref, watchClosure.
Getters
getData, getIcon, getIdentifier, getName, getProperty, getQdata, getSortKey, getStartStopType, getSymbolicIcon, getVolumes.
Setters
canEject
:: (HasCallStack, MonadIO m, IsDrive a) | |
=> a |
|
-> m Bool |
Checks if a drive can be ejected.
canPollForMedia
:: (HasCallStack, MonadIO m, IsDrive a) | |
=> a |
|
-> m Bool | Returns: |
Checks if a drive can be polled for media changes.
canStart
:: (HasCallStack, MonadIO m, IsDrive a) | |
=> a |
|
-> m Bool |
Checks if a drive can be started.
Since: 2.22
canStartDegraded
driveCanStartDegraded Source #
:: (HasCallStack, MonadIO m, IsDrive a) | |
=> a |
|
-> m Bool | Returns: |
Checks if a drive can be started degraded.
Since: 2.22
canStop
:: (HasCallStack, MonadIO m, IsDrive a) | |
=> a |
|
-> m Bool |
Checks if a drive can be stopped.
Since: 2.22
eject
:: (HasCallStack, MonadIO m, IsDrive a, IsCancellable b) | |
=> a |
|
-> [MountUnmountFlags] |
|
-> Maybe b |
|
-> Maybe AsyncReadyCallback |
|
-> m () |
Deprecated: (Since version 2.22)Use driveEjectWithOperation
instead.
Asynchronously ejects a drive.
When the operation is finished, callback
will be called.
You can then call driveEjectFinish
to obtain the
result of the operation.
ejectFinish
:: (HasCallStack, MonadIO m, IsDrive a, IsAsyncResult b) | |
=> a |
|
-> b |
|
-> m () | (Can throw |
Deprecated: (Since version 2.22)Use driveEjectWithOperationFinish
instead.
Finishes ejecting a drive.
ejectWithOperation
driveEjectWithOperation Source #
:: (HasCallStack, MonadIO m, IsDrive a, IsMountOperation b, IsCancellable c) | |
=> a |
|
-> [MountUnmountFlags] |
|
-> Maybe b |
|
-> Maybe c |
|
-> Maybe AsyncReadyCallback |
|
-> m () |
Ejects a drive. This is an asynchronous operation, and is
finished by calling driveEjectWithOperationFinish
with the drive
and AsyncResult
data returned in the callback
.
Since: 2.22
ejectWithOperationFinish
driveEjectWithOperationFinish Source #
:: (HasCallStack, MonadIO m, IsDrive a, IsAsyncResult b) | |
=> a |
|
-> b |
|
-> m () | (Can throw |
Finishes ejecting a drive. If any errors occurred during the operation,
error
will be set to contain the errors and False
will be returned.
Since: 2.22
enumerateIdentifiers
driveEnumerateIdentifiers Source #
:: (HasCallStack, MonadIO m, IsDrive a) | |
=> a |
|
-> m [Text] | Returns: a |
Gets the kinds of identifiers that drive
has.
Use driveGetIdentifier
to obtain the identifiers
themselves.
getIcon
:: (HasCallStack, MonadIO m, IsDrive a) | |
=> a |
|
-> m Icon | Returns: |
Gets the icon for drive
.
getIdentifier
:: (HasCallStack, MonadIO m, IsDrive a) | |
=> a |
|
-> Text |
|
-> m (Maybe Text) | Returns: a newly allocated string containing the
requested identifier, or |
Gets the identifier of the given kind for drive
. The only
identifier currently available is
DRIVE_IDENTIFIER_KIND_UNIX_DEVICE
.
getName
:: (HasCallStack, MonadIO m, IsDrive a) | |
=> a |
|
-> m Text | Returns: a string containing |
Gets the name of drive
.
getSortKey
:: (HasCallStack, MonadIO m, IsDrive a) | |
=> a |
|
-> m (Maybe Text) | Returns: Sorting key for |
Gets the sort key for drive
, if any.
Since: 2.32
getStartStopType
driveGetStartStopType Source #
:: (HasCallStack, MonadIO m, IsDrive a) | |
=> a |
|
-> m DriveStartStopType | Returns: A value from the |
Gets a hint about how a drive can be started/stopped.
Since: 2.22
getSymbolicIcon
:: (HasCallStack, MonadIO m, IsDrive a) | |
=> a |
|
-> m Icon | Returns: symbolic |
Gets the icon for drive
.
Since: 2.34
getVolumes
:: (HasCallStack, MonadIO m, IsDrive a) | |
=> a |
|
-> m [Volume] | Returns: |
Get a list of mountable volumes for drive
.
The returned list should be freed with g_list_free()
, after
its elements have been unreffed with objectUnref
.
hasMedia
:: (HasCallStack, MonadIO m, IsDrive a) | |
=> a |
|
-> m Bool |
Checks if the drive
has media. Note that the OS may not be polling
the drive for media changes; see driveIsMediaCheckAutomatic
for more details.
hasVolumes
:: (HasCallStack, MonadIO m, IsDrive a) | |
=> a |
|
-> m Bool | Returns: |
Check if drive
has any mountable volumes.
isMediaCheckAutomatic
driveIsMediaCheckAutomatic Source #
:: (HasCallStack, MonadIO m, IsDrive a) | |
=> a |
|
-> m Bool | Returns: |
Checks if drive
is capable of automatically detecting media changes.
isMediaRemovable
driveIsMediaRemovable Source #
:: (HasCallStack, MonadIO m, IsDrive a) | |
=> a |
|
-> m Bool | Returns: |
Checks if the drive
supports removable media.
isRemovable
:: (HasCallStack, MonadIO m, IsDrive a) | |
=> a |
|
-> m Bool | Returns: |
Checks if the Drive
and/or its media is considered removable by the user.
See driveIsMediaRemovable
.
Since: 2.50
pollForMedia
:: (HasCallStack, MonadIO m, IsDrive a, IsCancellable b) | |
=> a |
|
-> Maybe b |
|
-> Maybe AsyncReadyCallback |
|
-> m () |
Asynchronously polls drive
to see if media has been inserted or removed.
When the operation is finished, callback
will be called.
You can then call drivePollForMediaFinish
to obtain the
result of the operation.
pollForMediaFinish
drivePollForMediaFinish Source #
:: (HasCallStack, MonadIO m, IsDrive a, IsAsyncResult b) | |
=> a |
|
-> b |
|
-> m () | (Can throw |
Finishes an operation started with drivePollForMedia
on a drive.
start
:: (HasCallStack, MonadIO m, IsDrive a, IsMountOperation b, IsCancellable c) | |
=> a |
|
-> [DriveStartFlags] |
|
-> Maybe b |
|
-> Maybe c |
|
-> Maybe AsyncReadyCallback |
|
-> m () |
Asynchronously starts a drive.
When the operation is finished, callback
will be called.
You can then call driveStartFinish
to obtain the
result of the operation.
Since: 2.22
startFinish
:: (HasCallStack, MonadIO m, IsDrive a, IsAsyncResult b) | |
=> a |
|
-> b |
|
-> m () | (Can throw |
Finishes starting a drive.
Since: 2.22
stop
:: (HasCallStack, MonadIO m, IsDrive a, IsMountOperation b, IsCancellable c) | |
=> a |
|
-> [MountUnmountFlags] |
|
-> Maybe b |
|
-> Maybe c |
|
-> Maybe AsyncReadyCallback |
|
-> m () |
Asynchronously stops a drive.
When the operation is finished, callback
will be called.
You can then call driveStopFinish
to obtain the
result of the operation.
Since: 2.22
stopFinish
:: (HasCallStack, MonadIO m, IsDrive a, IsAsyncResult b) | |
=> a |
|
-> b |
|
-> m () | (Can throw |
Finishes stopping a drive.
Since: 2.22
Signals
changed
type DriveChangedCallback = IO () Source #
Emitted when the drive's state has changed.
afterDriveChanged :: (IsDrive a, MonadIO m) => a -> ((?self :: a) => DriveChangedCallback) -> m SignalHandlerId Source #
Connect a signal handler for the changed signal, to be run after the default handler. When overloading is enabled, this is equivalent to
after
drive #changed callback
By default the object invoking the signal is not passed to the callback.
If you need to access it, you can use the implit ?self
parameter.
Note that this requires activating the ImplicitParams
GHC extension.
onDriveChanged :: (IsDrive a, MonadIO m) => a -> ((?self :: a) => DriveChangedCallback) -> m SignalHandlerId Source #
Connect a signal handler for the changed signal, to be run before the default handler. When overloading is enabled, this is equivalent to
on
drive #changed callback
disconnected
type DriveDisconnectedCallback = IO () Source #
This signal is emitted when the Drive
have been
disconnected. If the recipient is holding references to the
object they should release them so the object can be
finalized.
afterDriveDisconnected :: (IsDrive a, MonadIO m) => a -> ((?self :: a) => DriveDisconnectedCallback) -> m SignalHandlerId Source #
Connect a signal handler for the disconnected signal, to be run after the default handler. When overloading is enabled, this is equivalent to
after
drive #disconnected callback
By default the object invoking the signal is not passed to the callback.
If you need to access it, you can use the implit ?self
parameter.
Note that this requires activating the ImplicitParams
GHC extension.
onDriveDisconnected :: (IsDrive a, MonadIO m) => a -> ((?self :: a) => DriveDisconnectedCallback) -> m SignalHandlerId Source #
Connect a signal handler for the disconnected signal, to be run before the default handler. When overloading is enabled, this is equivalent to
on
drive #disconnected callback
ejectButton
type DriveEjectButtonCallback = IO () Source #
Emitted when the physical eject button (if any) of a drive has been pressed.
afterDriveEjectButton :: (IsDrive a, MonadIO m) => a -> ((?self :: a) => DriveEjectButtonCallback) -> m SignalHandlerId Source #
Connect a signal handler for the ejectButton signal, to be run after the default handler. When overloading is enabled, this is equivalent to
after
drive #ejectButton callback
By default the object invoking the signal is not passed to the callback.
If you need to access it, you can use the implit ?self
parameter.
Note that this requires activating the ImplicitParams
GHC extension.
onDriveEjectButton :: (IsDrive a, MonadIO m) => a -> ((?self :: a) => DriveEjectButtonCallback) -> m SignalHandlerId Source #
Connect a signal handler for the ejectButton signal, to be run before the default handler. When overloading is enabled, this is equivalent to
on
drive #ejectButton callback
stopButton
type DriveStopButtonCallback = IO () Source #
Emitted when the physical stop button (if any) of a drive has been pressed.
Since: 2.22
afterDriveStopButton :: (IsDrive a, MonadIO m) => a -> ((?self :: a) => DriveStopButtonCallback) -> m SignalHandlerId Source #
Connect a signal handler for the stopButton signal, to be run after the default handler. When overloading is enabled, this is equivalent to
after
drive #stopButton callback
By default the object invoking the signal is not passed to the callback.
If you need to access it, you can use the implit ?self
parameter.
Note that this requires activating the ImplicitParams
GHC extension.
onDriveStopButton :: (IsDrive a, MonadIO m) => a -> ((?self :: a) => DriveStopButtonCallback) -> m SignalHandlerId Source #
Connect a signal handler for the stopButton signal, to be run before the default handler. When overloading is enabled, this is equivalent to
on
drive #stopButton callback