[gtk+/parser] cssprovider: Simplify code
- From: Benjamin Otte <otte src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/parser] cssprovider: Simplify code
- Date: Mon, 16 May 2011 21:53:47 +0000 (UTC)
commit 0135b692ee95f304b9a87f51031aa3a50993cb6f
Author: Benjamin Otte <otte redhat com>
Date: Mon May 16 19:54:57 2011 +0200
cssprovider: Simplify code
Don't go through an intermediate array when matching styles.
gtk/gtkcssprovider.c | 59 +++++++++++---------------------------------------
1 files changed, 13 insertions(+), 46 deletions(-)
---
diff --git a/gtk/gtkcssprovider.c b/gtk/gtkcssprovider.c
index a899ecd..cfd96d2 100644
--- a/gtk/gtkcssprovider.c
+++ b/gtk/gtkcssprovider.c
@@ -1077,44 +1077,6 @@ gtk_css_provider_init (GtkCssProvider *css_provider)
(GDestroyNotify) gtk_symbolic_color_unref);
}
-typedef struct StylePriorityInfo StylePriorityInfo;
-
-struct StylePriorityInfo
-{
- GHashTable *style;
- GtkStateFlags state;
-};
-
-static GArray *
-css_provider_get_selectors (GtkCssProvider *css_provider,
- GtkWidgetPath *path)
-{
- GtkCssProviderPrivate *priv;
- GArray *priority_info;
- guint i;
-
- priv = css_provider->priv;
- priority_info = g_array_new (FALSE, FALSE, sizeof (StylePriorityInfo));
-
- for (i = 0; i < priv->selectors_info->len; i++)
- {
- SelectorStyleInfo *info;
- StylePriorityInfo new;
-
- info = g_ptr_array_index (priv->selectors_info, i);
-
- if (_gtk_css_selector_matches (info->selector, path))
- {
- new.style = info->style;
- new.state = _gtk_css_selector_get_state_flags (info->selector);
-
- g_array_append_val (priority_info, new);
- }
- }
-
- return priority_info;
-}
-
static void
css_provider_dump_symbolic_colors (GtkCssProvider *css_provider,
GtkStyleProperties *props)
@@ -1143,23 +1105,27 @@ gtk_css_provider_get_style (GtkStyleProvider *provider,
GtkWidgetPath *path)
{
GtkCssProvider *css_provider;
+ GtkCssProviderPrivate *priv;
GtkStyleProperties *props;
- GArray *priority_info;
guint i;
css_provider = GTK_CSS_PROVIDER (provider);
+ priv = css_provider->priv;
props = gtk_style_properties_new ();
css_provider_dump_symbolic_colors (css_provider, props);
- priority_info = css_provider_get_selectors (css_provider, path);
- for (i = 0; i < priority_info->len; i++)
+ for (i = 0; i < priv->selectors_info->len; i++)
{
- StylePriorityInfo *info;
+ SelectorStyleInfo *info;
GHashTableIter iter;
gpointer key, value;
- info = &g_array_index (priority_info, StylePriorityInfo, i);
+ info = g_ptr_array_index (priv->selectors_info, i);
+
+ if (!_gtk_css_selector_matches (info->selector, path))
+ continue;
+
g_hash_table_iter_init (&iter, info->style);
while (g_hash_table_iter_next (&iter, &key, &value))
@@ -1174,12 +1140,13 @@ gtk_css_provider_get_style (GtkStyleProvider *provider,
!gtk_style_properties_lookup_property (prop, NULL, NULL))
continue;
- gtk_style_properties_set_property (props, key, info->state, value);
+ gtk_style_properties_set_property (props,
+ key,
+ _gtk_css_selector_get_state_flags (info->selector),
+ value);
}
}
- g_array_free (priority_info, TRUE);
-
return props;
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]