Fix crash with theme resource file

The freeing the GResource in gtk_css_provider_reset caused problems
because it was called from gtk_css_provider_load_from_path() inside
gtk_css_provider_get_named(). We fix this by delaying the
setting of priv->resource until we successfully loaded the file.
This commit is contained in:
Alexander Larsson 2012-02-03 16:37:54 +01:00
parent 6b2f10321f
commit fb0c53a0ed

View File

@ -2925,18 +2925,24 @@ gtk_css_provider_get_named (const gchar *name,
resource_file = g_build_filename (dir, "gtk.gresource", NULL);
resource = g_resource_load (resource_file, NULL);
if (resource != NULL)
{
provider->priv->resource = resource;
g_resources_register (resource);
}
g_resources_register (resource);
if (!gtk_css_provider_load_from_path (provider, path, NULL))
{
if (resource != NULL)
{
g_resources_unregister (resource);
g_resource_unref (resource);
}
g_object_unref (provider);
provider = NULL;
}
else
g_hash_table_insert (themes, g_strdup (key), provider);
{
/* Only set this after load success, as load_from_path will clear it */
provider->priv->resource = resource;
g_hash_table_insert (themes, g_strdup (key), provider);
}
g_free (path);
}