mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-04-06 15:53:06 +02:00
Improve docs for G_DEFINE_TYPE_* macros.
Sun Jan 11 01:25:44 2004 Matthias Clasen <maclas@gmx.de> * gobject/tmpl/gtype.sgml: Improve docs for G_DEFINE_TYPE_* macros. Sun Jan 11 01:25:29 2004 Matthias Clasen <maclas@gmx.de> * gobject/gobject-sections.txt: Add G_DEFINE_TYPE_EXTENDED.
This commit is contained in:
parent
805ba95fb1
commit
af81f44e66
@ -1,3 +1,11 @@
|
|||||||
|
Sun Jan 11 01:25:44 2004 Matthias Clasen <maclas@gmx.de>
|
||||||
|
|
||||||
|
* gobject/tmpl/gtype.sgml: Improve docs for G_DEFINE_TYPE_* macros.
|
||||||
|
|
||||||
|
Sun Jan 11 01:25:29 2004 Matthias Clasen <maclas@gmx.de>
|
||||||
|
|
||||||
|
* gobject/gobject-sections.txt: Add G_DEFINE_TYPE_EXTENDED.
|
||||||
|
|
||||||
Sat Jan 10 02:18:32 2004 Matthias Clasen <maclas@gmx.de>
|
Sat Jan 10 02:18:32 2004 Matthias Clasen <maclas@gmx.de>
|
||||||
|
|
||||||
* gobject/tmpl/gtype.sgml: Document the new GType boilerplate macros
|
* gobject/tmpl/gtype.sgml: Document the new GType boilerplate macros
|
||||||
|
@ -101,6 +101,8 @@ G_DEFINE_TYPE_WITH_CODE
|
|||||||
G_DEFINE_ABSTRACT_TYPE
|
G_DEFINE_ABSTRACT_TYPE
|
||||||
G_DEFINE_ABSTRACT_TYPE_WITH_CODE
|
G_DEFINE_ABSTRACT_TYPE_WITH_CODE
|
||||||
G_IMPLEMENT_INTERFACE
|
G_IMPLEMENT_INTERFACE
|
||||||
|
G_DEFINE_TYPE_EXTENDED
|
||||||
|
|
||||||
<SUBSECTION Private>
|
<SUBSECTION Private>
|
||||||
G_TYPE_FUNDAMENTAL_SHIFT
|
G_TYPE_FUNDAMENTAL_SHIFT
|
||||||
g_type_check_instance
|
g_type_check_instance
|
||||||
@ -115,7 +117,6 @@ g_type_instance_get_private
|
|||||||
g_type_test_flags
|
g_type_test_flags
|
||||||
g_type_name_from_instance
|
g_type_name_from_instance
|
||||||
g_type_name_from_class
|
g_type_name_from_class
|
||||||
G_DEFINE_TYPE_INTERNAL
|
|
||||||
|
|
||||||
<SUBSECTION>
|
<SUBSECTION>
|
||||||
G_TYPE_INVALID
|
G_TYPE_INVALID
|
||||||
|
@ -1462,8 +1462,15 @@ that implements or has internal knowledge of the implementation of
|
|||||||
|
|
||||||
<!-- ##### MACRO G_DEFINE_TYPE ##### -->
|
<!-- ##### MACRO G_DEFINE_TYPE ##### -->
|
||||||
<para>
|
<para>
|
||||||
A convenience macro for type implementations.
|
A convenience macro for type implementations, which declares a
|
||||||
See G_DEFINE_TYPE_WITH_CODE() for an example.
|
class initialization function, an instance initialization function (see #GTypeInfo for information about
|
||||||
|
these) and a static variable named parent_class pointing to the parent class. Furthermore, it defines
|
||||||
|
a *_get_type() function. See G_DEFINE_TYPE_EXTENDED() for an example.
|
||||||
|
</para>
|
||||||
|
<para>
|
||||||
|
Note that you can't use this macro if you want to define multiple types in one file,
|
||||||
|
since the parent_class variables will clash. In this case, use
|
||||||
|
G_DEFINE_TYPE_EXTENDED() and choose different identifiers for @type_parent_class.
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
@TN: The name of the new type, in Camel case.
|
@TN: The name of the new type, in Camel case.
|
||||||
@ -1472,25 +1479,105 @@ See G_DEFINE_TYPE_WITH_CODE() for an example.
|
|||||||
@T_P: The #GType of the parent type.
|
@T_P: The #GType of the parent type.
|
||||||
@Since: 2.4
|
@Since: 2.4
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### MACRO G_DEFINE_TYPE_WITH_CODE ##### -->
|
<!-- ##### MACRO G_DEFINE_TYPE_WITH_CODE ##### -->
|
||||||
<para>
|
<para>
|
||||||
A convenience macro for type implementations.
|
A convenience macro for type implementations.
|
||||||
|
Similar to G_DEFINE_TYPE(), but allows to insert custom code into the
|
||||||
|
*_get_type() function, e.g. interface implementations via G_IMPLEMENT_INTERFACE().
|
||||||
|
See G_DEFINE_TYPE_EXTENDED() for an example.
|
||||||
|
</para>
|
||||||
|
<para>
|
||||||
|
Note that you can't use this macro if you want to define multiple types in one file,
|
||||||
|
since the parent_class variables will clash. In this case, use
|
||||||
|
G_DEFINE_TYPE_EXTENDED() and choose different identifiers for @type_parent_class.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@TN: The name of the new type, in Camel case.
|
||||||
|
@t_n: The name of the new type in lowercase, with words separated by '_'.
|
||||||
|
@T_P: The #GType of the parent type.
|
||||||
|
@_C_: Custom code that gets inserted in the *_get_type() function.
|
||||||
|
@Since: 2.4
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO G_DEFINE_ABSTRACT_TYPE ##### -->
|
||||||
|
<para>
|
||||||
|
A convenience macro for type implementations.
|
||||||
|
Similar to G_DEFINE_TYPE(), but defines an abstract type.
|
||||||
|
See G_DEFINE_TYPE_EXTENDED() for an example.
|
||||||
|
</para>
|
||||||
|
<para>
|
||||||
|
Note that you can't use this macro if you want to define multiple types in one file,
|
||||||
|
since the parent_class variables will clash. In this case, use
|
||||||
|
G_DEFINE_TYPE_EXTENDED() and choose different identifiers for @type_parent_class.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@TN: The name of the new type, in Camel case.
|
||||||
|
@t_n: The name of the new type, in lowercase, with words
|
||||||
|
separated by '_'.
|
||||||
|
@T_P: The #GType of the parent type.
|
||||||
|
@Since: 2.4
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO G_DEFINE_ABSTRACT_TYPE_WITH_CODE ##### -->
|
||||||
|
<para>
|
||||||
|
A convenience macro for type implementations.
|
||||||
|
Similar to G_DEFINE_TYPE_WITH_CODE(), but defines an abstract type and allows to
|
||||||
|
insert custom code into the *_get_type() function, e.g. interface implementations
|
||||||
|
via G_IMPLEMENT_INTERFACE(). See G_DEFINE_TYPE_EXTENDED() for an example.
|
||||||
|
</para>
|
||||||
|
<para>
|
||||||
|
Note that you can't use this macro if you want to define multiple types in one file,
|
||||||
|
since the parent_class variables will clash. In this case, use
|
||||||
|
G_DEFINE_TYPE_EXTENDED() and choose different identifiers for @type_parent_class.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@TN: The name of the new type, in Camel case.
|
||||||
|
@t_n: The name of the new type, in lowercase, with words
|
||||||
|
separated by '_'.
|
||||||
|
@T_P: The #GType of the parent type.
|
||||||
|
@_C_: Custom code that gets inserted in the @type_name_get_type() function.
|
||||||
|
@Since: 2.4
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO G_IMPLEMENT_INTERFACE ##### -->
|
||||||
|
<para>
|
||||||
|
A convenience macro to ease interface addition in the @_C_ section
|
||||||
|
of G_DEFINE_TYPE_WITH_CODE() or G_DEFINE_ABSTRACT_TYPE_WITH_CODE().
|
||||||
|
See G_DEFINE_TYPE_EXTENDED() for an example.
|
||||||
|
</para>
|
||||||
|
<para>
|
||||||
|
Note that this macro can only be used together with the G_DEFINE_TYPE_*
|
||||||
|
macros, since it depends on variable names from those macros.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@TYPE_IFACE: The #GType of the interface to add
|
||||||
|
@iface_init: The interface init function
|
||||||
|
@Since: 2.4
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO G_DEFINE_TYPE_EXTENDED ##### -->
|
||||||
|
<para>
|
||||||
|
The most general convenience macro for type implementations, on which
|
||||||
|
G_DEFINE_TYPE(), etc are based.
|
||||||
</para>
|
</para>
|
||||||
<informalexample><programlisting>
|
<informalexample><programlisting>
|
||||||
G_DEFINE_TYPE_WITH_CODE (GtkGadget,
|
G_DEFINE_TYPE_EXTENDED (GtkGadget,
|
||||||
gtk_gadget,
|
gtk_gadget,
|
||||||
GTK_TYPE_WIDGET,
|
GTK_TYPE_WIDGET,
|
||||||
|
0,
|
||||||
|
gtk_gadget_parent_class,
|
||||||
G_IMPLEMENT_INTERFACE (TYPE_GIZMO,
|
G_IMPLEMENT_INTERFACE (TYPE_GIZMO,
|
||||||
gtk_gadget_gizmo_init));
|
gtk_gadget_gizmo_init));
|
||||||
</programlisting>
|
</programlisting>
|
||||||
exands to
|
expands to
|
||||||
<programlisting>
|
<programlisting>
|
||||||
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 parent_class = NULL;
|
static gpointer gtk_gadget_parent_class = NULL;
|
||||||
static void gtk_gadget_class_intern_init (gpointer klass)
|
static void gtk_gadget_class_intern_init (gpointer klass)
|
||||||
{
|
{
|
||||||
parent_class = g_type_class_peek_parent (klass);
|
gtk_gadget_parent_class = g_type_class_peek_parent (klass);
|
||||||
gtk_gadget_class_init ((GtkGadgetClass*) klass);
|
gtk_gadget_class_init ((GtkGadgetClass*) klass);
|
||||||
}
|
}
|
||||||
<!-- -->
|
<!-- -->
|
||||||
@ -1527,53 +1614,16 @@ instance and class structure and the definitions of the instance and class
|
|||||||
init functions.
|
init functions.
|
||||||
</informalexample>
|
</informalexample>
|
||||||
|
|
||||||
@TN: The name of the new type, in Camel case.
|
@TypeName: The name of the new type, in Camel case.
|
||||||
@t_n: The name of the new type in lowercase, with words separated by '_'.
|
@type_name: The name of the new type, in lowercase, with words
|
||||||
@T_P: The #GType of the parent type.
|
|
||||||
@_C_: Custom code that gets inserted in the *_get_type() function.
|
|
||||||
@Since: 2.4
|
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### MACRO G_DEFINE_ABSTRACT_TYPE ##### -->
|
|
||||||
<para>
|
|
||||||
A convenience macro for type implementations.
|
|
||||||
Similar to G_DEFINE_TYPE(), but defines an abstract type.
|
|
||||||
See G_DEFINE_TYPE_WITH_CODE() for an example.
|
|
||||||
</para>
|
|
||||||
|
|
||||||
@TN: The name of the new type, in Camel case.
|
|
||||||
@t_n: The name of the new type, in lowercase, with words
|
|
||||||
separated by '_'.
|
separated by '_'.
|
||||||
@T_P: The #GType of the parent type.
|
@TYPE_PARENT: The #GType of the parent type.
|
||||||
|
@flags: #GTypeFlags to pass to g_type_register_static()
|
||||||
|
@type_parent_class: the identifier for the static variable holding the parent class
|
||||||
|
@CODE: Custom code that gets inserted in the *_get_type() function.
|
||||||
@Since: 2.4
|
@Since: 2.4
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### MACRO G_DEFINE_ABSTRACT_TYPE_WITH_CODE ##### -->
|
|
||||||
<para>
|
|
||||||
A convenience macro for type implementations.
|
|
||||||
Similar to G_DEFINE_TYPE_WITH_CODE(), but defines an abstract type.
|
|
||||||
See G_DEFINE_TYPE_WITH_CODE() for an example.
|
|
||||||
</para>
|
|
||||||
|
|
||||||
@TN: The name of the new type, in Camel case.
|
|
||||||
@t_n: The name of the new type, in lowercase, with words
|
|
||||||
separated by '_'.
|
|
||||||
@T_P: The #GType of the parent type.
|
|
||||||
@_C_: Custom code that gets inserted in the @type_name_get_type() function.
|
|
||||||
@Since: 2.4
|
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### MACRO G_IMPLEMENT_INTERFACE ##### -->
|
|
||||||
<para>
|
|
||||||
A convenience macro to ease interface addition in the @Code section
|
|
||||||
of G_DEFINE_TYPE_WITH_CODE() or G_DEFINE_ABSTRACT_TYPE_WITH_CODE().
|
|
||||||
See G_DEFINE_TYPE_WITH_CODE() for an example.
|
|
||||||
</para>
|
|
||||||
|
|
||||||
@TYPE_IFACE: The #GType of the interface to add
|
|
||||||
@iface_init: The interface init function
|
|
||||||
@Since: 2.4
|
|
||||||
|
|
||||||
<!-- ##### MACRO G_TYPE_INVALID ##### -->
|
<!-- ##### MACRO G_TYPE_INVALID ##### -->
|
||||||
<para>
|
<para>
|
||||||
An invalid #GType, used as error return value in some functions which return
|
An invalid #GType, used as error return value in some functions which return
|
||||||
|
Loading…
x
Reference in New Issue
Block a user