docs/gobject/tutorial: Use g_object_class_install_properties

This commit is contained in:
Javier Jardón 2011-12-06 23:15:58 +00:00
parent c3d6595f5a
commit 9e732ab0ea
2 changed files with 48 additions and 34 deletions

View File

@ -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-&gt;set_property = maman_bar_set_property; gobject_class-&gt;set_property = maman_bar_set_property;
gobject_class-&gt;get_property = maman_bar_get_property; gobject_class-&gt;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 (&amp;val, 11);
g_object_set_property (G_OBJECT (bar), "papa-number", &amp;val); g_object_set_property (G_OBJECT (bar), "papa-number", &amp;val);
g_value_unset (&amp;val); g_value_unset (&amp;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>

View File

@ -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>