diff options
author | Alexander Larsson <alexl@redhat.com> | 2012-11-29 14:40:10 +0100 |
---|---|---|
committer | Alexander Larsson <alexl@redhat.com> | 2012-11-30 14:53:30 +0100 |
commit | 69feabd139b88539a115aa392d6638204e124b63 (patch) | |
tree | 58940e6187ffb96a5838b7fbecb3d1b345c827c4 /gtk/gtkcssprovider.c | |
parent | 0ede06d229f5d8b0ebdbd5b36a731736bea9dd5d (diff) | |
download | gtk+-69feabd139b88539a115aa392d6638204e124b63.tar.gz |
css: Better tree match verification
Diffstat (limited to 'gtk/gtkcssprovider.c')
-rw-r--r-- | gtk/gtkcssprovider.c | 61 |
1 files changed, 38 insertions, 23 deletions
diff --git a/gtk/gtkcssprovider.c b/gtk/gtkcssprovider.c index d1dbe0b0bb..88a1bd4696 100644 --- a/gtk/gtkcssprovider.c +++ b/gtk/gtkcssprovider.c @@ -1410,6 +1410,42 @@ gtk_css_provider_init (GtkCssProvider *css_provider) (GDestroyNotify) _gtk_css_value_unref); } +static void +verify_tree_match_results (GtkCssProvider *provider, + const GtkCssMatcher *matcher, + GPtrArray *tree_rules) +{ +#ifdef VERIFY_TREE + GtkCssProviderPrivate *priv = provider->priv; + GtkCssRuleset *ruleset; + int i, j; + + for (i = 0; i < priv->rulesets->len; i++) + { + gboolean found = FALSE; + + ruleset = &g_array_index (priv->rulesets, GtkCssRuleset, i); + + for (j = 0; j < tree_rules->len; j++) + { + if (ruleset == tree_rules->pdata[j]) + { + found = TRUE; + break; + } + } + + if (found != !!gtk_css_ruleset_matches (ruleset, matcher)) + { + g_error ("expected rule '%s' to %s, but it %s\n", + _gtk_css_selector_to_string (ruleset->selector), + gtk_css_ruleset_matches (ruleset, matcher) ? "match" : "not match", + found ? "matched" : "didn't match"); + } + } +#endif +} + static gboolean gtk_css_provider_get_style_property (GtkStyleProvider *provider, GtkWidgetPath *path, @@ -1514,29 +1550,7 @@ gtk_css_style_provider_lookup (GtkStyleProviderPrivate *provider, priv = css_provider->priv; tree_rules = _gtk_css_selector_tree_match_all (priv->tree, matcher); - -#ifdef VERIFY_TREE - for (i = 0; i < priv->rulesets->len; i++) - { - gboolean found = FALSE; - - ruleset = &g_array_index (priv->rulesets, GtkCssRuleset, i); - - for (j = 0; j < tree_rules->len; j++) - { - if (ruleset == tree_rules->pdata[j]) - { - found = TRUE; - break; - } - } - - if (found) - g_assert (gtk_css_ruleset_matches (ruleset, matcher)); - else - g_assert (!gtk_css_ruleset_matches (ruleset, matcher)); - } -#endif + verify_tree_match_results (css_provider, matcher, tree_rules); for (i = tree_rules->len - 1; i >= 0; i--) { @@ -1584,6 +1598,7 @@ gtk_css_style_provider_get_change (GtkStyleProviderPrivate *provider, priv = css_provider->priv; tree_rules = _gtk_css_selector_tree_match_all (priv->tree, matcher); + verify_tree_match_results (css_provider, matcher, tree_rules); for (i = tree_rules->len - 1; i >= 0; i--) { |