stylecontext: Rebuild cached styles with correct classes/regions

Previously, we were using the default classes and regions. That's
obviously wrong.
This commit is contained in:
Benjamin Otte
2012-09-26 16:48:35 +02:00
parent 4ccf8609ab
commit fbb4c61665

View File

@ -934,19 +934,17 @@ gtk_style_context_impl_get_property (GObject *object,
}
static GtkWidgetPath *
create_query_path (GtkStyleContext *context)
create_query_path (GtkStyleContext *context,
GtkStyleInfo *info)
{
GtkStyleContextPrivate *priv;
GtkWidgetPath *path;
GtkStyleInfo *info;
guint i, pos;
priv = context->priv;
path = priv->widget ? _gtk_widget_create_path (priv->widget) : gtk_widget_path_copy (priv->widget_path);
pos = gtk_widget_path_length (path) - 1;
info = priv->info;
/* Set widget regions */
for (i = 0; i < info->regions->len; i++)
{
@ -974,7 +972,7 @@ create_query_path (GtkStyleContext *context)
static void
build_properties (GtkStyleContext *context,
GtkCssComputedValues *values,
GtkStateFlags state,
GtkStyleInfo *info,
const GtkBitmask *relevant_changes)
{
GtkStyleContextPrivate *priv;
@ -984,10 +982,10 @@ build_properties (GtkStyleContext *context,
priv = context->priv;
path = create_query_path (context);
path = create_query_path (context, info);
lookup = _gtk_css_lookup_new (relevant_changes);
if (_gtk_css_matcher_init (&matcher, path, state))
if (_gtk_css_matcher_init (&matcher, path, info->state_flags))
_gtk_style_provider_private_lookup (GTK_STYLE_PROVIDER_PRIVATE (priv->cascade),
&matcher,
lookup);
@ -1028,7 +1026,7 @@ style_data_lookup (GtkStyleContext *context)
style_info_copy (info),
data);
build_properties (context, data->store, info->state_flags, NULL);
build_properties (context, data->store, info, NULL);
return data;
}
@ -2998,7 +2996,7 @@ gtk_style_context_update_cache (GtkStyleContext *context,
if (_gtk_bitmask_get (changes, GTK_CSS_PROPERTY_FONT_SIZE))
changes = _gtk_bitmask_union (changes, data->store->depends_on_font_size);
build_properties (context, data->store, info->state_flags, changes);
build_properties (context, data->store, info, changes);
}
}
@ -3058,7 +3056,7 @@ gtk_style_context_needs_full_revalidate (GtkStyleContext *context,
GtkWidgetPath *path;
GtkCssMatcher matcher;
path = create_query_path (context);
path = create_query_path (context, priv->info);
if (_gtk_css_matcher_init (&matcher, path, priv->info->state_flags))
priv->relevant_changes = _gtk_style_provider_private_get_change (GTK_STYLE_PROVIDER_PRIVATE (priv->cascade),
&matcher);