diff options
author | Benjamin Otte <otte@redhat.com> | 2011-12-29 02:28:32 +0100 |
---|---|---|
committer | Benjamin Otte <otte@redhat.com> | 2012-01-09 18:37:50 +0100 |
commit | aa4925480dc783faddca9adf9d0f4d6bd96c066e (patch) | |
tree | aa27c8f7d7799cc31b062d5988a37c2f65037f75 /gtk/gtkstyleproperty.c | |
parent | 4d15186e6756e8e757bc30686e7a02433e0291f7 (diff) | |
download | gtk+-aa4925480dc783faddca9adf9d0f4d6bd96c066e.tar.gz |
styleproperty: Pass initial value explicitly
Diffstat (limited to 'gtk/gtkstyleproperty.c')
-rw-r--r-- | gtk/gtkstyleproperty.c | 145 |
1 files changed, 86 insertions, 59 deletions
diff --git a/gtk/gtkstyleproperty.c b/gtk/gtkstyleproperty.c index fee3bba0e4..518a0e42c3 100644 --- a/gtk/gtkstyleproperty.c +++ b/gtk/gtkstyleproperty.c @@ -2211,34 +2211,6 @@ unset_border_image (GtkStyleProperties *props, gtk_style_properties_unset_property (props, "border-image-width", state); } -/*** default values ***/ - -static void -border_image_width_default_value (GtkStyleProperties *props, - GtkStateFlags state, - GValue *value) -{ -} - -static void -background_color_default_value (GtkStyleProperties *props, - GtkStateFlags state, - GValue *value) -{ - GdkRGBA transparent_black = { 0, 0, 0, 0 }; - - g_value_set_boxed (value, &transparent_black); -} - -static void -border_color_default_value (GtkStyleProperties *props, - GtkStateFlags state, - GValue *value) -{ - g_value_unset (value); - gtk_style_properties_get_property (props, "color", state, value); -} - /*** API ***/ guint @@ -2440,24 +2412,7 @@ _gtk_style_property_default_value (const GtkStyleProperty *property, GtkStateFlags state, GValue *value) { - if (property->default_value_func) - property->default_value_func (properties, state, value); - else if (property->pspec->value_type == GTK_TYPE_THEMING_ENGINE) - g_value_set_object (value, gtk_theming_engine_load (NULL)); - else if (property->pspec->value_type == PANGO_TYPE_FONT_DESCRIPTION) - g_value_take_boxed (value, pango_font_description_from_string ("Sans 10")); - else if (property->pspec->value_type == GDK_TYPE_RGBA) - { - GdkRGBA color; - gdk_rgba_parse (&color, "pink"); - g_value_set_boxed (value, &color); - } - else if (property->pspec->value_type == GTK_TYPE_BORDER) - { - g_value_take_boxed (value, gtk_border_new ()); - } - else - g_param_value_set_default (property->pspec, value); + g_value_copy (&property->initial_value, value); } gboolean @@ -2584,7 +2539,24 @@ _gtk_style_property_resolve (const GtkStyleProperty *property, GValue *val, GValue *val_out) { - if (G_VALUE_TYPE (val) == GTK_TYPE_SYMBOLIC_COLOR) + if (G_VALUE_TYPE (val) == GTK_TYPE_CSS_SPECIAL_VALUE) + { + GtkCssSpecialValue special = g_value_get_enum (val); + + g_value_unset (val); + switch (special) + { + case GTK_CSS_CURRENT_COLOR: + g_assert (property->pspec->value_type == GDK_TYPE_RGBA); + gtk_style_properties_get_property (props, "color", state, val); + break; + case GTK_CSS_INHERIT: + case GTK_CSS_INITIAL: + default: + g_assert_not_reached (); + } + } + else if (G_VALUE_TYPE (val) == GTK_TYPE_SYMBOLIC_COLOR) { if (property->pspec->value_type == GDK_TYPE_RGBA) { @@ -2669,9 +2641,19 @@ _gtk_style_property_pack (const GtkStyleProperty *property, property->pack_func (value, props, state, context); } +#define rgba_init(rgba, r, g, b, a) G_STMT_START{ \ + (rgba)->red = (r); \ + (rgba)->green = (g); \ + (rgba)->blue = (b); \ + (rgba)->alpha = (a); \ +}G_STMT_END static void gtk_style_property_init (void) { + GValue value = { 0, }; + char *default_font_family[] = { "Sans", NULL }; + GdkRGBA rgba; + if (G_LIKELY (properties)) return; @@ -2681,6 +2663,9 @@ gtk_style_property_init (void) /* note that gtk_style_properties_register_property() calls this function, * so make sure we're sanely inited to avoid infloops */ + g_value_init (&value, GDK_TYPE_RGBA); + rgba_init (&rgba, 1, 1, 1, 1); + g_value_set_boxed (&value, &rgba); _gtk_style_property_register (g_param_spec_boxed ("color", "Foreground color", "Foreground color", @@ -2691,8 +2676,10 @@ gtk_style_property_init (void) NULL, NULL, NULL, - NULL, + &value, NULL); + rgba_init (&rgba, 0, 0, 0, 0); + g_value_set_boxed (&value, &rgba); _gtk_style_property_register (g_param_spec_boxed ("background-color", "Background color", "Background color", @@ -2703,9 +2690,12 @@ gtk_style_property_init (void) NULL, transparent_color_value_parse, NULL, - background_color_default_value, + &value, NULL); + g_value_unset (&value); + g_value_init (&value, G_TYPE_STRV); + g_value_set_boxed (&value, default_font_family); _gtk_style_property_register (g_param_spec_boxed ("font-family", "Font family", "Font family", @@ -2716,8 +2706,9 @@ gtk_style_property_init (void) NULL, font_family_parse, font_family_value_print, - NULL, + &value, NULL); + g_value_unset (&value); _gtk_style_property_register (g_param_spec_enum ("font-style", "Font style", "Font style", @@ -2758,6 +2749,8 @@ gtk_style_property_init (void) NULL, NULL, NULL); + g_value_init (&value, G_TYPE_DOUBLE); + g_value_set_double (&value, 10); _gtk_style_property_register (g_param_spec_double ("font-size", "Font size", "Font size", @@ -2768,8 +2761,9 @@ gtk_style_property_init (void) NULL, NULL, NULL, - NULL, + &value, NULL); + g_value_unset (&value); _gtk_style_property_register (g_param_spec_boxed ("font", "Font Description", "Font Description", @@ -2990,6 +2984,8 @@ gtk_style_property_init (void) "Background origin", GTK_TYPE_CSS_AREA, GTK_CSS_AREA_PADDING_BOX, 0)); + g_value_init (&value, GTK_TYPE_CSS_SPECIAL_VALUE); + g_value_set_enum (&value, GTK_CSS_CURRENT_COLOR); _gtk_style_property_register (g_param_spec_boxed ("border-top-color", "Border top color", "Border top color", @@ -3000,7 +2996,7 @@ gtk_style_property_init (void) NULL, transparent_color_value_parse, NULL, - border_color_default_value, + &value, NULL); _gtk_style_property_register (g_param_spec_boxed ("border-right-color", "Border right color", @@ -3012,7 +3008,7 @@ gtk_style_property_init (void) NULL, transparent_color_value_parse, NULL, - border_color_default_value, + &value, NULL); _gtk_style_property_register (g_param_spec_boxed ("border-bottom-color", "Border bottom color", @@ -3024,7 +3020,7 @@ gtk_style_property_init (void) NULL, transparent_color_value_parse, NULL, - border_color_default_value, + &value, NULL); _gtk_style_property_register (g_param_spec_boxed ("border-left-color", "Border left color", @@ -3036,8 +3032,9 @@ gtk_style_property_init (void) NULL, transparent_color_value_parse, NULL, - border_color_default_value, + &value, NULL); + g_value_unset (&value); _gtk_style_property_register (g_param_spec_boxed ("border-color", "Border color", "Border color", @@ -3077,6 +3074,7 @@ gtk_style_property_init (void) "Border image slice", "Border image slice", GTK_TYPE_BORDER, 0)); + g_value_init (&value, GTK_TYPE_BORDER); _gtk_style_property_register (g_param_spec_boxed ("border-image-width", "Border image width", "Border image width", @@ -3087,8 +3085,9 @@ gtk_style_property_init (void) NULL, NULL, NULL, - border_image_width_default_value, + &value, NULL); + g_value_unset (&value); _gtk_style_property_register (g_param_spec_boxed ("border-image", "Border Image", "Border Image", @@ -3143,7 +3142,7 @@ _gtk_style_property_register (GParamSpec *pspec, GtkStylePackFunc pack_func, GtkStyleParseFunc parse_func, GtkStylePrintFunc print_func, - GtkStyleDefaultValueFunc default_value_func, + const GValue * initial_value, GtkStyleUnsetFunc unset_func) { const GtkStyleProperty *existing; @@ -3169,11 +3168,39 @@ _gtk_style_property_register (GParamSpec *pspec, node->unpack_func = unpack_func; node->parse_func = parse_func; node->print_func = print_func; - node->default_value_func = default_value_func; node->unset_func = unset_func; if (!_gtk_style_property_is_shorthand (node)) - _gtk_style_property_generate_id (node); + { + _gtk_style_property_generate_id (node); + + /* initialize the initial value */ + if (initial_value) + { + g_value_init (&node->initial_value, G_VALUE_TYPE (initial_value)); + g_value_copy (initial_value, &node->initial_value); + } + else + { + g_value_init (&node->initial_value, pspec->value_type); + if (pspec->value_type == GTK_TYPE_THEMING_ENGINE) + g_value_set_object (&node->initial_value, gtk_theming_engine_load (NULL)); + else if (pspec->value_type == PANGO_TYPE_FONT_DESCRIPTION) + g_value_take_boxed (&node->initial_value, pango_font_description_from_string ("Sans 10")); + else if (pspec->value_type == GDK_TYPE_RGBA) + { + GdkRGBA color; + gdk_rgba_parse (&color, "pink"); + g_value_set_boxed (&node->initial_value, &color); + } + else if (pspec->value_type == GTK_TYPE_BORDER) + { + g_value_take_boxed (&node->initial_value, gtk_border_new ()); + } + else + g_param_value_set_default (pspec, &node->initial_value); + } + } /* pspec owns name */ g_hash_table_insert (properties, (gchar *)pspec->name, node); |