mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-02 17:00:19 +00:00
stylecontext: Don't cache the root values
Those are the ones that are special and get animated. Caching them only causes confusion.
This commit is contained in:
parent
0d380f43d6
commit
c38095faed
@ -704,6 +704,17 @@ gtk_style_context_impl_get_property (GObject *object,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* returns TRUE if someone called gtk_style_context_save() but hasn’t
|
||||||
|
* called gtk_style_context_restore() yet.
|
||||||
|
* In those situations we don’t invalidate the context when somebody
|
||||||
|
* changes state/regions/classes.
|
||||||
|
*/
|
||||||
|
static gboolean
|
||||||
|
gtk_style_context_is_saved (GtkStyleContext *context)
|
||||||
|
{
|
||||||
|
return context->priv->info->next != NULL;
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
style_info_add_to_widget_path (GtkStyleInfo *info,
|
style_info_add_to_widget_path (GtkStyleInfo *info,
|
||||||
GtkWidgetPath *path,
|
GtkWidgetPath *path,
|
||||||
@ -810,13 +821,17 @@ style_values_lookup (GtkStyleContext *context)
|
|||||||
}
|
}
|
||||||
|
|
||||||
values = _gtk_css_computed_values_new ();
|
values = _gtk_css_computed_values_new ();
|
||||||
style_info_set_values (info, values);
|
|
||||||
g_hash_table_insert (priv->style_values,
|
|
||||||
style_info_copy (info),
|
|
||||||
values);
|
|
||||||
|
|
||||||
|
style_info_set_values (info, values);
|
||||||
|
if (gtk_style_context_is_saved (context))
|
||||||
|
g_hash_table_insert (priv->style_values,
|
||||||
|
style_info_copy (info),
|
||||||
|
g_object_ref (values));
|
||||||
|
|
||||||
build_properties (context, values, info, NULL);
|
build_properties (context, values, info, NULL);
|
||||||
|
|
||||||
|
g_object_unref (values);
|
||||||
|
|
||||||
return values;
|
return values;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -861,17 +876,6 @@ gtk_style_context_set_invalid (GtkStyleContext *context,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* returns TRUE if someone called gtk_style_context_save() but hasn’t
|
|
||||||
* called gtk_style_context_restore() yet.
|
|
||||||
* In those situations we don’t invalidate the context when somebody
|
|
||||||
* changes state/regions/classes.
|
|
||||||
*/
|
|
||||||
static gboolean
|
|
||||||
gtk_style_context_is_saved (GtkStyleContext *context)
|
|
||||||
{
|
|
||||||
return context->priv->info->next != NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gtk_style_context_queue_invalidate_internal (GtkStyleContext *context,
|
gtk_style_context_queue_invalidate_internal (GtkStyleContext *context,
|
||||||
GtkCssChange change)
|
GtkCssChange change)
|
||||||
@ -3080,10 +3084,6 @@ _gtk_style_context_validate (GtkStyleContext *context,
|
|||||||
if (current)
|
if (current)
|
||||||
{
|
{
|
||||||
changes = _gtk_css_computed_values_get_difference (values, current);
|
changes = _gtk_css_computed_values_get_difference (values, current);
|
||||||
|
|
||||||
/* In the case where we keep the cache, we want unanimated values */
|
|
||||||
if (values != current)
|
|
||||||
_gtk_css_computed_values_cancel_animations (current);
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -3094,6 +3094,8 @@ _gtk_style_context_validate (GtkStyleContext *context,
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
changes = _gtk_css_computed_values_compute_dependencies (current, parent_changes);
|
changes = _gtk_css_computed_values_compute_dependencies (current, parent_changes);
|
||||||
|
if (!_gtk_bitmask_is_empty (changes))
|
||||||
|
build_properties (context, current, info, changes);
|
||||||
|
|
||||||
gtk_style_context_update_cache (context, parent_changes);
|
gtk_style_context_update_cache (context, parent_changes);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user