[gtk+] Move import syntax closer to css
- From: Carlos Garnacho <carlosg src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+] Move import syntax closer to css
- Date: Sat, 4 Dec 2010 15:15:53 +0000 (UTC)
commit 11cd19987b96c1fceb4a912e1337761ebab56a51
Author: Matthias Clasen <mclasen redhat com>
Date: Thu Nov 18 01:25:41 2010 -0500
Move import syntax closer to css
Css allows @import url ("foo.css") or @import "foo.css" or
@import url ('foo.css') but not @import url(foo.css) or @immport foo.css.
gtk/gtkcssprovider.c | 88 +++++++++++++++++++++++++++++++------------------
1 files changed, 56 insertions(+), 32 deletions(-)
---
diff --git a/gtk/gtkcssprovider.c b/gtk/gtkcssprovider.c
index 3834775..a4e2a71 100644
--- a/gtk/gtkcssprovider.c
+++ b/gtk/gtkcssprovider.c
@@ -197,7 +197,7 @@
* <example>
* <title>Using the @import rule</title>
* <programlisting>
- * @import url (path/to/common.css)
+ * @import url ("path/to/common.css")
* </programlisting>
* </example>
* <para>
@@ -358,8 +358,8 @@
* <entry></entry>
* <entry>
* <programlisting>
- * border-image: url (/path/to/image.png) 3 4 3 4 stretch;
- * border-image: url (/path/to/image.png) 3 4 4 3 repeat stretch;</programlisting>
+ * border-image: url ("/path/to/image.png") 3 4 3 4 stretch;
+ * border-image: url ("/path/to/image.png") 3 4 4 3 repeat stretch;</programlisting>
* </entry>
* </row>
* <row>
@@ -1558,6 +1558,7 @@ parse_selector (GtkCssProvider *css_provider,
}
#define SKIP_SPACES(s) while (s[0] == ' ' || s[0] == '\t' || s[0] == '\n') s++;
+#define SKIP_SPACES_BACK(s) while (s[0] == ' ' || s[0] == '\t' || s[0] == '\n') s--;
static GtkSymbolicColor *
symbolic_color_parse_str (const gchar *string,
@@ -2099,36 +2100,59 @@ path_parse_str (GtkCssProvider *css_provider,
{
gchar *path, *chr;
- if (!g_str_has_prefix (str, "url"))
+ if (g_str_has_prefix (str, "url"))
{
- *end_ptr = (gchar *) str;
- return NULL;
- }
+ str += strlen ("url");
+ SKIP_SPACES (str);
- str += strlen ("url");
- SKIP_SPACES (str);
+ if (*str != '(')
+ {
+ *end_ptr = (gchar *) str;
+ return NULL;
+ }
- if (*str != '(')
- {
- *end_ptr = (gchar *) str;
- return NULL;
- }
+ chr = strrchr (str, ')');
- chr = strchr (str, ')');
+ if (!chr)
+ {
+ *end_ptr = (gchar *) str;
+ return NULL;
+ }
- if (!chr)
- {
- *end_ptr = (gchar *) str;
- return NULL;
- }
+ str++;
+ SKIP_SPACES (str);
- str++;
- SKIP_SPACES (str);
+ if (*str == '"' || *str == '\'')
+ {
+ gchar *p;
+ p = str;
+ str++;
- path = g_strndup (str, chr - str);
- g_strstrip (path);
+ SKIP_SPACES_BACK (chr);
- *end_ptr = chr + 1;
+ if (*chr != *p)
+ {
+ *end_ptr = str;
+ return NULL;
+ }
+ chr--;
+ }
+ else
+ {
+ *end_ptr = str;
+ return NULL;
+ }
+
+ path = g_strndup (str, chr - str);
+ g_strstrip (path);
+
+ *end_ptr = chr + 1;
+ }
+ else
+ {
+ path = g_strdup (str);
+ *end_ptr = str + strlen (str);
+ }
/* Always return an absolute path */
if (!g_path_is_absolute (path))
@@ -2678,13 +2702,13 @@ parse_rule (GtkCssProvider *css_provider,
css_provider_push_scope (css_provider, SCOPE_VALUE);
g_scanner_get_next_token (scanner);
- if (scanner->token != G_TOKEN_IDENTIFIER)
- return G_TOKEN_IDENTIFIER;
-
- path = path_parse (css_provider,
- g_strstrip (scanner->value.v_identifier));
-
- if (!path)
+ if (scanner->token == G_TOKEN_IDENTIFIER)
+ path = path_parse (css_provider,
+ g_strstrip (scanner->value.v_identifier));
+ else if (scanner->token == G_TOKEN_STRING)
+ path = path_parse (css_provider,
+ g_strstrip (scanner->value.v_string));
+ else
return G_TOKEN_IDENTIFIER;
css_provider_pop_scope (css_provider);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]