[gtk+/wip/css: 34/153] styleproperties: Add _gtk_style_properties_peek_property()
- From: Benjamin Otte <otte src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/wip/css: 34/153] styleproperties: Add _gtk_style_properties_peek_property()
- Date: Sat, 7 Jan 2012 01:59:26 +0000 (UTC)
commit 2f915b45e6ec7bdd1d8786bb7b45e5c64b6b89cb
Author: Benjamin Otte <otte redhat com>
Date: Sat Dec 31 01:05:50 2011 +0100
styleproperties: Add _gtk_style_properties_peek_property()
gtk/gtkstyleproperties.c | 37 ++++++++++++++++++++++---------------
gtk/gtkstylepropertiesprivate.h | 3 +++
2 files changed, 25 insertions(+), 15 deletions(-)
---
diff --git a/gtk/gtkstyleproperties.c b/gtk/gtkstyleproperties.c
index 26a9665..08ed39b 100644
--- a/gtk/gtkstyleproperties.c
+++ b/gtk/gtkstyleproperties.c
@@ -717,6 +717,25 @@ gtk_style_properties_set (GtkStyleProperties *props,
va_end (args);
}
+const GValue *
+_gtk_style_properties_peek_property (GtkStyleProperties *props,
+ const GtkStyleProperty *property,
+ GtkStateFlags state)
+{
+ GtkStylePropertiesPrivate *priv;
+ PropertyData *prop;
+
+ g_return_val_if_fail (GTK_IS_STYLE_PROPERTIES (props), FALSE);
+ g_return_val_if_fail (property != NULL, FALSE);
+
+ priv = props->priv;
+ prop = g_hash_table_lookup (priv->properties, property);
+ if (prop == NULL)
+ return NULL;
+
+ return property_data_match_state (prop, state);
+}
+
gboolean
_gtk_style_properties_get_property (GtkStyleProperties *props,
const gchar *property,
@@ -724,10 +743,8 @@ _gtk_style_properties_get_property (GtkStyleProperties *props,
GtkStylePropertyContext *context,
GValue *value)
{
- GtkStylePropertiesPrivate *priv;
const GtkStyleProperty *node;
- PropertyData *prop;
- GValue *val = NULL;
+ const GValue *val;
g_return_val_if_fail (GTK_IS_STYLE_PROPERTIES (props), FALSE);
g_return_val_if_fail (property != NULL, FALSE);
@@ -740,21 +757,11 @@ _gtk_style_properties_get_property (GtkStyleProperties *props,
return FALSE;
}
- priv = props->priv;
- prop = g_hash_table_lookup (priv->properties, node);
-
- val = NULL;
-
- if (prop)
- {
- /* NB: Will return NULL for shorthands */
- val = property_data_match_state (prop, state);
- }
-
+ val = _gtk_style_properties_peek_property (props, node, state);
g_value_init (value, node->pspec->value_type);
if (val)
- _gtk_style_property_resolve (node, props, state, context, val, value);
+ _gtk_style_property_resolve (node, props, state, context, (GValue *) val, value);
else if (_gtk_style_property_is_shorthand (node))
_gtk_style_property_pack (node, props, state, context, value);
else
diff --git a/gtk/gtkstylepropertiesprivate.h b/gtk/gtkstylepropertiesprivate.h
index 24e9714..61f940c 100644
--- a/gtk/gtkstylepropertiesprivate.h
+++ b/gtk/gtkstylepropertiesprivate.h
@@ -39,6 +39,9 @@ void _gtk_style_properties_get_valist (GtkStylePropertie
GtkStylePropertyContext *context,
va_list args);
+const GValue * _gtk_style_properties_peek_property (GtkStyleProperties *props,
+ const GtkStyleProperty *property,
+ GtkStateFlags state);
void _gtk_style_properties_set_property_by_property (GtkStyleProperties *props,
const GtkStyleProperty *property,
GtkStateFlags state,
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]