[gtk+/gtk-style-context: 65/533] GtkCssProvider: Allow '*' selectors.
- From: Carlos Garnacho <carlosg src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/gtk-style-context: 65/533] GtkCssProvider: Allow '*' selectors.
- Date: Wed, 1 Dec 2010 02:11:11 +0000 (UTC)
commit b9a9924959d626db5d1db08b47bb310ddee15bc6
Author: Carlos Garnacho <carlosg gnome org>
Date: Fri Apr 16 00:29:11 2010 +0200
GtkCssProvider: Allow '*' selectors.
These would match a single widget of any type.
gtk/gtkcssprovider.c | 66 ++++++++++++++++++++++++++++---------------------
1 files changed, 38 insertions(+), 28 deletions(-)
---
diff --git a/gtk/gtkcssprovider.c b/gtk/gtkcssprovider.c
index c401133..ffb23b8 100644
--- a/gtk/gtkcssprovider.c
+++ b/gtk/gtkcssprovider.c
@@ -38,7 +38,8 @@ typedef enum ParserScope ParserScope;
enum SelectorElementType {
SELECTOR_TYPE_NAME,
SELECTOR_NAME,
- SELECTOR_GTYPE
+ SELECTOR_GTYPE,
+ SELECTOR_GLOB
};
struct SelectorElement
@@ -165,6 +166,17 @@ selector_path_prepend_type (SelectorPath *path,
path->elements = g_slist_prepend (path->elements, elem);
}
+static void
+selector_path_prepend_glob (SelectorPath *path)
+{
+ SelectorElement *elem;
+
+ elem = g_slice_new (SelectorElement);
+ elem->elem_type = SELECTOR_GLOB;
+
+ path->elements = g_slist_prepend (path->elements, elem);
+}
+
static SelectorStyleInfo *
selector_style_info_new (SelectorPath *path)
{
@@ -295,6 +307,11 @@ compare_path_foreach (GType type,
data->score |= score;
}
}
+ else if (elem->elem_type == SELECTOR_GLOB)
+ {
+ /* Treat as lowest matching type */
+ data->score++;
+ }
data->iter = data->iter->next;
@@ -460,11 +477,19 @@ css_provider_apply_scope (GtkCssProvider *css_provider,
{
priv->scanner->config->cset_identifier_first = G_CSET_a_2_z "#-_0123456789" G_CSET_A_2_Z;
priv->scanner->config->cset_identifier_nth = G_CSET_a_2_z "#-_ 0123456789" G_CSET_A_2_Z;
+ priv->scanner->config->scan_identifier_1char = FALSE;
+ }
+ else if (scope == SCOPE_SELECTOR)
+ {
+ priv->scanner->config->cset_identifier_first = G_CSET_a_2_z G_CSET_A_2_Z "*";
+ priv->scanner->config->cset_identifier_nth = G_CSET_a_2_z "-" G_CSET_A_2_Z;
+ priv->scanner->config->scan_identifier_1char = TRUE;
}
else
{
priv->scanner->config->cset_identifier_first = G_CSET_a_2_z G_CSET_A_2_Z;
priv->scanner->config->cset_identifier_nth = G_CSET_a_2_z "-" G_CSET_A_2_Z;
+ priv->scanner->config->scan_identifier_1char = FALSE;
}
priv->scanner->config->scan_float = FALSE;
@@ -556,9 +581,9 @@ css_provider_commit (GtkCssProvider *css_provider)
}
static GTokenType
-parse_selector (GtkCssProvider *css_provider,
- GScanner *scanner,
- SelectorPath **selector_out)
+parse_selector (GtkCssProvider *css_provider,
+ GScanner *scanner,
+ SelectorPath **selector_out)
{
SelectorPath *path;
@@ -569,34 +594,19 @@ parse_selector (GtkCssProvider *css_provider,
path = selector_path_new ();
- if (g_ascii_isupper (scanner->value.v_identifier[0]))
+ while (scanner->token == G_TOKEN_IDENTIFIER)
{
- while (scanner->token == G_TOKEN_IDENTIFIER &&
- g_ascii_isupper (scanner->value.v_identifier[0]))
+ if (g_ascii_isupper (scanner->value.v_identifier[0]))
+ selector_path_prepend_type (path, scanner->value.v_identifier);
+ else if (scanner->value.v_identifier[0] == '*')
+ selector_path_prepend_glob (path);
+ else
{
- selector_path_prepend_type (path, scanner->value.v_identifier);
- g_scanner_get_next_token (scanner);
+ selector_path_unref (path);
+ return G_TOKEN_IDENTIFIER;
}
- if (scanner->token == '.')
- {
- /* style class scanning */
- g_scanner_get_next_token (scanner);
-
- if (scanner->token != G_TOKEN_IDENTIFIER)
- {
- selector_path_unref (path);
- return G_TOKEN_IDENTIFIER;
- }
-
- g_print ("Style class: %s\n", scanner->value.v_identifier);
- g_scanner_get_next_token (scanner);
- }
- }
- else
- {
- selector_path_unref (path);
- return G_TOKEN_IDENTIFIER;
+ g_scanner_get_next_token (scanner);
}
if (scanner->token == ':')
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]