Basics
Guides
API Reference
Basics
Guides
API Reference
[28:7] extends: object
A structure containing a weak reference to a #GObject. A GWeakRef can
either be empty (i.e. point to %NULL), or point to an object for as long as
at least one "strong" reference to that object exists. Before the object's
#GObjectClass.dispose method is called, every #GWeakRef associated with
becomes empty (i.e. points to %NULL). Like #GValue, #GWeakRef can be
statically allocated, stack- or heap-allocated, or embedded in larger
structures. Unlike g_object_weak_ref() and g_object_add_weak_pointer(), this
weak reference is thread-safe: converting a weak pointer to a reference is
atomic with respect to invalidation of weak pointers to destroyed objects. If
the object's #GObjectClass.dispose method results in additional references to
the object being held (‘re-referencing’), any #GWeakRefs taken before it was
disposed will continue to point to %NULL. Any #GWeakRefs taken during
disposal and after re-referencing, or after disposal has returned due to the
re-referencing, will continue to point to the object until its refcount goes
back to zero, at which point they too will be invalidated. It is invalid to
take a #GWeakRef on an object during #GObjectClass.dispose without first
having or creating a strong reference to the object.
WeakRef (Handle = null)
Creates a new
WeakRefby 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.
Aussom
Write once. Embed everywhere.
Copyright 2026 Austin Lehman. All rights reserved.