mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-11 23:16:14 +01:00
docs: GType documentation cleanup
Still some markup left.
This commit is contained in:
parent
24ab95582b
commit
adfaf0e456
@ -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
|
||||||
|
325
gobject/gtype.h
325
gobject/gtype.h
@ -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.
|
* - Zero initialization of the remaining members not copied
|
||||||
* </para></listitem>
|
* over from the parent class.
|
||||||
* <listitem><para>
|
* - Invocation of the GBaseInitFunc() initializers of all parent
|
||||||
* 2 - Zero initialization of the remaining members not copied
|
* types and the class' type.
|
||||||
* over from the parent class.
|
* - Invocation of the class' GClassInitFunc() initializer.
|
||||||
* </para></listitem>
|
*
|
||||||
* <listitem><para>
|
|
||||||
* 3 - Invocation of the GBaseInitFunc() initializers of all parent
|
|
||||||
* types and the class' type.
|
|
||||||
* </para></listitem>
|
|
||||||
* <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) /* always honour */
|
* 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
|
||||||
*/
|
*/
|
||||||
|
Loading…
Reference in New Issue
Block a user