From 8f9c5090db695c1b83e90bdcf86013d8a30b5b81 Mon Sep 17 00:00:00 2001 From: Philip Withnall Date: Fri, 20 May 2022 12:55:18 +0100 Subject: [PATCH 1/2] docs: Use G_PARAM_STATIC_STRINGS in examples and explain it more Make it a bit clearer in the documentation that using `G_PARAM_STATIC_STRINGS` everywhere is a good thing. Signed-off-by: Philip Withnall --- docs/reference/gobject/tut_gobject.xml | 4 ++-- docs/reference/gobject/tut_howto.xml | 2 +- gobject/glib-types.h | 2 +- gobject/gobject.c | 6 +++--- gobject/gparam.h | 6 ++++++ 5 files changed, 13 insertions(+), 7 deletions(-) diff --git a/docs/reference/gobject/tut_gobject.xml b/docs/reference/gobject/tut_gobject.xml index 0423a38a3..7a2ecc77e 100644 --- a/docs/reference/gobject/tut_gobject.xml +++ b/docs/reference/gobject/tut_gobject.xml @@ -555,7 +555,7 @@ viewer_file_class_init (ViewerFileClass *klass) "Filename", "Name of the file to load and display from.", NULL /* default value */, - G_PARAM_CONSTRUCT_ONLY | G_PARAM_READWRITE); + G_PARAM_CONSTRUCT_ONLY | G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS); obj_properties[PROP_ZOOM_LEVEL] = g_param_spec_uint ("zoom-level", @@ -564,7 +564,7 @@ viewer_file_class_init (ViewerFileClass *klass) 0 /* minimum value */, 10 /* maximum value */, 2 /* default value */, - G_PARAM_READWRITE); + G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS); g_object_class_install_properties (object_class, N_PROPERTIES, diff --git a/docs/reference/gobject/tut_howto.xml b/docs/reference/gobject/tut_howto.xml index b61a328b6..4ed178cec 100644 --- a/docs/reference/gobject/tut_howto.xml +++ b/docs/reference/gobject/tut_howto.xml @@ -1226,7 +1226,7 @@ viewer_editable_default_init (ViewerEditableInterface *iface) 0.0, /* minimum */ G_MAXDOUBLE, /* maximum */ 0.0, /* default */ - G_PARAM_READWRITE)); + G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS)); } diff --git a/gobject/glib-types.h b/gobject/glib-types.h index f0d33234a..c54eda99c 100644 --- a/gobject/glib-types.h +++ b/gobject/glib-types.h @@ -54,7 +54,7 @@ typedef gsize GType; * _("Authors"), * _("List of authors"), * G_TYPE_STRV, - * G_PARAM_READWRITE)); + * G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS)); * * gchar *authors[] = { "Owen", "Tim", NULL }; * g_object_set (obj, "authors", authors, NULL); diff --git a/gobject/gobject.c b/gobject/gobject.c index d33d8e5b0..caee34f4e 100644 --- a/gobject/gobject.c +++ b/gobject/gobject.c @@ -722,12 +722,12 @@ g_object_class_install_property (GObjectClass *class, * g_param_spec_int ("foo", "Foo", "Foo", * -1, G_MAXINT, * 0, - * G_PARAM_READWRITE); + * G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS); * * obj_properties[PROP_BAR] = * g_param_spec_string ("bar", "Bar", "Bar", * NULL, - * G_PARAM_READWRITE); + * G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS); * * gobject_class->set_property = my_object_set_property; * gobject_class->get_property = my_object_get_property; @@ -1421,7 +1421,7 @@ g_object_notify (GObject *object, * properties[PROP_FOO] = g_param_spec_int ("foo", "Foo", "The foo", * 0, 100, * 50, - * G_PARAM_READWRITE); + * G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS); * g_object_class_install_property (gobject_class, * PROP_FOO, * properties[PROP_FOO]); diff --git a/gobject/gparam.h b/gobject/gparam.h index e0f316682..4dff763e5 100644 --- a/gobject/gparam.h +++ b/gobject/gparam.h @@ -172,6 +172,12 @@ typedef enum * * #GParamFlags value alias for %G_PARAM_STATIC_NAME | %G_PARAM_STATIC_NICK | %G_PARAM_STATIC_BLURB. * + * It is recommended to use this for all properties by default, as it allows for + * internal performance improvements in GObject. + * + * It is very rare that a property would have a dynamically constructed name, + * nickname or blurb. + * * Since 2.13.0 */ #define G_PARAM_STATIC_STRINGS (G_PARAM_STATIC_NAME | G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB) From 3c14b6846d5ea9fb2b4e07fc0a8c4587d9fc2b68 Mon Sep 17 00:00:00 2001 From: Philip Withnall Date: Fri, 20 May 2022 12:56:03 +0100 Subject: [PATCH 2/2] docs: Standardise property ID enums in examples MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Drop the redundant `PROP_0` (which isn’t a real property) and initialise the first member of the enum instead. Add a typedef so that the enum type can be used in `switch` statements in `get_property()` and `set_property()` vfuncs. This allows `-Wswitch-enum` to be used to improve type safety. The examples here don’t have `get_property()` or `set_property()` vfuncs, but people might copy/paste the code to somewhere which does. Signed-off-by: Philip Withnall --- gobject/gobject.c | 17 +++++++++-------- 1 file changed, 9 insertions(+), 8 deletions(-) diff --git a/gobject/gobject.c b/gobject/gobject.c index caee34f4e..a7a1d3032 100644 --- a/gobject/gobject.c +++ b/gobject/gobject.c @@ -707,9 +707,11 @@ g_object_class_install_property (GObjectClass *class, * class initialization: * * |[ - * enum { - * PROP_0, PROP_FOO, PROP_BAR, N_PROPERTIES - * }; + * typedef enum { + * PROP_FOO = 1, + * PROP_BAR, + * N_PROPERTIES + * } MyObjectProperty; * * static GParamSpec *obj_properties[N_PROPERTIES] = { NULL, }; * @@ -732,7 +734,7 @@ g_object_class_install_property (GObjectClass *class, * gobject_class->set_property = my_object_set_property; * gobject_class->get_property = my_object_get_property; * g_object_class_install_properties (gobject_class, - * N_PROPERTIES, + * G_N_ELEMENTS (obj_properties), * obj_properties); * } * ]| @@ -1406,12 +1408,11 @@ g_object_notify (GObject *object, * g_object_class_install_property() inside a static array, e.g.: * *|[ - * enum + * typedef enum * { - * PROP_0, - * PROP_FOO, + * PROP_FOO = 1, * PROP_LAST - * }; + * } MyObjectProperty; * * static GParamSpec *properties[PROP_LAST]; *