stylecontext: Always pass the static style

... to build_properties.
There is always one available, so we can insist on that one.

This simplifies a bunch of code.
This commit is contained in:
Benjamin Otte
2014-10-27 00:25:18 +01:00
parent c7e9489e3e
commit 270e73bfcc
5 changed files with 15 additions and 54 deletions

View File

@ -126,24 +126,6 @@ gtk_css_animated_style_new (void)
return g_object_new (GTK_TYPE_CSS_ANIMATED_STYLE, NULL); return g_object_new (GTK_TYPE_CSS_ANIMATED_STYLE, NULL);
} }
void
gtk_css_animated_style_compute_value (GtkCssAnimatedStyle *style,
GtkStyleProviderPrivate *provider,
int scale,
GtkCssStyle *parent_style,
guint id,
GtkCssValue *specified,
GtkCssSection *section)
{
gtk_internal_return_if_fail (GTK_IS_CSS_ANIMATED_STYLE (style));
gtk_internal_return_if_fail (GTK_IS_STYLE_PROVIDER_PRIVATE (provider));
gtk_internal_return_if_fail (parent_style == NULL || GTK_IS_CSS_STYLE (parent_style));
gtk_css_static_style_compute_value (GTK_CSS_STATIC_STYLE (style->style),
provider, scale, parent_style,
id, specified, section);
}
void void
gtk_css_animated_style_set_animated_value (GtkCssAnimatedStyle *style, gtk_css_animated_style_set_animated_value (GtkCssAnimatedStyle *style,
guint id, guint id,

View File

@ -54,13 +54,6 @@ GType gtk_css_animated_style_get_type (void) G_GNUC_CO
GtkCssStyle * gtk_css_animated_style_new (void); GtkCssStyle * gtk_css_animated_style_new (void);
void gtk_css_animated_style_compute_value (GtkCssAnimatedStyle *style,
GtkStyleProviderPrivate*provider,
int scale,
GtkCssStyle *parent_style,
guint id,
GtkCssValue *specified,
GtkCssSection *section);
void gtk_css_animated_style_set_animated_value(GtkCssAnimatedStyle *style, void gtk_css_animated_style_set_animated_value(GtkCssAnimatedStyle *style,
guint id, guint id,
GtkCssValue *value); GtkCssValue *value);

View File

@ -19,8 +19,6 @@
#include "gtkcsslookupprivate.h" #include "gtkcsslookupprivate.h"
#include "gtkcssanimatedstyleprivate.h"
#include "gtkcssstaticstyleprivate.h"
#include "gtkcssstylepropertyprivate.h" #include "gtkcssstylepropertyprivate.h"
#include "gtkcsstypesprivate.h" #include "gtkcsstypesprivate.h"
#include "gtkprivatetypebuiltins.h" #include "gtkprivatetypebuiltins.h"
@ -108,14 +106,14 @@ void
_gtk_css_lookup_resolve (GtkCssLookup *lookup, _gtk_css_lookup_resolve (GtkCssLookup *lookup,
GtkStyleProviderPrivate *provider, GtkStyleProviderPrivate *provider,
int scale, int scale,
GtkCssStyle *style, GtkCssStaticStyle *style,
GtkCssStyle *parent_style) GtkCssStyle *parent_style)
{ {
guint i, n; guint i, n;
g_return_if_fail (lookup != NULL); g_return_if_fail (lookup != NULL);
g_return_if_fail (GTK_IS_STYLE_PROVIDER_PRIVATE (provider)); g_return_if_fail (GTK_IS_STYLE_PROVIDER_PRIVATE (provider));
g_return_if_fail (GTK_IS_CSS_STYLE (style)); g_return_if_fail (GTK_IS_CSS_STATIC_STYLE (style));
g_return_if_fail (parent_style == NULL || GTK_IS_CSS_STYLE (parent_style)); g_return_if_fail (parent_style == NULL || GTK_IS_CSS_STYLE (parent_style));
n = _gtk_css_style_property_get_n_properties (); n = _gtk_css_style_property_get_n_properties ();
@ -124,24 +122,13 @@ _gtk_css_lookup_resolve (GtkCssLookup *lookup,
{ {
if (lookup->values[i].value || if (lookup->values[i].value ||
_gtk_bitmask_get (lookup->missing, i)) _gtk_bitmask_get (lookup->missing, i))
{ gtk_css_static_style_compute_value (GTK_CSS_STATIC_STYLE (style),
if (GTK_IS_CSS_ANIMATED_STYLE (style)) provider,
gtk_css_animated_style_compute_value (GTK_CSS_ANIMATED_STYLE (style), scale,
provider, parent_style,
scale, i,
parent_style, lookup->values[i].value,
i, lookup->values[i].section);
lookup->values[i].value,
lookup->values[i].section);
else
gtk_css_static_style_compute_value (GTK_CSS_STATIC_STYLE (style),
provider,
scale,
parent_style,
i,
lookup->values[i].value,
lookup->values[i].section);
}
/* else not a relevant property */ /* else not a relevant property */
} }
} }

View File

@ -20,7 +20,7 @@
#include <glib-object.h> #include <glib-object.h>
#include "gtk/gtkbitmaskprivate.h" #include "gtk/gtkbitmaskprivate.h"
#include "gtk/gtkcssstyleprivate.h" #include "gtk/gtkcssstaticstyleprivate.h"
#include "gtk/gtkcsssection.h" #include "gtk/gtkcsssection.h"
@ -51,7 +51,7 @@ void _gtk_css_lookup_set (GtkCssLookup
void _gtk_css_lookup_resolve (GtkCssLookup *lookup, void _gtk_css_lookup_resolve (GtkCssLookup *lookup,
GtkStyleProviderPrivate *provider, GtkStyleProviderPrivate *provider,
int scale, int scale,
GtkCssStyle *style, GtkCssStaticStyle *style,
GtkCssStyle *parent_style); GtkCssStyle *parent_style);
static inline const GtkBitmask * static inline const GtkBitmask *

View File

@ -706,7 +706,7 @@ build_properties (GtkStyleContext *context,
_gtk_css_lookup_resolve (lookup, _gtk_css_lookup_resolve (lookup,
GTK_STYLE_PROVIDER_PRIVATE (priv->cascade), GTK_STYLE_PROVIDER_PRIVATE (priv->cascade),
priv->scale, priv->scale,
style, GTK_CSS_STATIC_STYLE (style),
priv->parent ? style_values_lookup (priv->parent) : NULL); priv->parent ? style_values_lookup (priv->parent) : NULL);
_gtk_css_lookup_free (lookup); _gtk_css_lookup_free (lookup);
@ -739,19 +739,18 @@ style_values_lookup (GtkStyleContext *context)
if (gtk_style_context_is_saved (context)) if (gtk_style_context_is_saved (context))
{ {
<<<<<<< HEAD
values = gtk_css_static_style_new (); values = gtk_css_static_style_new ();
g_hash_table_insert (priv->style_values, g_hash_table_insert (priv->style_values,
gtk_css_node_declaration_ref (info->decl), gtk_css_node_declaration_ref (info->decl),
g_object_ref (values)); g_object_ref (values));
build_properties (context, values, info->decl, NULL, NULL); build_properties (context, values, info->decl, NULL, NULL);
} }
else else
{ {
values = gtk_css_animated_style_new (); values = gtk_css_animated_style_new ();
build_properties (context, values, info->decl, NULL, &priv->relevant_changes); build_properties (context, GTK_CSS_ANIMATED_STYLE (values)->style, info->decl, NULL, &priv->relevant_changes);
/* These flags are always relevant */ /* These flags are always relevant */
priv->relevant_changes |= GTK_CSS_CHANGE_SOURCE; priv->relevant_changes |= GTK_CSS_CHANGE_SOURCE;
} }
@ -2838,7 +2837,7 @@ _gtk_style_context_validate (GtkStyleContext *context,
{ {
changes = gtk_css_style_compute_dependencies (current, parent_changes); changes = gtk_css_style_compute_dependencies (current, parent_changes);
if (!_gtk_bitmask_is_empty (changes)) if (!_gtk_bitmask_is_empty (changes))
build_properties (context, current, info->decl, changes, NULL); build_properties (context, GTK_CSS_ANIMATED_STYLE (current)->style, info->decl, changes, NULL);
gtk_style_context_update_cache (context, parent_changes); gtk_style_context_update_cache (context, parent_changes);
} }