[gtk+/wip/css] styleproperty: Move parse/print vfuncs to GtkCssStyleProperty
- From: Benjamin Otte <otte src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/wip/css] styleproperty: Move parse/print vfuncs to GtkCssStyleProperty
- Date: Tue, 3 Jan 2012 02:23:30 +0000 (UTC)
commit 93e24c2f043532ba7494a3ea04c7b68e950c2a68
Author: Benjamin Otte <otte redhat com>
Date: Mon Jan 2 18:05:06 2012 +0100
styleproperty: Move parse/print vfuncs to GtkCssStyleProperty
gtk/gtkcssstyleproperty.c | 39 ++++++++++++++------
gtk/gtkcssstylepropertyimpl.c | 71 +++++++++++++++++++++----------------
gtk/gtkcssstylepropertyprivate.h | 9 +++++
gtk/gtkstylepropertyprivate.h | 7 ----
4 files changed, 76 insertions(+), 50 deletions(-)
---
diff --git a/gtk/gtkcssstyleproperty.c b/gtk/gtkcssstyleproperty.c
index e358077..03418dd 100644
--- a/gtk/gtkcssstyleproperty.c
+++ b/gtk/gtkcssstyleproperty.c
@@ -143,7 +143,7 @@ gtk_css_style_property_parse_value (GtkStyleProperty *property,
GtkCssParser *parser,
GFile *base)
{
- gboolean success;
+ GtkCssStyleProperty *style_property = GTK_CSS_STYLE_PROPERTY (property);
if (_gtk_css_parser_try (parser, "initial", TRUE))
{
@@ -168,15 +168,13 @@ gtk_css_style_property_parse_value (GtkStyleProperty *property,
}
g_value_init (value, _gtk_style_property_get_value_type (property));
- if (property->parse_func)
- success = (* property->parse_func) (parser, base, value);
- else
- success = _gtk_css_style_parse_value (value, parser, base);
-
- if (!success)
- g_value_unset (value);
+ if (!(* style_property->parse_value) (style_property, value, parser, base))
+ {
+ g_value_unset (value);
+ return FALSE;
+ }
- return success;
+ return TRUE;
}
static void
@@ -218,6 +216,23 @@ _gtk_css_style_property_class_init (GtkCssStylePropertyClass *klass)
klass->style_properties = g_ptr_array_new ();
}
+static gboolean
+gtk_css_style_property_real_parse_value (GtkCssStyleProperty *property,
+ GValue *value,
+ GtkCssParser *parser,
+ GFile *base)
+{
+ return _gtk_css_style_parse_value (value, parser, base);
+}
+
+static void
+gtk_css_style_property_real_print_value (GtkCssStyleProperty *property,
+ const GValue *value,
+ GString *string)
+{
+ _gtk_css_style_print_value (value, string);
+}
+
static void
gtk_css_style_property_real_compute_value (GtkCssStyleProperty *property,
GValue *computed,
@@ -231,6 +246,8 @@ gtk_css_style_property_real_compute_value (GtkCssStyleProperty *property,
static void
_gtk_css_style_property_init (GtkCssStyleProperty *property)
{
+ property->parse_value = gtk_css_style_property_real_parse_value;
+ property->print_value = gtk_css_style_property_real_print_value;
property->compute_value = gtk_css_style_property_real_compute_value;
}
@@ -382,9 +399,7 @@ _gtk_css_style_property_print_value (GtkCssStyleProperty *property,
g_type_class_unref (enum_class);
}
- else if (GTK_STYLE_PROPERTY (property)->print_func)
- (* GTK_STYLE_PROPERTY (property)->print_func) (value, string);
else
- _gtk_css_style_print_value (value, string);
+ property->print_value (property, value, string);
}
diff --git a/gtk/gtkcssstylepropertyimpl.c b/gtk/gtkcssstylepropertyimpl.c
index 9f520cb..6a59299 100644
--- a/gtk/gtkcssstylepropertyimpl.c
+++ b/gtk/gtkcssstylepropertyimpl.c
@@ -45,14 +45,14 @@
/*** REGISTRATION ***/
static void
-_gtk_style_property_register (const char * name,
- GType value_type,
- GtkStylePropertyFlags flags,
- GtkStyleParseFunc parse_func,
- GtkStylePrintFunc print_func,
- const GValue * initial_value)
+_gtk_style_property_register (const char * name,
+ GType value_type,
+ GtkStylePropertyFlags flags,
+ GtkCssStylePropertyParseFunc parse_value,
+ GtkCssStylePropertyPrintFunc print_value,
+ const GValue * initial_value)
{
- GtkStyleProperty *node;
+ GtkCssStyleProperty *node;
node = g_object_new (GTK_TYPE_CSS_STYLE_PROPERTY,
"inherit", (flags & GTK_STYLE_PROPERTY_INHERIT) ? TRUE : FALSE,
@@ -60,23 +60,26 @@ _gtk_style_property_register (const char * name,
"name", name,
"value-type", value_type,
NULL);
- node->parse_func = parse_func;
- node->print_func = print_func;
+
+ if (parse_value)
+ node->parse_value = parse_value;
+ if (print_value)
+ node->print_value = print_value;
}
static void
-gtk_style_property_register (const char * name,
- GType value_type,
- GtkStylePropertyFlags flags,
- GtkStyleParseFunc parse_func,
- GtkStylePrintFunc print_func,
+gtk_style_property_register (const char * name,
+ GType value_type,
+ GtkStylePropertyFlags flags,
+ GtkCssStylePropertyParseFunc parse_value,
+ GtkCssStylePropertyPrintFunc print_value,
...)
{
GValue initial_value = G_VALUE_INIT;
char *error = NULL;
va_list args;
- va_start (args, print_func);
+ va_start (args, print_value);
G_VALUE_COLLECT_INIT (&initial_value, value_type,
args, 0, &error);
if (error)
@@ -88,7 +91,7 @@ gtk_style_property_register (const char * name,
va_end (args);
- _gtk_style_property_register (name, value_type, flags, parse_func, print_func, &initial_value);
+ _gtk_style_property_register (name, value_type, flags, parse_value, print_value, &initial_value);
g_value_unset (&initial_value);
}
@@ -145,9 +148,10 @@ string_append_string (GString *str,
/*** IMPLEMENTATIONS ***/
static gboolean
-font_family_parse (GtkCssParser *parser,
- GFile *base,
- GValue *value)
+font_family_parse (GtkCssStyleProperty *property,
+ GValue *value,
+ GtkCssParser *parser,
+ GFile *base)
{
GPtrArray *names;
char *name;
@@ -191,8 +195,9 @@ font_family_parse (GtkCssParser *parser,
}
static void
-font_family_value_print (const GValue *value,
- GString *string)
+font_family_value_print (GtkCssStyleProperty *property,
+ const GValue *value,
+ GString *string)
{
const char **names = g_value_get_boxed (value);
@@ -213,9 +218,10 @@ font_family_value_print (const GValue *value,
}
static gboolean
-bindings_value_parse (GtkCssParser *parser,
- GFile *base,
- GValue *value)
+bindings_value_parse (GtkCssStyleProperty *property,
+ GValue *value,
+ GtkCssParser *parser,
+ GFile *base)
{
GPtrArray *array;
GtkBindingSet *binding_set;
@@ -252,8 +258,9 @@ bindings_value_parse (GtkCssParser *parser,
}
static void
-bindings_value_print (const GValue *value,
- GString *string)
+bindings_value_print (GtkCssStyleProperty *property,
+ const GValue *value,
+ GString *string)
{
GPtrArray *array;
guint i;
@@ -271,9 +278,10 @@ bindings_value_print (const GValue *value,
}
static gboolean
-border_corner_radius_value_parse (GtkCssParser *parser,
- GFile *base,
- GValue *value)
+border_corner_radius_value_parse (GtkCssStyleProperty *property,
+ GValue *value,
+ GtkCssParser *parser,
+ GFile *base)
{
GtkCssBorderCornerRadius corner;
@@ -299,8 +307,9 @@ negative:
}
static void
-border_corner_radius_value_print (const GValue *value,
- GString *string)
+border_corner_radius_value_print (GtkCssStyleProperty *property,
+ const GValue *value,
+ GString *string)
{
GtkCssBorderCornerRadius *corner;
diff --git a/gtk/gtkcssstylepropertyprivate.h b/gtk/gtkcssstylepropertyprivate.h
index a8f6dce..ca86bc8 100644
--- a/gtk/gtkcssstylepropertyprivate.h
+++ b/gtk/gtkcssstylepropertyprivate.h
@@ -35,6 +35,13 @@ G_BEGIN_DECLS
typedef struct _GtkCssStyleProperty GtkCssStyleProperty;
typedef struct _GtkCssStylePropertyClass GtkCssStylePropertyClass;
+typedef gboolean (* GtkCssStylePropertyParseFunc) (GtkCssStyleProperty *property,
+ GValue *value,
+ GtkCssParser *parser,
+ GFile *base);
+typedef void (* GtkCssStylePropertyPrintFunc) (GtkCssStyleProperty *property,
+ const GValue *value,
+ GString *string);
typedef void (* GtkCssStylePropertyComputeFunc)(GtkCssStyleProperty *property,
GValue *computed,
GtkStyleContext *context,
@@ -47,6 +54,8 @@ struct _GtkCssStyleProperty
guint id;
guint inherit :1;
+ GtkCssStylePropertyParseFunc parse_value;
+ GtkCssStylePropertyPrintFunc print_value;
GtkCssStylePropertyComputeFunc compute_value;
};
diff --git a/gtk/gtkstylepropertyprivate.h b/gtk/gtkstylepropertyprivate.h
index b2c7b92..92cfb07 100644
--- a/gtk/gtkstylepropertyprivate.h
+++ b/gtk/gtkstylepropertyprivate.h
@@ -45,11 +45,6 @@ typedef void (* GtkStylePackFunc) (GValue
GtkStyleProperties *props,
GtkStateFlags state,
GtkStylePropertyContext *context);
-typedef gboolean (* GtkStyleParseFunc) (GtkCssParser *parser,
- GFile *base,
- GValue *value);
-typedef void (* GtkStylePrintFunc) (const GValue *value,
- GString *string);
struct _GtkStyleProperty
{
@@ -60,8 +55,6 @@ struct _GtkStyleProperty
GtkStyleUnpackFunc unpack_func;
GtkStylePackFunc pack_func;
- GtkStyleParseFunc parse_func;
- GtkStylePrintFunc print_func;
};
struct _GtkStylePropertyClass
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]