From 138fd6f0f332207963acef2548e108d65f9b15df Mon Sep 17 00:00:00 2001 From: Matthias Clasen Date: Sun, 19 Sep 2021 22:30:34 -0400 Subject: [PATCH] builder: Small optimization Use g_object_setv where we can. It would be much nicer if we could pass the pspecs we already have, and avoid having GObject look them up again. --- gtk/gtkbuilder.c | 180 ++++++++++++++++++++++++++++------------------- 1 file changed, 106 insertions(+), 74 deletions(-) diff --git a/gtk/gtkbuilder.c b/gtk/gtkbuilder.c index 5487fa86db..b36b81e47e 100644 --- a/gtk/gtkbuilder.c +++ b/gtk/gtkbuilder.c @@ -459,7 +459,6 @@ typedef struct { GPtrArray *names; GArray *values; - guint len; } ObjectProperties; @@ -468,8 +467,6 @@ object_properties_init (ObjectProperties *self) { self->names = NULL; self->values = NULL; - - self->len = 0; } static void @@ -483,8 +480,6 @@ object_properties_destroy (ObjectProperties *self) if (self->values) g_array_unref (self->values); - - self->len = 0; } static void @@ -493,10 +488,8 @@ object_properties_add (ObjectProperties *self, const GValue *value) { if (!self->names) - self->names = g_ptr_array_sized_new (8); - - if (!self->values) { + self->names = g_ptr_array_sized_new (8); self->values = g_array_sized_new (FALSE, FALSE, sizeof (GValue), 8); g_array_set_clear_func (self->values, (GDestroyNotify) g_value_unset); } @@ -505,8 +498,6 @@ object_properties_add (ObjectProperties *self, g_array_append_vals (self->values, value, 1); g_assert (self->names->len == self->values->len); - - self->len += 1; } static const char * @@ -566,12 +557,12 @@ gtk_builder_get_parameters (GtkBuilder *builder, continue; } else if (G_IS_PARAM_SPEC_OBJECT (prop->pspec) && - (G_PARAM_SPEC_VALUE_TYPE (prop->pspec) != GDK_TYPE_PIXBUF) && - (G_PARAM_SPEC_VALUE_TYPE (prop->pspec) != GDK_TYPE_TEXTURE) && - (G_PARAM_SPEC_VALUE_TYPE (prop->pspec) != GDK_TYPE_PAINTABLE) && - (G_PARAM_SPEC_VALUE_TYPE (prop->pspec) != GTK_TYPE_SHORTCUT_TRIGGER) && - (G_PARAM_SPEC_VALUE_TYPE (prop->pspec) != GTK_TYPE_SHORTCUT_ACTION) && - (G_PARAM_SPEC_VALUE_TYPE (prop->pspec) != G_TYPE_FILE)) + (G_PARAM_SPEC_VALUE_TYPE (prop->pspec) != GDK_TYPE_PIXBUF) && + (G_PARAM_SPEC_VALUE_TYPE (prop->pspec) != GDK_TYPE_TEXTURE) && + (G_PARAM_SPEC_VALUE_TYPE (prop->pspec) != GDK_TYPE_PAINTABLE) && + (G_PARAM_SPEC_VALUE_TYPE (prop->pspec) != GTK_TYPE_SHORTCUT_TRIGGER) && + (G_PARAM_SPEC_VALUE_TYPE (prop->pspec) != GTK_TYPE_SHORTCUT_ACTION) && + (G_PARAM_SPEC_VALUE_TYPE (prop->pspec) != G_TYPE_FILE)) { GObject *object = g_hash_table_lookup (priv->objects, g_strstrip (prop->text->str)); @@ -751,9 +742,6 @@ _gtk_builder_construct (GtkBuilder *builder, ObjectProperties parameters, construct_parameters; GObject *obj; int i; - GtkBuildableIface *iface; - gboolean custom_set_property; - GtkBuildable *buildable; GParamFlags param_filter_flags; g_assert (info->type != G_TYPE_INVALID); @@ -821,7 +809,7 @@ _gtk_builder_construct (GtkBuilder *builder, builder, info->id); g_assert (obj != NULL); - if (construct_parameters.len > 0) + if (construct_parameters.names->len > 0) g_warning ("Can't pass in construct-only parameters to %s", info->id); } else if (info->parent && @@ -836,7 +824,7 @@ _gtk_builder_construct (GtkBuilder *builder, object_properties_destroy (&construct_parameters); return NULL; } - if (construct_parameters.len > 0) + if (construct_parameters.names) g_warning ("Can't pass in construct-only parameters to %s", childname); g_object_ref (obj); } @@ -844,9 +832,9 @@ _gtk_builder_construct (GtkBuilder *builder, { ensure_special_construct_parameters (builder, info->type, &construct_parameters); - if (construct_parameters.len > 0) + if (construct_parameters.names) obj = g_object_new_with_properties (info->type, - construct_parameters.len, + construct_parameters.names->len, (const char **) construct_parameters.names->pdata, (GValue *) construct_parameters.values->data); else @@ -869,36 +857,60 @@ _gtk_builder_construct (GtkBuilder *builder, } object_properties_destroy (&construct_parameters); - custom_set_property = FALSE; - buildable = NULL; - iface = NULL; - if (GTK_IS_BUILDABLE (obj)) + if (parameters.names) { - buildable = GTK_BUILDABLE (obj); - iface = GTK_BUILDABLE_GET_IFACE (obj); - if (iface->set_buildable_property) - custom_set_property = TRUE; - } + GtkBuildableIface *iface = NULL; + gboolean custom_set_property = FALSE; + GtkBuildable *buildable = NULL; - for (i = 0; i < parameters.len; i++) - { - const char *name = object_properties_get_name (¶meters, i); - const GValue *value = object_properties_get_value (¶meters, i); + if (GTK_IS_BUILDABLE (obj)) + { + buildable = GTK_BUILDABLE (obj); + iface = GTK_BUILDABLE_GET_IFACE (obj); + if (iface->set_buildable_property) + custom_set_property = TRUE; + } if (custom_set_property) - iface->set_buildable_property (buildable, builder, name, value); - else - g_object_set_property (obj, name, value); - -#ifdef G_ENABLE_DEBUG - if (GTK_DEBUG_CHECK (BUILDER)) { - char *str = g_strdup_value_contents (value); - g_message ("set %s: %s = %s", info->id, name, str); - g_free (str); - } + for (i = 0; i < parameters.names->len; i++) + { + const char *name = object_properties_get_name (¶meters, i); + const GValue *value = object_properties_get_value (¶meters, i); + + iface->set_buildable_property (buildable, builder, name, value); +#ifdef G_ENABLE_DEBUG + if (GTK_DEBUG_CHECK (BUILDER)) + { + char *str = g_strdup_value_contents (value); + g_message ("set %s: %s = %s", info->id, name, str); + g_free (str); + } #endif + } + } + else + { + g_object_setv (obj, + parameters.names->len, + (const char **) parameters.names->pdata, + (GValue *) parameters.values->data); +#ifdef G_ENABLE_DEBUG + if (GTK_DEBUG_CHECK (BUILDER)) + { + for (i = 0; i < parameters.names->len; i++) + { + const char *name = object_properties_get_name (¶meters, i); + const GValue *value = object_properties_get_value (¶meters, i); + char *str = g_strdup_value_contents (value); + g_message ("set %s: %s = %s", info->id, name, str); + g_free (str); + } + } +#endif + } } + object_properties_destroy (¶meters); if (info->bindings) @@ -919,10 +931,6 @@ _gtk_builder_apply_properties (GtkBuilder *builder, GError **error) { ObjectProperties parameters; - GtkBuildableIface *iface; - GtkBuildable *buildable; - gboolean custom_set_property; - int i; g_assert (info->object != NULL); g_assert (info->type != G_TYPE_INVALID); @@ -936,36 +944,60 @@ _gtk_builder_apply_properties (GtkBuilder *builder, G_PARAM_CONSTRUCT_ONLY, ¶meters, NULL); - - custom_set_property = FALSE; - buildable = NULL; - iface = NULL; - if (GTK_IS_BUILDABLE (info->object)) + if (parameters.names) { - buildable = GTK_BUILDABLE (info->object); - iface = GTK_BUILDABLE_GET_IFACE (info->object); - if (iface->set_buildable_property) - custom_set_property = TRUE; - } + GtkBuildableIface *iface = NULL; + GtkBuildable *buildable = NULL; + gboolean custom_set_property = FALSE; + int i; - for (i = 0; i < parameters.len; i++) - { - const char *name = object_properties_get_name (¶meters, i); - const GValue *value = object_properties_get_value (¶meters, i); - if (custom_set_property) - iface->set_buildable_property (buildable, builder, name, value); - else - g_object_set_property (info->object, name, value); - -#ifdef G_ENABLE_DEBUG - if (GTK_DEBUG_CHECK (BUILDER)) + if (GTK_IS_BUILDABLE (info->object)) { - char *str = g_strdup_value_contents (value); - g_message ("set %s: %s = %s", info->id, name, str); - g_free (str); + buildable = GTK_BUILDABLE (info->object); + iface = GTK_BUILDABLE_GET_IFACE (info->object); + if (iface->set_buildable_property) + custom_set_property = TRUE; } + + if (custom_set_property) + { + for (i = 0; i < parameters.names->len; i++) + { + const char *name = object_properties_get_name (¶meters, i); + const GValue *value = object_properties_get_value (¶meters, i); + iface->set_buildable_property (buildable, builder, name, value); +#ifdef G_ENABLE_DEBUG + if (GTK_DEBUG_CHECK (BUILDER)) + { + char *str = g_strdup_value_contents (value); + g_message ("set %s: %s = %s", info->id, name, str); + g_free (str); + } #endif + } + } + else + { + g_object_setv (info->object, + parameters.names->len, + (const char **) parameters.names->pdata, + (GValue *) parameters.values->data); +#ifdef G_ENABLE_DEBUG + if (GTK_DEBUG_CHECK (BUILDER)) + { + for (i = 0; i < parameters.names->len; i++) + { + const char *name = object_properties_get_name (¶meters, i); + const GValue *value = object_properties_get_value (¶meters, i); + char *str = g_strdup_value_contents (value); + g_message ("set %s: %s = %s", info->id, name, str); + g_free (str); + } + } +#endif + } } + object_properties_destroy (¶meters); }