Title: Value Collection SPDX-License-Identifier: LGPL-2.1-or-later SPDX-FileCopyrightText: 2005 Matthias Clasen
GLib provides a set of macros for the varargs parsing support needed in variadic GObject functions such as [ctor@GObject.Object.new] or [method@GObject.Object.set]
They currently support the collection of integral types, floating point types and pointers.
G_VALUE_COLLECT_INIT(value, _value_type, var_args, flags, __error)
: Collects a variable argument value from a va_list.
We have to implement the varargs collection as a macro, because on some systems `va_list` variables cannot be passed by reference. Since: 2.24
G_VALUE_COLLECT_INIT2(value, g_vci_vtab, _value_type, var_args, flags, __error)
: A variant of G_VALUE_COLLECT_INIT that provides the [struct@GObject.TypeValueTable] to the caller.
Since: 2.74
G_VALUE_COLLECT(value, var_args, flags, __error)
: Collects a variable argument value from a va_list.
We have to implement the varargs collection as a macro, because on some systems `va_list` variables cannot be passed by reference. Note: If you are creating the `value argument` just before calling this macro, you should use the `G_VALUE_COLLECT_INIT` variant and pass the uninitialized `GValue`. That variant is faster than `G_VALUE_COLLECT`.
G_VALUE_COLLECT_SKIP(_value_type, var_args)
: Skip an argument of type _value_type from var_args.
G_VALUE_LCOPY(value, var_args, flags, __error)
: Stores a value’s value into one or more argument locations from a va_list.
This is the inverse of G_VALUE_COLLECT().
G_VALUE_COLLECT_FORMAT_MAX_LENGTH
: The maximal number of [type@GObject.TypeCValue]s which can be collected for a single GValue.