summaryrefslogtreecommitdiff
path: root/gtk/gtkbuilder.c
diff options
context:
space:
mode:
authorMatthias Clasen <mclasen@redhat.com>2014-05-30 12:39:07 -0400
committerMatthias Clasen <mclasen@redhat.com>2014-05-30 12:39:07 -0400
commit6de6656d1f8d762093fe9d73f2713380573b9e39 (patch)
treeb0fe43d3a390a229bbfd91386bf64d14315ca16d /gtk/gtkbuilder.c
parent1153ea86edc978423aa8b2fadfaef6a5e0c742ea (diff)
downloadgtk+-6de6656d1f8d762093fe9d73f2713380573b9e39.tar.gz
GtkBuilder: Ensure types are fully initialized
Just calling get_type() does not ensure that the signals, properties and everything else gets set up properly. Ensure it is, by calling g_type_class_ref() before using the type. This fixes the testcase added in the previous commit.
Diffstat (limited to 'gtk/gtkbuilder.c')
-rw-r--r--gtk/gtkbuilder.c9
1 files changed, 8 insertions, 1 deletions
diff --git a/gtk/gtkbuilder.c b/gtk/gtkbuilder.c
index f6e5c52e4f..60927df10e 100644
--- a/gtk/gtkbuilder.c
+++ b/gtk/gtkbuilder.c
@@ -2275,10 +2275,17 @@ GType
gtk_builder_get_type_from_name (GtkBuilder *builder,
const gchar *type_name)
{
+ GType type;
+
g_return_val_if_fail (GTK_IS_BUILDER (builder), G_TYPE_INVALID);
g_return_val_if_fail (type_name != NULL, G_TYPE_INVALID);
- return GTK_BUILDER_GET_CLASS (builder)->get_type_from_name (builder, type_name);
+ type = GTK_BUILDER_GET_CLASS (builder)->get_type_from_name (builder, type_name);
+
+ if (G_TYPE_IS_CLASSED (type))
+ g_type_class_unref (g_type_class_ref (type));
+
+ return type;
}
GQuark