docs: GType documentation cleanup

Still some markup left.
This commit is contained in:
Matthias Clasen 2014-05-31 20:55:00 -04:00
parent 24ab95582b
commit adfaf0e456
2 changed files with 160 additions and 168 deletions

View File

@ -4463,8 +4463,7 @@ gobject_init_ctor (void)
* my_object->priv = G_TYPE_INSTANCE_GET_PRIVATE (my_object, * my_object->priv = G_TYPE_INSTANCE_GET_PRIVATE (my_object,
* MY_TYPE_OBJECT, * MY_TYPE_OBJECT,
* MyObjectPrivate); * MyObjectPrivate);
* /<!-- -->* my_object->priv->some_field will be * // my_object->priv->some_field will be automatically initialised to 0
* * automatically initialised to 0 *<!-- -->/
* } * }
* *
* static int * static int

View File

@ -256,27 +256,27 @@ G_BEGIN_DECLS
*/ */
/** /**
* G_TYPE_IS_FUNDAMENTAL: * G_TYPE_IS_FUNDAMENTAL:
* @type: A #GType value. * @type: A #GType value
* *
* Checks if @type is a fundamental type. * Checks if @type is a fundamental type.
* *
* Returns: %TRUE on success. * Returns: %TRUE on success
*/ */
#define G_TYPE_IS_FUNDAMENTAL(type) ((type) <= G_TYPE_FUNDAMENTAL_MAX) #define G_TYPE_IS_FUNDAMENTAL(type) ((type) <= G_TYPE_FUNDAMENTAL_MAX)
/** /**
* G_TYPE_IS_DERIVED: * G_TYPE_IS_DERIVED:
* @type: A #GType value. * @type: A #GType value
* *
* Checks if @type is derived (or in object-oriented terminology: * Checks if @type is derived (or in object-oriented terminology:
* inherited) from another type (this holds true for all non-fundamental * inherited) from another type (this holds true for all non-fundamental
* types). * types).
* *
* Returns: %TRUE on success. * Returns: %TRUE on success
*/ */
#define G_TYPE_IS_DERIVED(type) ((type) > G_TYPE_FUNDAMENTAL_MAX) #define G_TYPE_IS_DERIVED(type) ((type) > G_TYPE_FUNDAMENTAL_MAX)
/** /**
* G_TYPE_IS_INTERFACE: * G_TYPE_IS_INTERFACE:
* @type: A #GType value. * @type: A #GType value
* *
* Checks if @type is an interface type. * Checks if @type is an interface type.
* An interface type provides a pure API, the implementation * An interface type provides a pure API, the implementation
@ -286,86 +286,86 @@ G_BEGIN_DECLS
* with the difference that GType interfaces are not derivable (but see * with the difference that GType interfaces are not derivable (but see
* g_type_interface_add_prerequisite() for an alternative). * g_type_interface_add_prerequisite() for an alternative).
* *
* Returns: %TRUE on success. * Returns: %TRUE on success
*/ */
#define G_TYPE_IS_INTERFACE(type) (G_TYPE_FUNDAMENTAL (type) == G_TYPE_INTERFACE) #define G_TYPE_IS_INTERFACE(type) (G_TYPE_FUNDAMENTAL (type) == G_TYPE_INTERFACE)
/** /**
* G_TYPE_IS_CLASSED: * G_TYPE_IS_CLASSED:
* @type: A #GType value. * @type: A #GType value
* *
* Checks if @type is a classed type. * Checks if @type is a classed type.
* *
* Returns: %TRUE on success. * Returns: %TRUE on success
*/ */
#define G_TYPE_IS_CLASSED(type) (g_type_test_flags ((type), G_TYPE_FLAG_CLASSED)) #define G_TYPE_IS_CLASSED(type) (g_type_test_flags ((type), G_TYPE_FLAG_CLASSED))
/** /**
* G_TYPE_IS_INSTANTIATABLE: * G_TYPE_IS_INSTANTIATABLE:
* @type: A #GType value. * @type: A #GType value
* *
* Checks if @type can be instantiated. Instantiation is the * Checks if @type can be instantiated. Instantiation is the
* process of creating an instance (object) of this type. * process of creating an instance (object) of this type.
* *
* Returns: %TRUE on success. * Returns: %TRUE on success
*/ */
#define G_TYPE_IS_INSTANTIATABLE(type) (g_type_test_flags ((type), G_TYPE_FLAG_INSTANTIATABLE)) #define G_TYPE_IS_INSTANTIATABLE(type) (g_type_test_flags ((type), G_TYPE_FLAG_INSTANTIATABLE))
/** /**
* G_TYPE_IS_DERIVABLE: * G_TYPE_IS_DERIVABLE:
* @type: A #GType value. * @type: A #GType value
* *
* Checks if @type is a derivable type. A derivable type can * Checks if @type is a derivable type. A derivable type can
* be used as the base class of a flat (single-level) class hierarchy. * be used as the base class of a flat (single-level) class hierarchy.
* *
* Returns: %TRUE on success. * Returns: %TRUE on success
*/ */
#define G_TYPE_IS_DERIVABLE(type) (g_type_test_flags ((type), G_TYPE_FLAG_DERIVABLE)) #define G_TYPE_IS_DERIVABLE(type) (g_type_test_flags ((type), G_TYPE_FLAG_DERIVABLE))
/** /**
* G_TYPE_IS_DEEP_DERIVABLE: * G_TYPE_IS_DEEP_DERIVABLE:
* @type: A #GType value. * @type: A #GType value
* *
* Checks if @type is a deep derivable type. A deep derivable type * Checks if @type is a deep derivable type. A deep derivable type
* can be used as the base class of a deep (multi-level) class hierarchy. * can be used as the base class of a deep (multi-level) class hierarchy.
* *
* Returns: %TRUE on success. * Returns: %TRUE on success
*/ */
#define G_TYPE_IS_DEEP_DERIVABLE(type) (g_type_test_flags ((type), G_TYPE_FLAG_DEEP_DERIVABLE)) #define G_TYPE_IS_DEEP_DERIVABLE(type) (g_type_test_flags ((type), G_TYPE_FLAG_DEEP_DERIVABLE))
/** /**
* G_TYPE_IS_ABSTRACT: * G_TYPE_IS_ABSTRACT:
* @type: A #GType value. * @type: A #GType value
* *
* Checks if @type is an abstract type. An abstract type cannot be * Checks if @type is an abstract type. An abstract type cannot be
* instantiated and is normally used as an abstract base class for * instantiated and is normally used as an abstract base class for
* derived classes. * derived classes.
* *
* Returns: %TRUE on success. * Returns: %TRUE on success
*/ */
#define G_TYPE_IS_ABSTRACT(type) (g_type_test_flags ((type), G_TYPE_FLAG_ABSTRACT)) #define G_TYPE_IS_ABSTRACT(type) (g_type_test_flags ((type), G_TYPE_FLAG_ABSTRACT))
/** /**
* G_TYPE_IS_VALUE_ABSTRACT: * G_TYPE_IS_VALUE_ABSTRACT:
* @type: A #GType value. * @type: A #GType value
* *
* Checks if @type is an abstract value type. An abstract value type introduces * Checks if @type is an abstract value type. An abstract value type introduces
* a value table, but can't be used for g_value_init() and is normally used as * a value table, but can't be used for g_value_init() and is normally used as
* an abstract base type for derived value types. * an abstract base type for derived value types.
* *
* Returns: %TRUE on success. * Returns: %TRUE on success
*/ */
#define G_TYPE_IS_VALUE_ABSTRACT(type) (g_type_test_flags ((type), G_TYPE_FLAG_VALUE_ABSTRACT)) #define G_TYPE_IS_VALUE_ABSTRACT(type) (g_type_test_flags ((type), G_TYPE_FLAG_VALUE_ABSTRACT))
/** /**
* G_TYPE_IS_VALUE_TYPE: * G_TYPE_IS_VALUE_TYPE:
* @type: A #GType value. * @type: A #GType value
* *
* Checks if @type is a value type and can be used with g_value_init(). * Checks if @type is a value type and can be used with g_value_init().
* *
* Returns: %TRUE on success. * Returns: %TRUE on success
*/ */
#define G_TYPE_IS_VALUE_TYPE(type) (g_type_check_is_value_type (type)) #define G_TYPE_IS_VALUE_TYPE(type) (g_type_check_is_value_type (type))
/** /**
* G_TYPE_HAS_VALUE_TABLE: * G_TYPE_HAS_VALUE_TABLE:
* @type: A #GType value. * @type: A #GType value
* *
* Checks if @type has a #GTypeValueTable. * Checks if @type has a #GTypeValueTable.
* *
* Returns: %TRUE on success. * Returns: %TRUE on success
*/ */
#define G_TYPE_HAS_VALUE_TABLE(type) (g_type_value_table_peek (type) != NULL) #define G_TYPE_HAS_VALUE_TABLE(type) (g_type_value_table_peek (type) != NULL)
@ -431,13 +431,13 @@ struct _GTypeInterface
}; };
/** /**
* GTypeQuery: * GTypeQuery:
* @type: the #GType value of the type. * @type: the #GType value of the type
* @type_name: the name of the type. * @type_name: the name of the type
* @class_size: the size of the class structure. * @class_size: the size of the class structure
* @instance_size: the size of the instance structure. * @instance_size: the size of the instance structure
* *
* A structure holding information for a specific type. It is * A structure holding information for a specific type.
* filled in by the g_type_query() function. * It is filled in by the g_type_query() function.
*/ */
struct _GTypeQuery struct _GTypeQuery
{ {
@ -454,21 +454,21 @@ struct _GTypeQuery
/*< protected >*/ /*< protected >*/
/** /**
* G_TYPE_CHECK_INSTANCE: * G_TYPE_CHECK_INSTANCE:
* @instance: Location of a #GTypeInstance structure. * @instance: Location of a #GTypeInstance structure
* *
* Checks if @instance is a valid #GTypeInstance structure, * Checks if @instance is a valid #GTypeInstance structure,
* otherwise issues a warning and returns %FALSE. * otherwise issues a warning and returns %FALSE.
* *
* This macro should only be used in type implementations. * This macro should only be used in type implementations.
* *
* Returns: %TRUE on success. * Returns: %TRUE on success
*/ */
#define G_TYPE_CHECK_INSTANCE(instance) (_G_TYPE_CHI ((GTypeInstance*) (instance))) #define G_TYPE_CHECK_INSTANCE(instance) (_G_TYPE_CHI ((GTypeInstance*) (instance)))
/** /**
* G_TYPE_CHECK_INSTANCE_CAST: * G_TYPE_CHECK_INSTANCE_CAST:
* @instance: Location of a #GTypeInstance structure. * @instance: Location of a #GTypeInstance structure
* @g_type: The type to be returned. * @g_type: The type to be returned
* @c_type: The corresponding C type of @g_type. * @c_type: The corresponding C type of @g_type
* *
* Checks that @instance is an instance of the type identified by @g_type * Checks that @instance is an instance of the type identified by @g_type
* and issues a warning if this is not the case. Returns @instance casted * and issues a warning if this is not the case. Returns @instance casted
@ -486,7 +486,7 @@ struct _GTypeQuery
* *
* This macro should only be used in type implementations. * This macro should only be used in type implementations.
* *
* Returns: %TRUE on success. * Returns: %TRUE on success
*/ */
#define G_TYPE_CHECK_INSTANCE_TYPE(instance, g_type) (_G_TYPE_CIT ((instance), (g_type))) #define G_TYPE_CHECK_INSTANCE_TYPE(instance, g_type) (_G_TYPE_CIT ((instance), (g_type)))
/** /**
@ -498,20 +498,20 @@ struct _GTypeQuery
* *
* This macro should only be used in type implementations. * This macro should only be used in type implementations.
* *
* Returns: %TRUE on success. * Returns: %TRUE on success
*/ */
#define G_TYPE_CHECK_INSTANCE_FUNDAMENTAL_TYPE(instance, g_type) (_G_TYPE_CIFT ((instance), (g_type))) #define G_TYPE_CHECK_INSTANCE_FUNDAMENTAL_TYPE(instance, g_type) (_G_TYPE_CIFT ((instance), (g_type)))
/** /**
* G_TYPE_INSTANCE_GET_CLASS: * G_TYPE_INSTANCE_GET_CLASS:
* @instance: Location of the #GTypeInstance structure. * @instance: Location of the #GTypeInstance structure
* @g_type: The #GType of the class to be returned. * @g_type: The #GType of the class to be returned
* @c_type: The C type of the class structure. * @c_type: The C type of the class structure
* *
* Get the class structure of a given @instance, casted * Get the class structure of a given @instance, casted
* to a specified ancestor type @g_type of the instance. * to a specified ancestor type @g_type of the instance.
* *
* Note that while calling a GInstanceInitFunc(), the class pointer gets * Note that while calling a GInstanceInitFunc(), the class pointer
* modified, so it might not always return the expected pointer. * gets modified, so it might not always return the expected pointer.
* *
* This macro should only be used in type implementations. * This macro should only be used in type implementations.
* *
@ -520,9 +520,9 @@ struct _GTypeQuery
#define G_TYPE_INSTANCE_GET_CLASS(instance, g_type, c_type) (_G_TYPE_IGC ((instance), (g_type), c_type)) #define G_TYPE_INSTANCE_GET_CLASS(instance, g_type, c_type) (_G_TYPE_IGC ((instance), (g_type), c_type))
/** /**
* G_TYPE_INSTANCE_GET_INTERFACE: * G_TYPE_INSTANCE_GET_INTERFACE:
* @instance: Location of the #GTypeInstance structure. * @instance: Location of the #GTypeInstance structure
* @g_type: The #GType of the interface to be returned. * @g_type: The #GType of the interface to be returned
* @c_type: The C type of the interface structure. * @c_type: The C type of the interface structure
* *
* Get the interface structure for interface @g_type of a given @instance. * Get the interface structure for interface @g_type of a given @instance.
* *
@ -533,9 +533,9 @@ struct _GTypeQuery
#define G_TYPE_INSTANCE_GET_INTERFACE(instance, g_type, c_type) (_G_TYPE_IGI ((instance), (g_type), c_type)) #define G_TYPE_INSTANCE_GET_INTERFACE(instance, g_type, c_type) (_G_TYPE_IGI ((instance), (g_type), c_type))
/** /**
* G_TYPE_CHECK_CLASS_CAST: * G_TYPE_CHECK_CLASS_CAST:
* @g_class: Location of a #GTypeClass structure. * @g_class: Location of a #GTypeClass structure
* @g_type: The type to be returned. * @g_type: The type to be returned
* @c_type: The corresponding C type of class structure of @g_type. * @c_type: The corresponding C type of class structure of @g_type
* *
* Checks that @g_class is a class structure of the type identified by @g_type * Checks that @g_class is a class structure of the type identified by @g_type
* and issues a warning if this is not the case. Returns @g_class casted * and issues a warning if this is not the case. Returns @g_class casted
@ -546,15 +546,15 @@ struct _GTypeQuery
#define G_TYPE_CHECK_CLASS_CAST(g_class, g_type, c_type) (_G_TYPE_CCC ((g_class), (g_type), c_type)) #define G_TYPE_CHECK_CLASS_CAST(g_class, g_type, c_type) (_G_TYPE_CCC ((g_class), (g_type), c_type))
/** /**
* G_TYPE_CHECK_CLASS_TYPE: * G_TYPE_CHECK_CLASS_TYPE:
* @g_class: Location of a #GTypeClass structure. * @g_class: Location of a #GTypeClass structure
* @g_type: The type to be checked. * @g_type: The type to be checked
* *
* Checks if @g_class is a class structure of the type identified by * Checks if @g_class is a class structure of the type identified by
* @g_type. * @g_type.
* *
* This macro should only be used in type implementations. * This macro should only be used in type implementations.
* *
* Returns: %TRUE on success. * Returns: %TRUE on success
*/ */
#define G_TYPE_CHECK_CLASS_TYPE(g_class, g_type) (_G_TYPE_CCT ((g_class), (g_type))) #define G_TYPE_CHECK_CLASS_TYPE(g_class, g_type) (_G_TYPE_CCT ((g_class), (g_type)))
/** /**
@ -566,25 +566,25 @@ struct _GTypeQuery
* *
* This macro should only be used in type implementations. * This macro should only be used in type implementations.
* *
* Returns: %TRUE on success. * Returns: %TRUE on success
*/ */
#define G_TYPE_CHECK_VALUE(value) (_G_TYPE_CHV ((value))) #define G_TYPE_CHECK_VALUE(value) (_G_TYPE_CHV ((value)))
/** /**
* G_TYPE_CHECK_VALUE_TYPE: * G_TYPE_CHECK_VALUE_TYPE:
* @value: a #GValue * @value: a #GValue
* @g_type: The type to be checked. * @g_type: The type to be checked
* *
* Checks if @value has been initialized to hold values * Checks if @value has been initialized to hold values
* of type @g_type. * of type @g_type.
* *
* This macro should only be used in type implementations. * This macro should only be used in type implementations.
* *
* Returns: %TRUE on success. * Returns: %TRUE on success
*/ */
#define G_TYPE_CHECK_VALUE_TYPE(value, g_type) (_G_TYPE_CVH ((value), (g_type))) #define G_TYPE_CHECK_VALUE_TYPE(value, g_type) (_G_TYPE_CVH ((value), (g_type)))
/** /**
* G_TYPE_FROM_INSTANCE: * G_TYPE_FROM_INSTANCE:
* @instance: Location of a valid #GTypeInstance structure. * @instance: Location of a valid #GTypeInstance structure
* *
* Get the type identifier from a given @instance structure. * Get the type identifier from a given @instance structure.
* *
@ -595,7 +595,7 @@ struct _GTypeQuery
#define G_TYPE_FROM_INSTANCE(instance) (G_TYPE_FROM_CLASS (((GTypeInstance*) (instance))->g_class)) #define G_TYPE_FROM_INSTANCE(instance) (G_TYPE_FROM_CLASS (((GTypeInstance*) (instance))->g_class))
/** /**
* G_TYPE_FROM_CLASS: * G_TYPE_FROM_CLASS:
* @g_class: Location of a valid #GTypeClass structure. * @g_class: Location of a valid #GTypeClass structure
* *
* Get the type identifier from a given @class structure. * Get the type identifier from a given @class structure.
* *
@ -606,7 +606,7 @@ struct _GTypeQuery
#define G_TYPE_FROM_CLASS(g_class) (((GTypeClass*) (g_class))->g_type) #define G_TYPE_FROM_CLASS(g_class) (((GTypeClass*) (g_class))->g_type)
/** /**
* G_TYPE_FROM_INTERFACE: * G_TYPE_FROM_INTERFACE:
* @g_iface: Location of a valid #GTypeInterface structure. * @g_iface: Location of a valid #GTypeInterface structure
* *
* Get the type identifier from a given @interface structure. * Get the type identifier from a given @interface structure.
* *
@ -618,9 +618,9 @@ struct _GTypeQuery
/** /**
* G_TYPE_INSTANCE_GET_PRIVATE: * G_TYPE_INSTANCE_GET_PRIVATE:
* @instance: the instance of a type deriving from @private_type. * @instance: the instance of a type deriving from @private_type
* @g_type: the type identifying which private data to retrieve. * @g_type: the type identifying which private data to retrieve
* @c_type: The C type for the private structure. * @c_type: The C type for the private structure
* *
* Gets the private structure for a particular type. * Gets the private structure for a particular type.
* The private structure must have been registered in the * The private structure must have been registered in the
@ -629,15 +629,15 @@ struct _GTypeQuery
* This macro should only be used in type implementations. * This macro should only be used in type implementations.
* *
* Since: 2.4 * Since: 2.4
* Returns: a pointer to the private data structure. * Returns: a pointer to the private data structure
*/ */
#define G_TYPE_INSTANCE_GET_PRIVATE(instance, g_type, c_type) ((c_type*) g_type_instance_get_private ((GTypeInstance*) (instance), (g_type))) #define G_TYPE_INSTANCE_GET_PRIVATE(instance, g_type, c_type) ((c_type*) g_type_instance_get_private ((GTypeInstance*) (instance), (g_type)))
/** /**
* G_TYPE_CLASS_GET_PRIVATE: * G_TYPE_CLASS_GET_PRIVATE:
* @klass: the class of a type deriving from @private_type. * @klass: the class of a type deriving from @private_type
* @g_type: the type identifying which private data to retrieve. * @g_type: the type identifying which private data to retrieve
* @c_type: The C type for the private structure. * @c_type: The C type for the private structure
* *
* Gets the private class structure for a particular type. * Gets the private class structure for a particular type.
* The private structure must have been registered in the * The private structure must have been registered in the
@ -646,16 +646,16 @@ struct _GTypeQuery
* This macro should only be used in type implementations. * This macro should only be used in type implementations.
* *
* Since: 2.24 * Since: 2.24
* Returns: a pointer to the private data structure. * Returns: a pointer to the private data structure
*/ */
#define G_TYPE_CLASS_GET_PRIVATE(klass, g_type, c_type) ((c_type*) g_type_class_get_private ((GTypeClass*) (klass), (g_type))) #define G_TYPE_CLASS_GET_PRIVATE(klass, g_type, c_type) ((c_type*) g_type_class_get_private ((GTypeClass*) (klass), (g_type)))
/** /**
* GTypeDebugFlags: * GTypeDebugFlags:
* @G_TYPE_DEBUG_NONE: Print no messages. * @G_TYPE_DEBUG_NONE: Print no messages
* @G_TYPE_DEBUG_OBJECTS: Print messages about object bookkeeping. * @G_TYPE_DEBUG_OBJECTS: Print messages about object bookkeeping
* @G_TYPE_DEBUG_SIGNALS: Print messages about signal emissions. * @G_TYPE_DEBUG_SIGNALS: Print messages about signal emissions
* @G_TYPE_DEBUG_MASK: Mask covering all debug flags. * @G_TYPE_DEBUG_MASK: Mask covering all debug flags
* *
* These flags used to be passed to g_type_init_with_debug_flags() which * These flags used to be passed to g_type_init_with_debug_flags() which
* is now deprecated. * is now deprecated.
@ -742,7 +742,7 @@ void g_type_query (GType type,
/* --- type registration --- */ /* --- type registration --- */
/** /**
* GBaseInitFunc: * GBaseInitFunc:
* @g_class: The #GTypeClass structure to initialize. * @g_class: The #GTypeClass structure to initialize
* *
* A callback function used by the type system to do base initialization * A callback function used by the type system to do base initialization
* of the class structures of derived types. It is called as part of the * of the class structures of derived types. It is called as part of the
@ -756,7 +756,7 @@ void g_type_query (GType type,
typedef void (*GBaseInitFunc) (gpointer g_class); typedef void (*GBaseInitFunc) (gpointer g_class);
/** /**
* GBaseFinalizeFunc: * GBaseFinalizeFunc:
* @g_class: The #GTypeClass structure to finalize. * @g_class: The #GTypeClass structure to finalize
* *
* A callback function used by the type system to finalize those portions * A callback function used by the type system to finalize those portions
* of a derived types class structure that were setup from the corresponding * of a derived types class structure that were setup from the corresponding
@ -773,24 +773,17 @@ typedef void (*GBaseFinalizeFunc) (gpointer g_class);
* A callback function used by the type system to initialize the class * A callback function used by the type system to initialize the class
* of a specific type. This function should initialize all static class * of a specific type. This function should initialize all static class
* members. * members.
*
* The initialization process of a class involves: * The initialization process of a class involves:
* <itemizedlist> *
* <listitem><para> * - Copying common members from the parent class over to the
* 1 - Copying common members from the parent class over to the
* derived class structure. * derived class structure.
* </para></listitem> * - Zero initialization of the remaining members not copied
* <listitem><para>
* 2 - Zero initialization of the remaining members not copied
* over from the parent class. * over from the parent class.
* </para></listitem> * - Invocation of the GBaseInitFunc() initializers of all parent
* <listitem><para>
* 3 - Invocation of the GBaseInitFunc() initializers of all parent
* types and the class' type. * types and the class' type.
* </para></listitem> * - Invocation of the class' GClassInitFunc() initializer.
* <listitem><para> *
* 4 - Invocation of the class' GClassInitFunc() initializer.
* </para></listitem>
* </itemizedlist>
* Since derived classes are partially initialized through a memory copy * Since derived classes are partially initialized through a memory copy
* of the parent class, the general rule is that GBaseInitFunc() and * of the parent class, the general rule is that GBaseInitFunc() and
* GBaseFinalizeFunc() should take care of necessary reinitialization * GBaseFinalizeFunc() should take care of necessary reinitialization
@ -801,10 +794,11 @@ typedef void (*GBaseFinalizeFunc) (gpointer g_class);
* or reference counted resources) are better handled by a GBaseInitFunc() * or reference counted resources) are better handled by a GBaseInitFunc()
* for this type, so proper initialization of the dynamic class members * for this type, so proper initialization of the dynamic class members
* is performed for class initialization of derived types as well. * is performed for class initialization of derived types as well.
*
* An example may help to correspond the intend of the different class * An example may help to correspond the intend of the different class
* initializers: * initializers:
* *
* |[ * |[<!-- language="C" -->
* typedef struct { * typedef struct {
* GObjectClass parent_class; * GObjectClass parent_class;
* gint static_integer; * gint static_integer;
@ -850,6 +844,7 @@ typedef void (*GBaseFinalizeFunc) (gpointer g_class);
* Initialization of TypeBClass will first cause initialization of * Initialization of TypeBClass will first cause initialization of
* TypeAClass (derived classes reference their parent classes, see * TypeAClass (derived classes reference their parent classes, see
* g_type_class_ref() on this). * g_type_class_ref() on this).
*
* Initialization of TypeAClass roughly involves zero-initializing its fields, * Initialization of TypeAClass roughly involves zero-initializing its fields,
* then calling its GBaseInitFunc() type_a_base_class_init() to allocate * then calling its GBaseInitFunc() type_a_base_class_init() to allocate
* its dynamic members (dynamic_string), and finally calling its GClassInitFunc() * its dynamic members (dynamic_string), and finally calling its GClassInitFunc()
@ -860,11 +855,13 @@ typedef void (*GBaseFinalizeFunc) (gpointer g_class);
* The dynamic members of TypeAClass within TypeBClass now need * The dynamic members of TypeAClass within TypeBClass now need
* reinitialization which is performed by calling type_a_base_class_init() * reinitialization which is performed by calling type_a_base_class_init()
* with an argument of TypeBClass. * with an argument of TypeBClass.
*
* After that, the GBaseInitFunc() of TypeBClass, type_b_base_class_init() * After that, the GBaseInitFunc() of TypeBClass, type_b_base_class_init()
* is called to allocate the dynamic members of TypeBClass (dynamic_gstring), * is called to allocate the dynamic members of TypeBClass (dynamic_gstring),
* and finally the GClassInitFunc() of TypeBClass, type_b_class_init(), * and finally the GClassInitFunc() of TypeBClass, type_b_class_init(),
* is called to complete the initialization process with the static members * is called to complete the initialization process with the static members
* (static_float). * (static_float).
*
* Corresponding finalization counter parts to the GBaseInitFunc() functions * Corresponding finalization counter parts to the GBaseInitFunc() functions
* have to be provided to release allocated resources at class finalization * have to be provided to release allocated resources at class finalization
* time. * time.
@ -873,8 +870,8 @@ typedef void (*GClassInitFunc) (gpointer g_class,
gpointer class_data); gpointer class_data);
/** /**
* GClassFinalizeFunc: * GClassFinalizeFunc:
* @g_class: The #GTypeClass structure to finalize. * @g_class: The #GTypeClass structure to finalize
* @class_data: The @class_data member supplied via the #GTypeInfo structure. * @class_data: The @class_data member supplied via the #GTypeInfo structure
* *
* A callback function used by the type system to finalize a class. * A callback function used by the type system to finalize a class.
* This function is rarely needed, as dynamically allocated class resources * This function is rarely needed, as dynamically allocated class resources
@ -888,8 +885,8 @@ typedef void (*GClassFinalizeFunc) (gpointer g_class,
gpointer class_data); gpointer class_data);
/** /**
* GInstanceInitFunc: * GInstanceInitFunc:
* @instance: The instance to initialize. * @instance: The instance to initialize
* @g_class: The class of the type the instance is created for. * @g_class: The class of the type the instance is created for
* *
* A callback function used by the type system to initialize a new * A callback function used by the type system to initialize a new
* instance of a type. This function initializes all instance members and * instance of a type. This function initializes all instance members and
@ -907,8 +904,8 @@ typedef void (*GInstanceInitFunc) (GTypeInstance *instance,
gpointer g_class); gpointer g_class);
/** /**
* GInterfaceInitFunc: * GInterfaceInitFunc:
* @g_iface: The interface structure to initialize. * @g_iface: The interface structure to initialize
* @iface_data: The @interface_data supplied via the #GInterfaceInfo structure. * @iface_data: The @interface_data supplied via the #GInterfaceInfo structure
* *
* A callback function used by the type system to initialize a new * A callback function used by the type system to initialize a new
* interface. This function should initialize all internal data and * interface. This function should initialize all internal data and
@ -921,8 +918,8 @@ typedef void (*GInterfaceInitFunc) (gpointer g_iface,
gpointer iface_data); gpointer iface_data);
/** /**
* GInterfaceFinalizeFunc: * GInterfaceFinalizeFunc:
* @g_iface: The interface structure to finalize. * @g_iface: The interface structure to finalize
* @iface_data: The @interface_data supplied via the #GInterfaceInfo structure. * @iface_data: The @interface_data supplied via the #GInterfaceInfo structure
* *
* A callback function used by the type system to finalize an interface. * A callback function used by the type system to finalize an interface.
* This function should destroy any internal data and release any resources * This function should destroy any internal data and release any resources
@ -946,13 +943,13 @@ typedef void (*GInterfaceFinalizeFunc) (gpointer g_iface,
* classes are routed through the same #GTypeClassCacheFunc chain. * classes are routed through the same #GTypeClassCacheFunc chain.
* *
* Returns: %TRUE to stop further #GTypeClassCacheFuncs from being * Returns: %TRUE to stop further #GTypeClassCacheFuncs from being
* called, %FALSE to continue. * called, %FALSE to continue
*/ */
typedef gboolean (*GTypeClassCacheFunc) (gpointer cache_data, typedef gboolean (*GTypeClassCacheFunc) (gpointer cache_data,
GTypeClass *g_class); GTypeClass *g_class);
/** /**
* GTypeInterfaceCheckFunc: * GTypeInterfaceCheckFunc:
* @check_data: data passed to g_type_add_interface_check(). * @check_data: data passed to g_type_add_interface_check()
* @g_iface: the interface that has been initialized * @g_iface: the interface that has been initialized
* *
* A callback called after an interface vtable is initialized. * A callback called after an interface vtable is initialized.
@ -964,10 +961,10 @@ typedef void (*GTypeInterfaceCheckFunc) (gpointer check_data,
gpointer g_iface); gpointer g_iface);
/** /**
* GTypeFundamentalFlags: * GTypeFundamentalFlags:
* @G_TYPE_FLAG_CLASSED: Indicates a classed type. * @G_TYPE_FLAG_CLASSED: Indicates a classed type
* @G_TYPE_FLAG_INSTANTIATABLE: Indicates an instantiable type (implies classed). * @G_TYPE_FLAG_INSTANTIATABLE: Indicates an instantiable type (implies classed)
* @G_TYPE_FLAG_DERIVABLE: Indicates a flat derivable type. * @G_TYPE_FLAG_DERIVABLE: Indicates a flat derivable type
* @G_TYPE_FLAG_DEEP_DERIVABLE: Indicates a deep derivable type (implies derivable). * @G_TYPE_FLAG_DEEP_DERIVABLE: Indicates a deep derivable type (implies derivable)
* *
* Bit masks used to check or determine specific characteristics of a * Bit masks used to check or determine specific characteristics of a
* fundamental type. * fundamental type.
@ -982,10 +979,10 @@ typedef enum /*< skip >*/
/** /**
* GTypeFlags: * GTypeFlags:
* @G_TYPE_FLAG_ABSTRACT: Indicates an abstract type. No instances can be * @G_TYPE_FLAG_ABSTRACT: Indicates an abstract type. No instances can be
* created for an abstract type. * created for an abstract type
* @G_TYPE_FLAG_VALUE_ABSTRACT: Indicates an abstract value type, i.e. a type * @G_TYPE_FLAG_VALUE_ABSTRACT: Indicates an abstract value type, i.e. a type
* that introduces a value table, but can't be used for * that introduces a value table, but can't be used for
* g_value_init(). * g_value_init()
* *
* Bit masks used to check or determine characteristics of a type. * Bit masks used to check or determine characteristics of a type.
*/ */
@ -996,9 +993,9 @@ typedef enum /*< skip >*/
} GTypeFlags; } GTypeFlags;
/** /**
* GTypeInfo: * GTypeInfo:
* @class_size: Size of the class structure (required for interface, classed and instantiatable types). * @class_size: Size of the class structure (required for interface, classed and instantiatable types)
* @base_init: Location of the base initialization function (optional). * @base_init: Location of the base initialization function (optional)
* @base_finalize: Location of the base finalization function (optional). * @base_finalize: Location of the base finalization function (optional)
* @class_init: Location of the class initialization function for * @class_init: Location of the class initialization function for
* classed and instantiatable types. Location of the default vtable * classed and instantiatable types. Location of the default vtable
* inititalization function for interface types. (optional) This function * inititalization function for interface types. (optional) This function
@ -1008,16 +1005,17 @@ typedef enum /*< skip >*/
* @class_finalize: Location of the class finalization function for * @class_finalize: Location of the class finalization function for
* classed and instantiatable types. Location of the default vtable * classed and instantiatable types. Location of the default vtable
* finalization function for interface types. (optional) * finalization function for interface types. (optional)
* @class_data: User-supplied data passed to the class init/finalize functions. * @class_data: User-supplied data passed to the class init/finalize functions
* @instance_size: Size of the instance (object) structure (required for instantiatable types only). * @instance_size: Size of the instance (object) structure (required for instantiatable types only)
* @n_preallocs: Prior to GLib 2.10, it specified the number of pre-allocated (cached) instances to reserve memory for (0 indicates no caching). Since GLib 2.10, it is ignored, since instances are allocated with the [slice allocator][glib-Memory-Slices] now. * @n_preallocs: Prior to GLib 2.10, it specified the number of pre-allocated (cached) instances to reserve memory for (0 indicates no caching). Since GLib 2.10, it is ignored, since instances are allocated with the [slice allocator][glib-Memory-Slices] now.
* @instance_init: Location of the instance initialization function (optional, for instantiatable types only). * @instance_init: Location of the instance initialization function (optional, for instantiatable types only)
* @value_table: A #GTypeValueTable function table for generic handling of GValues of this type (usually only * @value_table: A #GTypeValueTable function table for generic handling of GValues
* useful for fundamental types). * of this type (usually only useful for fundamental types)
* *
* This structure is used to provide the type system with the information * This structure is used to provide the type system with the information
* required to initialize and destruct (finalize) a type's class and * required to initialize and destruct (finalize) a type's class and
* its instances. * its instances.
*
* The initialized structure is passed to the g_type_register_static() function * The initialized structure is passed to the g_type_register_static() function
* (or is copied into the provided #GTypeInfo structure in the * (or is copied into the provided #GTypeInfo structure in the
* g_type_plugin_complete_type_info()). The type system will perform a deep * g_type_plugin_complete_type_info()). The type system will perform a deep
@ -1080,14 +1078,14 @@ struct _GInterfaceInfo
* old contents. E.g. for the implementation of a string * old contents. E.g. for the implementation of a string
* value that may never be %NULL, the implementation might * value that may never be %NULL, the implementation might
* look like: * look like:
* |[ * |[<!-- language="C" -->
* value->data[0].v_pointer = g_strdup (""); * value->data[0].v_pointer = g_strdup ("");
* ]| * ]|
* @value_free: Free any old contents that might be left in the * @value_free: Free any old contents that might be left in the
* data array of the passed in @value. No resources may * data array of the passed in @value. No resources may
* remain allocated through the #GValue contents after * remain allocated through the #GValue contents after
* this function returns. E.g. for our above string type: * this function returns. E.g. for our above string type:
* |[ * |[<!-- language="C" -->
* // only free strings without a specific flag for static storage * // only free strings without a specific flag for static storage
* if (!(value->data[1].v_uint & G_VALUE_NOCOPY_CONTENTS)) * if (!(value->data[1].v_uint & G_VALUE_NOCOPY_CONTENTS))
* g_free (value->data[0].v_pointer); * g_free (value->data[0].v_pointer);
@ -1099,33 +1097,25 @@ struct _GInterfaceInfo
* @src_value into @dest_value in a way, that even after * @src_value into @dest_value in a way, that even after
* @src_value has been freed, the contents of @dest_value * @src_value has been freed, the contents of @dest_value
* remain valid. String type example: * remain valid. String type example:
* |[ * |[<!-- language="C" -->
* dest_value->data[0].v_pointer = g_strdup (src_value->data[0].v_pointer); * dest_value->data[0].v_pointer = g_strdup (src_value->data[0].v_pointer);
* ]| * ]|
* @value_peek_pointer: If the value contents fit into a pointer, such as objects * @value_peek_pointer: If the value contents fit into a pointer, such as objects
* or strings, return this pointer, so the caller can peek at * or strings, return this pointer, so the caller can peek at
* the current contents. To extend on our above string example: * the current contents. To extend on our above string example:
* |[ * |[<!-- language="C" -->
* return value->data[0].v_pointer; * return value->data[0].v_pointer;
* ]| * ]|
* @collect_format: A string format describing how to collect the contents of * @collect_format: A string format describing how to collect the contents of
* this value bit-by-bit. Each character in the format represents * this value bit-by-bit. Each character in the format represents
* an argument to be collected, and the characters themselves indicate * an argument to be collected, and the characters themselves indicate
* the type of the argument. Currently supported arguments are: * the type of the argument. Currently supported arguments are:
* <variablelist> *
* <varlistentry><term /><listitem><para> * - 'i' - Integers. passed as collect_values[].v_int.
* 'i' - Integers. passed as collect_values[].v_int. * - 'l' - Longs. passed as collect_values[].v_long.
* </para></listitem></varlistentry> * - 'd' - Doubles. passed as collect_values[].v_double.
* <varlistentry><term /><listitem><para> * - 'p' - Pointers. passed as collect_values[].v_pointer.
* 'l' - Longs. passed as collect_values[].v_long. *
* </para></listitem></varlistentry>
* <varlistentry><term /><listitem><para>
* 'd' - Doubles. passed as collect_values[].v_double.
* </para></listitem></varlistentry>
* <varlistentry><term /><listitem><para>
* 'p' - Pointers. passed as collect_values[].v_pointer.
* </para></listitem></varlistentry>
* </variablelist>
* It should be noted that for variable argument list construction, * It should be noted that for variable argument list construction,
* ANSI C promotes every type smaller than an integer to an int, and * ANSI C promotes every type smaller than an integer to an int, and
* floats to doubles. So for collection of short int or char, 'i' * floats to doubles. So for collection of short int or char, 'i'
@ -1150,7 +1140,7 @@ struct _GInterfaceInfo
* Thus an extra copy of the contents stored in @collect_values is * Thus an extra copy of the contents stored in @collect_values is
* not required for assignment to @value. * not required for assignment to @value.
* For our above string example, we continue with: * For our above string example, we continue with:
* |[ * |[<!-- language="C" -->
* if (!collect_values[0].v_pointer) * if (!collect_values[0].v_pointer)
* value->data[0].v_pointer = g_strdup (""); * value->data[0].v_pointer = g_strdup ("");
* else if (collect_flags & G_VALUE_NOCOPY_CONTENTS) * else if (collect_flags & G_VALUE_NOCOPY_CONTENTS)
@ -1171,7 +1161,7 @@ struct _GInterfaceInfo
* array. To deviate from our string example for a moment, and taking * array. To deviate from our string example for a moment, and taking
* a look at an exemplary implementation for collect_value() of * a look at an exemplary implementation for collect_value() of
* #GObject: * #GObject:
* |[ * |[<!-- language="C" -->
* if (collect_values[0].v_pointer) * if (collect_values[0].v_pointer)
* { * {
* GObject *object = G_OBJECT (collect_values[0].v_pointer); * GObject *object = G_OBJECT (collect_values[0].v_pointer);
@ -1211,7 +1201,7 @@ struct _GInterfaceInfo
* Similar to collect_value() the function may prematurely abort * Similar to collect_value() the function may prematurely abort
* by returning a newly allocated string describing an error condition. * by returning a newly allocated string describing an error condition.
* To complete the string example: * To complete the string example:
* |[ * |[<!-- language="C" -->
* gchar **string_p = collect_values[0].v_pointer; * gchar **string_p = collect_values[0].v_pointer;
* if (!string_p) * if (!string_p)
* return g_strdup_printf ("string location passed as NULL"); * return g_strdup_printf ("string location passed as NULL");
@ -1222,21 +1212,21 @@ struct _GInterfaceInfo
* ]| * ]|
* And an illustrative version of lcopy_value() for * And an illustrative version of lcopy_value() for
* reference-counted types: * reference-counted types:
* |[ * |[<!-- language="C" -->
* GObject **object_p = collect_values[0].v_pointer; * GObject **object_p = collect_values[0].v_pointer;
* if (!object_p) * if (!object_p)
* return g_strdup_printf ("object location passed as NULL"); * return g_strdup_printf ("object location passed as NULL");
* if (!value->data[0].v_pointer) * if (!value->data[0].v_pointer)
* *object_p = NULL; * *object_p = NULL;
* else if (collect_flags & G_VALUE_NOCOPY_CONTENTS) /&ast; always honour &ast;/ * else if (collect_flags & G_VALUE_NOCOPY_CONTENTS) // always honour
* *object_p = value->data[0].v_pointer; * *object_p = value->data[0].v_pointer;
* else * else
* *object_p = g_object_ref (value->data[0].v_pointer); * *object_p = g_object_ref (value->data[0].v_pointer);
* return NULL; * return NULL;
* ]| * ]|
* *
* The #GTypeValueTable provides the functions required by the #GValue implementation, * The #GTypeValueTable provides the functions required by the #GValue
* to serve as a container for values of a type. * implementation, to serve as a container for values of a type.
*/ */
struct _GTypeValueTable struct _GTypeValueTable
@ -1333,10 +1323,11 @@ guint g_type_get_type_registration_serial (void);
* separated by '_'. * separated by '_'.
* @T_P: The #GType of the parent type. * @T_P: The #GType of the parent type.
* *
* A convenience macro for type implementations, which declares a * A convenience macro for type implementations, which declares a class
* class initialization function, an instance initialization function (see #GTypeInfo for information about * initialization function, an instance initialization function (see #GTypeInfo
* these) and a static variable named @t_n<!-- -->_parent_class pointing to the parent class. Furthermore, it defines * for information about these) and a static variable named `t_n_parent_class`
* a *_get_type() function. See G_DEFINE_TYPE_EXTENDED() for an example. * pointing to the parent class. Furthermore, it defines a *_get_type() function.
* See G_DEFINE_TYPE_EXTENDED() for an example.
* *
* Since: 2.4 * Since: 2.4
*/ */
@ -1363,14 +1354,15 @@ guint g_type_get_type_registration_serial (void);
* separated by '_'. * separated by '_'.
* @T_P: The #GType of the parent type. * @T_P: The #GType of the parent type.
* *
* A convenience macro for type implementations, which declares a * A convenience macro for type implementations, which declares a class
* class initialization function, an instance initialization function (see #GTypeInfo for information about * initialization function, an instance initialization function (see #GTypeInfo
* these), a static variable named @t_n<!-- -->_parent_class pointing to the parent class, and adds private * for information about these), a static variable named `t_n_parent_class`
* instance data to the type. Furthermore, it defines a *_get_type() function. See G_DEFINE_TYPE_EXTENDED() * pointing to the parent class, and adds private instance data to the type.
* Furthermore, it defines a *_get_type() function. See G_DEFINE_TYPE_EXTENDED()
* for an example. * for an example.
* *
* Note that private structs added with this macros must have a struct * Note that private structs added with this macros must have a struct
* name of the form <replaceable>@TN</replaceable>Private. * name of the form @TN Private.
* *
* Since: 2.38 * Since: 2.38
*/ */
@ -1398,9 +1390,10 @@ guint g_type_get_type_registration_serial (void);
* @_C_: Custom code that gets inserted in the @type_name_get_type() function. * @_C_: Custom code that gets inserted in the @type_name_get_type() function.
* *
* A convenience macro for type implementations. * A convenience macro for type implementations.
* Similar to G_DEFINE_TYPE_WITH_CODE(), but defines an abstract type and allows you to * Similar to G_DEFINE_TYPE_WITH_CODE(), but defines an abstract type and
* insert custom code into the *_get_type() function, e.g. interface implementations * allows you to insert custom code into the *_get_type() function, e.g.
* via G_IMPLEMENT_INTERFACE(). See G_DEFINE_TYPE_EXTENDED() for an example. * interface implementations via G_IMPLEMENT_INTERFACE().
* See G_DEFINE_TYPE_EXTENDED() for an example.
* *
* Since: 2.4 * Since: 2.4
*/ */
@ -1430,7 +1423,7 @@ guint g_type_get_type_registration_serial (void);
* The most general convenience macro for type implementations, on which * The most general convenience macro for type implementations, on which
* G_DEFINE_TYPE(), etc are based. * G_DEFINE_TYPE(), etc are based.
* *
* |[ * |[<!-- language="C" -->
* G_DEFINE_TYPE_EXTENDED (GtkGadget, * G_DEFINE_TYPE_EXTENDED (GtkGadget,
* gtk_gadget, * gtk_gadget,
* GTK_TYPE_WIDGET, * GTK_TYPE_WIDGET,
@ -1439,7 +1432,7 @@ guint g_type_get_type_registration_serial (void);
* gtk_gadget_gizmo_init)); * gtk_gadget_gizmo_init));
* ]| * ]|
* expands to * expands to
* |[ * |[<!-- language="C" -->
* static void gtk_gadget_init (GtkGadget *self); * static void gtk_gadget_init (GtkGadget *self);
* static void gtk_gadget_class_init (GtkGadgetClass *klass); * static void gtk_gadget_class_init (GtkGadgetClass *klass);
* static gpointer gtk_gadget_parent_class = NULL; * static gpointer gtk_gadget_parent_class = NULL;
@ -1525,7 +1518,7 @@ guint g_type_get_type_registration_serial (void);
* @TYPE_IFACE: The #GType of the interface to add * @TYPE_IFACE: The #GType of the interface to add
* @iface_init: The interface init function * @iface_init: The interface init function
* *
* A convenience macro to ease interface addition in the @_C_ section * A convenience macro to ease interface addition in the `_C_` section
* of G_DEFINE_TYPE_WITH_CODE() or G_DEFINE_ABSTRACT_TYPE_WITH_CODE(). * of G_DEFINE_TYPE_WITH_CODE() or G_DEFINE_ABSTRACT_TYPE_WITH_CODE().
* See G_DEFINE_TYPE_EXTENDED() for an example. * See G_DEFINE_TYPE_EXTENDED() for an example.
* *
@ -1551,7 +1544,7 @@ guint g_type_get_type_registration_serial (void);
* *
* For instance: * For instance:
* *
* |[ * |[<!-- language="C" -->
* typedef struct _MyObject MyObject; * typedef struct _MyObject MyObject;
* typedef struct _MyObjectClass MyObjectClass; * typedef struct _MyObjectClass MyObjectClass;
* *
@ -1571,7 +1564,7 @@ guint g_type_get_type_registration_serial (void);
* based on the arguments to this macro, which can be used to safely * based on the arguments to this macro, which can be used to safely
* retrieve the private data from an instance of the type; for instance: * retrieve the private data from an instance of the type; for instance:
* *
* |[ * |[<!-- language="C" -->
* gint * gint
* my_object_get_foo (MyObject *obj) * my_object_get_foo (MyObject *obj)
* { * {
@ -1595,7 +1588,7 @@ guint g_type_get_type_registration_serial (void);
* macros, since it depends on variable names from those macros. * macros, since it depends on variable names from those macros.
* *
* Also note that private structs added with these macros must have a struct * Also note that private structs added with these macros must have a struct
* name of the form <replaceable>TypeName</replaceable>Private. * name of the form `TypeNamePrivate`.
* *
* Since: 2.38 * Since: 2.38
*/ */
@ -1751,9 +1744,9 @@ type_name##_get_type (void) \
/** /**
* G_DEFINE_BOXED_TYPE: * G_DEFINE_BOXED_TYPE:
* @TypeName: The name of the new type, in Camel case. * @TypeName: The name of the new type, in Camel case
* @type_name: The name of the new type, in lowercase, with words * @type_name: The name of the new type, in lowercase, with words
* separated by '_'. * separated by '_'
* @copy_func: the #GBoxedCopyFunc for the new type * @copy_func: the #GBoxedCopyFunc for the new type
* @free_func: the #GBoxedFreeFunc for the new type * @free_func: the #GBoxedFreeFunc for the new type
* *
@ -1765,12 +1758,12 @@ type_name##_get_type (void) \
#define G_DEFINE_BOXED_TYPE(TypeName, type_name, copy_func, free_func) G_DEFINE_BOXED_TYPE_WITH_CODE (TypeName, type_name, copy_func, free_func, {}) #define G_DEFINE_BOXED_TYPE(TypeName, type_name, copy_func, free_func) G_DEFINE_BOXED_TYPE_WITH_CODE (TypeName, type_name, copy_func, free_func, {})
/** /**
* G_DEFINE_BOXED_TYPE_WITH_CODE: * G_DEFINE_BOXED_TYPE_WITH_CODE:
* @TypeName: The name of the new type, in Camel case. * @TypeName: The name of the new type, in Camel case
* @type_name: The name of the new type, in lowercase, with words * @type_name: The name of the new type, in lowercase, with words
* separated by '_'. * separated by '_'
* @copy_func: the #GBoxedCopyFunc for the new type * @copy_func: the #GBoxedCopyFunc for the new type
* @free_func: the #GBoxedFreeFunc for the new type * @free_func: the #GBoxedFreeFunc for the new type
* @_C_: Custom code that gets inserted in the *_get_type() function. * @_C_: Custom code that gets inserted in the *_get_type() function
* *
* A convenience macro for boxed type implementations. * A convenience macro for boxed type implementations.
* Similar to G_DEFINE_BOXED_TYPE(), but allows to insert custom code into the * Similar to G_DEFINE_BOXED_TYPE(), but allows to insert custom code into the
@ -1826,9 +1819,9 @@ type_name##_get_type (void) \
/** /**
* G_DEFINE_POINTER_TYPE: * G_DEFINE_POINTER_TYPE:
* @TypeName: The name of the new type, in Camel case. * @TypeName: The name of the new type, in Camel case
* @type_name: The name of the new type, in lowercase, with words * @type_name: The name of the new type, in lowercase, with words
* separated by '_'. * separated by '_'
* *
* A convenience macro for pointer type implementations, which defines a * A convenience macro for pointer type implementations, which defines a
* type_name_get_type() function registering the pointer type. * type_name_get_type() function registering the pointer type.
@ -1838,14 +1831,14 @@ type_name##_get_type (void) \
#define G_DEFINE_POINTER_TYPE(TypeName, type_name) G_DEFINE_POINTER_TYPE_WITH_CODE (TypeName, type_name, {}) #define G_DEFINE_POINTER_TYPE(TypeName, type_name) G_DEFINE_POINTER_TYPE_WITH_CODE (TypeName, type_name, {})
/** /**
* G_DEFINE_POINTER_TYPE_WITH_CODE: * G_DEFINE_POINTER_TYPE_WITH_CODE:
* @TypeName: The name of the new type, in Camel case. * @TypeName: The name of the new type, in Camel case
* @type_name: The name of the new type, in lowercase, with words * @type_name: The name of the new type, in lowercase, with words
* separated by '_'. * separated by '_'
* @_C_: Custom code that gets inserted in the *_get_type() function. * @_C_: Custom code that gets inserted in the *_get_type() function
* *
* A convenience macro for pointer type implementations. * A convenience macro for pointer type implementations.
* Similar to G_DEFINE_POINTER_TYPE(), but allows to insert custom code into the * Similar to G_DEFINE_POINTER_TYPE(), but allows to insert
* type_name_get_type() function. * custom code into the type_name_get_type() function.
* *
* Since: 2.26 * Since: 2.26
*/ */