Module: Gio::Seekable
- Included in:
- RubyInputStream, RubyOutputStream
- Defined in:
- (unknown)
Overview
GSeekable is implemented by streams (implementations of
[classGio.InputStream] or [classGio.OutputStream]) that support seeking.
Seekable streams largely fall into two categories: resizable and fixed-size.
GSeekable on fixed-sized streams is approximately the same as POSIX
lseek() on a block device (for example: attempting to seek
past the end of the device is an error). Fixed streams typically cannot be
truncated.
GSeekable on resizable streams is approximately the same as POSIX
lseek() on a normal file. Seeking past the end and writing
data will usually cause the stream to resize by introducing zero bytes.
Instance Method Summary collapse
-
#can_seek(seekable) ⇒ Boolean
True if seekable can be seeked.
-
#can_truncate(seekable) ⇒ Boolean
True if the stream can be truncated, false otherwise.
-
#seek(seekable, offset, type, cancellable) ⇒ Boolean
True if successful.
-
#tell(seekable) ⇒ Integer
buffer, zero if the target is not seekable.
-
#truncate(offset, cancellable) ⇒ Boolean
Sets the length of the stream to offset.
-
#truncate_fn(seekable, offset, cancellable) ⇒ Boolean
True if successful.
Instance Method Details
#can_seek(seekable) ⇒ Boolean
Returns true if seekable can be seeked. false otherwise.
#can_truncate(seekable) ⇒ Boolean
Returns true if the stream can be truncated, false otherwise.
#seek(seekable, offset, type, cancellable) ⇒ Boolean
Returns true if successful. If an error has occurred, this function will return false and set error appropriately if present.
#tell(seekable) ⇒ Integer
buffer, zero if the target is not seekable.
#truncate(offset, cancellable) ⇒ Boolean
Sets the length of the stream to offset. If the stream was previously larger than offset, the extra data is discarded. If the stream was previously shorter than offset, it is extended with NUL ('\0') bytes.
If cancellable is not nil, then the operation can be cancelled by triggering the cancellable object from another thread. If the operation was cancelled, the error %G_IO_ERROR_CANCELLED will be returned. If an operation was partially finished when the operation was cancelled the partial result will be returned, without an error.
#truncate_fn(seekable, offset, cancellable) ⇒ Boolean
Returns true if successful. If an error has occurred, this function will return false and set error appropriately if present.