diff options
author | Matthias Clasen <mclasen@redhat.com> | 2014-05-30 12:39:07 -0400 |
---|---|---|
committer | Matthias Clasen <mclasen@redhat.com> | 2014-05-30 12:39:07 -0400 |
commit | 6de6656d1f8d762093fe9d73f2713380573b9e39 (patch) | |
tree | b0fe43d3a390a229bbfd91386bf64d14315ca16d /gtk/gtkbuilder.c | |
parent | 1153ea86edc978423aa8b2fadfaef6a5e0c742ea (diff) | |
download | gtk+-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.c | 9 |
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 |