mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-13 07:56:17 +01:00
docs/gobject/tutorial: Use g_object_class_install_properties
This commit is contained in:
parent
c3d6595f5a
commit
9e732ab0ea
@ -495,14 +495,14 @@ void g_object_run_dispose (GObject *object);
|
|||||||
One of GObject's nice features is its generic get/set mechanism for object
|
One of GObject's nice features is its generic get/set mechanism for object
|
||||||
properties. When an object
|
properties. When an object
|
||||||
is instantiated, the object's class_init handler should be used to register
|
is instantiated, the object's class_init handler should be used to register
|
||||||
the object's properties with <function><link linkend="g-object-class-install-property">g_object_class_install_property</link></function>
|
the object's properties with <function><link linkend="g-object-class-install-properties">g_object_class_install_properties</link></function>
|
||||||
(implemented in <filename>gobject.c</filename>).
|
(implemented in <filename>gobject.c</filename>).
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
<para>
|
<para>
|
||||||
The best way to understand how object properties work is by looking at a real example
|
The best way to understand how object properties work is by looking at a real example
|
||||||
on how it is used:
|
on how it is used:
|
||||||
<programlisting>
|
<informalexample><programlisting>
|
||||||
/************************************************/
|
/************************************************/
|
||||||
/* Implementation */
|
/* Implementation */
|
||||||
/************************************************/
|
/************************************************/
|
||||||
@ -512,9 +512,13 @@ enum
|
|||||||
PROP_0,
|
PROP_0,
|
||||||
|
|
||||||
PROP_MAMAN_NAME,
|
PROP_MAMAN_NAME,
|
||||||
PROP_PAPA_NUMBER
|
PROP_PAPA_NUMBER,
|
||||||
|
|
||||||
|
N_PROPERTIES
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static GParamSpec *obj_properties[N_PROPERTIES] = { NULL, };
|
||||||
|
|
||||||
static void
|
static void
|
||||||
maman_bar_set_property (GObject *object,
|
maman_bar_set_property (GObject *object,
|
||||||
guint property_id,
|
guint property_id,
|
||||||
@ -572,30 +576,29 @@ static void
|
|||||||
maman_bar_class_init (MamanBarClass *klass)
|
maman_bar_class_init (MamanBarClass *klass)
|
||||||
{
|
{
|
||||||
GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
|
GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
|
||||||
GParamSpec *pspec;
|
|
||||||
|
|
||||||
gobject_class->set_property = maman_bar_set_property;
|
gobject_class->set_property = maman_bar_set_property;
|
||||||
gobject_class->get_property = maman_bar_get_property;
|
gobject_class->get_property = maman_bar_get_property;
|
||||||
|
|
||||||
pspec = g_param_spec_string ("maman-name",
|
obj_properties[PROP_NAME] =
|
||||||
"Maman construct prop",
|
g_param_spec_string ("maman-name",
|
||||||
"Set maman's name",
|
"Maman construct prop",
|
||||||
"no-name-set" /* default value */,
|
"Set maman's name",
|
||||||
G_PARAM_CONSTRUCT_ONLY | G_PARAM_READWRITE);
|
"no-name-set" /* default value */,
|
||||||
g_object_class_install_property (gobject_class,
|
G_PARAM_CONSTRUCT_ONLY | G_PARAM_READWRITE);
|
||||||
PROP_MAMAN_NAME,
|
|
||||||
pspec);
|
|
||||||
|
|
||||||
pspec = g_param_spec_uchar ("papa-number",
|
obj_properties[PROP_NUMBER] =
|
||||||
"Number of current Papa",
|
g_param_spec_uchar ("papa-number",
|
||||||
"Set/Get papa's number",
|
"Number of current Papa",
|
||||||
0 /* minimum value */,
|
"Set/Get papa's number",
|
||||||
10 /* maximum value */,
|
0 /* minimum value */,
|
||||||
2 /* default value */,
|
10 /* maximum value */,
|
||||||
G_PARAM_READWRITE);
|
2 /* default value */,
|
||||||
g_object_class_install_property (gobject_class,
|
G_PARAM_READWRITE);
|
||||||
PROP_PAPA_NUMBER,
|
|
||||||
pspec);
|
g_object_class_install_properties (gobject_class,
|
||||||
|
N_PROPERTIES,
|
||||||
|
obj_properties);
|
||||||
}
|
}
|
||||||
|
|
||||||
/************************************************/
|
/************************************************/
|
||||||
@ -613,7 +616,7 @@ g_value_set_char (&val, 11);
|
|||||||
g_object_set_property (G_OBJECT (bar), "papa-number", &val);
|
g_object_set_property (G_OBJECT (bar), "papa-number", &val);
|
||||||
|
|
||||||
g_value_unset (&val);
|
g_value_unset (&val);
|
||||||
</programlisting>
|
</programlisting></informalexample>
|
||||||
The client code just above looks simple but a lot of things happen under the hood:
|
The client code just above looks simple but a lot of things happen under the hood:
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
|
@ -341,26 +341,37 @@ maman_bar_init (MamanBar *self)
|
|||||||
<xref linkend="gobject-properties"/>. Make sure that these properties use a construct only
|
<xref linkend="gobject-properties"/>. Make sure that these properties use a construct only
|
||||||
<link linkend="GParamSpec"><type>GParamSpec</type></link> by setting the param spec's flag field to G_PARAM_CONSTRUCT_ONLY: this helps
|
<link linkend="GParamSpec"><type>GParamSpec</type></link> by setting the param spec's flag field to G_PARAM_CONSTRUCT_ONLY: this helps
|
||||||
GType ensure that these properties are not set again later by malicious user code.
|
GType ensure that these properties are not set again later by malicious user code.
|
||||||
<programlisting>
|
<informalexample><programlisting>
|
||||||
|
enum {
|
||||||
|
PROP_0,
|
||||||
|
|
||||||
|
PROP_MAMAN,
|
||||||
|
|
||||||
|
N_PROPERTIES
|
||||||
|
};
|
||||||
|
|
||||||
|
static GParamSpec *obj_properties[N_PROPERTIES] = { NULL, };
|
||||||
|
|
||||||
static void
|
static void
|
||||||
bar_class_init (MamanBarClass *klass)
|
bar_class_init (MamanBarClass *klass)
|
||||||
{
|
{
|
||||||
GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
|
GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
|
||||||
GParamSpec *pspec;
|
|
||||||
|
|
||||||
gobject_class->set_property = bar_set_property;
|
gobject_class->set_property = bar_set_property;
|
||||||
gobject_class->get_property = bar_get_property;
|
gobject_class->get_property = bar_get_property;
|
||||||
|
|
||||||
pspec = g_param_spec_string ("maman",
|
obj_properties[PROP_MAMAN] =
|
||||||
"Maman construct prop",
|
g_param_spec_string ("maman",
|
||||||
"Set maman's name",
|
"Maman construct prop",
|
||||||
"no-name-set" /* default value */,
|
"Set maman's name",
|
||||||
G_PARAM_CONSTRUCT_ONLY | G_PARAM_READWRITE);
|
"no-name-set" /* default value */,
|
||||||
g_object_class_install_property (gobject_class,
|
G_PARAM_CONSTRUCT_ONLY | G_PARAM_READWRITE);
|
||||||
PROP_MAMAN,
|
|
||||||
pspec);
|
g_object_class_install_properties (gobject_class,
|
||||||
|
N_PROPERTIES,
|
||||||
|
obj_properties);
|
||||||
}
|
}
|
||||||
</programlisting>
|
</programlisting></informalexample>
|
||||||
If you need this, make sure you can build and run code similar to the code shown above. Make sure
|
If you need this, make sure you can build and run code similar to the code shown above. Make sure
|
||||||
your construct properties can set correctly during construction, make sure you cannot set them
|
your construct properties can set correctly during construction, make sure you cannot set them
|
||||||
afterwards and make sure that if your users do not call <function><link linkend="g-object-new">g_object_new</link></function>
|
afterwards and make sure that if your users do not call <function><link linkend="g-object-new">g_object_new</link></function>
|
||||||
|
Loading…
Reference in New Issue
Block a user