Basics
Guides
API Reference
Basics
Guides
API Reference
[22:7] extends: object
GSeekable is implemented by streams (implementations of
[class@Gio.InputStream] or [class@Gio.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.
Seekable (Handle = null)
Creates a new
Seekableby wrapping a native handle or another wrapper.
Handle is the native handle or another wrapper whose handle to adopt.toNativeHandle (Source)
Normalizes a constructor argument into a raw pointer carrier. Accepts a raw NativeHandle, a raw NativeBuffer returned from
fn.call(...), another generated wrapper exposinghandle(), or null. Returns null when the argument carries no pointer.
Source is the raw handle, raw buffer, wrapper, or null.A raw pointer carrier or null when no pointer is present.getLib ()
Returns the opened native library for this generated wrapper.
The opened native library.handle ()
Returns the wrapped NativeHandle.
The wrapped NativeHandle.isNull ()
Returns true when the wrapped handle is null.
A bool.describe ()
Returns a small string for debugging generated wrappers.
A string.can_seek ()
Tests if the stream supports the #GSeekableIface.
can_truncate ()
Tests if the length of the stream can be adjusted with g_seekable_truncate().

Aussom
Write once. Embed everywhere.
Copyright 2026 Austin Lehman. All rights reserved.