GtkCssProvider: Allow '*' selectors.

These would match a single widget of any type.
This commit is contained in:
Carlos Garnacho 2010-04-16 00:29:11 +02:00
parent 468f216b1c
commit 4c8353bcbf

View File

@ -38,7 +38,8 @@ typedef enum ParserScope ParserScope;
enum SelectorElementType { enum SelectorElementType {
SELECTOR_TYPE_NAME, SELECTOR_TYPE_NAME,
SELECTOR_NAME, SELECTOR_NAME,
SELECTOR_GTYPE SELECTOR_GTYPE,
SELECTOR_GLOB
}; };
struct SelectorElement struct SelectorElement
@ -165,6 +166,17 @@ selector_path_prepend_type (SelectorPath *path,
path->elements = g_slist_prepend (path->elements, elem); 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 * static SelectorStyleInfo *
selector_style_info_new (SelectorPath *path) selector_style_info_new (SelectorPath *path)
{ {
@ -295,6 +307,11 @@ compare_path_foreach (GType type,
data->score |= score; data->score |= score;
} }
} }
else if (elem->elem_type == SELECTOR_GLOB)
{
/* Treat as lowest matching type */
data->score++;
}
data->iter = data->iter->next; 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_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->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 else
{ {
priv->scanner->config->cset_identifier_first = G_CSET_a_2_z G_CSET_A_2_Z; 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->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; priv->scanner->config->scan_float = FALSE;
@ -556,9 +581,9 @@ css_provider_commit (GtkCssProvider *css_provider)
} }
static GTokenType static GTokenType
parse_selector (GtkCssProvider *css_provider, parse_selector (GtkCssProvider *css_provider,
GScanner *scanner, GScanner *scanner,
SelectorPath **selector_out) SelectorPath **selector_out)
{ {
SelectorPath *path; SelectorPath *path;
@ -569,34 +594,19 @@ parse_selector (GtkCssProvider *css_provider,
path = selector_path_new (); 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 && if (g_ascii_isupper (scanner->value.v_identifier[0]))
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); selector_path_unref (path);
g_scanner_get_next_token (scanner); return G_TOKEN_IDENTIFIER;
} }
if (scanner->token == '.') g_scanner_get_next_token (scanner);
{
/* 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;
} }
if (scanner->token == ':') if (scanner->token == ':')