[gtk+/gtk-style-context: 74/251] GtkCssProvider: free selector path on parse_rule().
- From: Carlos Garnacho <carlosg src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/gtk-style-context: 74/251] GtkCssProvider: free selector path on parse_rule().
- Date: Tue, 12 Oct 2010 02:01:20 +0000 (UTC)
commit a35944d5bf1a4a3b3391a15f7e7c927c45aefb76
Author: Carlos Garnacho <carlosg gnome org>
Date: Wed Apr 21 01:51:46 2010 +0200
GtkCssProvider: free selector path on parse_rule().
gtk/gtkcssprovider.c | 28 +++++++++++++---------------
1 files changed, 13 insertions(+), 15 deletions(-)
---
diff --git a/gtk/gtkcssprovider.c b/gtk/gtkcssprovider.c
index 1c5ee9e..ed78aec 100644
--- a/gtk/gtkcssprovider.c
+++ b/gtk/gtkcssprovider.c
@@ -748,7 +748,8 @@ parse_selector (GtkCssProvider *css_provider,
{
SelectorPath *path;
- *selector_out = NULL;
+ path = selector_path_new ();
+ *selector_out = path;
if (scanner->token != ':' &&
scanner->token != G_TOKEN_IDENTIFIER)
@@ -774,10 +775,7 @@ parse_selector (GtkCssProvider *css_provider,
g_scanner_get_next_token (scanner);
if ((token = parse_nth_child (css_provider, scanner, path, &flags)) != G_TOKEN_NONE)
- {
- selector_path_unref (path);
- return token;
- }
+ return token;
}
selector_path_prepend_region (path, region_name, flags);
@@ -786,10 +784,7 @@ parse_selector (GtkCssProvider *css_provider,
else if (scanner->value.v_identifier[0] == '*')
selector_path_prepend_glob (path);
else
- {
- selector_path_unref (path);
- return G_TOKEN_IDENTIFIER;
- }
+ return G_TOKEN_IDENTIFIER;
g_scanner_get_next_token (scanner);
@@ -811,10 +806,7 @@ parse_selector (GtkCssProvider *css_provider,
g_scanner_get_next_token (scanner);
if (scanner->token != G_TOKEN_SYMBOL)
- {
- selector_path_unref (path);
- return G_TOKEN_SYMBOL;
- }
+ return G_TOKEN_SYMBOL;
path->state = GPOINTER_TO_INT (scanner->value.v_symbol);
@@ -883,7 +875,10 @@ parse_rule (GtkCssProvider *css_provider,
expected_token = parse_selector (css_provider, scanner, &selector);
if (expected_token != G_TOKEN_NONE)
- return expected_token;
+ {
+ selector_path_unref (selector);
+ return expected_token;
+ }
priv->cur_selectors = g_slist_prepend (priv->cur_selectors, selector);
@@ -894,7 +889,10 @@ parse_rule (GtkCssProvider *css_provider,
expected_token = parse_selector (css_provider, scanner, &selector);
if (expected_token != G_TOKEN_NONE)
- return expected_token;
+ {
+ selector_path_unref (selector);
+ return expected_token;
+ }
priv->cur_selectors = g_slist_prepend (priv->cur_selectors, selector);
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]