mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-07 11:20:09 +00:00
GtkCssProvider: Parse and match class info.
This commit is contained in:
parent
27c91622f6
commit
74697d91fe
@ -42,6 +42,7 @@ enum SelectorElementType {
|
|||||||
SELECTOR_NAME,
|
SELECTOR_NAME,
|
||||||
SELECTOR_GTYPE,
|
SELECTOR_GTYPE,
|
||||||
SELECTOR_REGION,
|
SELECTOR_REGION,
|
||||||
|
SELECTOR_CLASS,
|
||||||
SELECTOR_GLOB
|
SELECTOR_GLOB
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -247,6 +248,21 @@ selector_path_prepend_name (SelectorPath *path,
|
|||||||
path->elements = g_slist_prepend (path->elements, elem);
|
path->elements = g_slist_prepend (path->elements, elem);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
selector_path_prepend_class (SelectorPath *path,
|
||||||
|
const gchar *name)
|
||||||
|
{
|
||||||
|
SelectorElement *elem;
|
||||||
|
|
||||||
|
elem = g_slice_new (SelectorElement);
|
||||||
|
elem->combinator = COMBINATOR_DESCENDANT;
|
||||||
|
elem->elem_type = SELECTOR_CLASS;
|
||||||
|
|
||||||
|
elem->name = g_quark_from_string (name);
|
||||||
|
|
||||||
|
path->elements = g_slist_prepend (path->elements, elem);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
selector_path_prepend_combinator (SelectorPath *path,
|
selector_path_prepend_combinator (SelectorPath *path,
|
||||||
CombinatorType combinator)
|
CombinatorType combinator)
|
||||||
@ -439,6 +455,14 @@ compare_selector_element (GtkWidgetPath *path,
|
|||||||
*score = 0xF;
|
*score = 0xF;
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
else if (elem->elem_type == SELECTOR_CLASS)
|
||||||
|
{
|
||||||
|
if (!gtk_widget_path_iter_has_qclass (path, index, elem->name))
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
*score = 0xF;
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
@ -939,14 +963,21 @@ parse_selector (GtkCssProvider *css_provider,
|
|||||||
|
|
||||||
if (scanner->token != ':' &&
|
if (scanner->token != ':' &&
|
||||||
scanner->token != '#' &&
|
scanner->token != '#' &&
|
||||||
|
scanner->token != '.' &&
|
||||||
scanner->token != G_TOKEN_IDENTIFIER)
|
scanner->token != G_TOKEN_IDENTIFIER)
|
||||||
return G_TOKEN_IDENTIFIER;
|
return G_TOKEN_IDENTIFIER;
|
||||||
|
|
||||||
while (scanner->token == '#' ||
|
while (scanner->token == '#' ||
|
||||||
|
scanner->token == '.' ||
|
||||||
scanner->token == G_TOKEN_IDENTIFIER)
|
scanner->token == G_TOKEN_IDENTIFIER)
|
||||||
{
|
{
|
||||||
if (scanner->token == '#')
|
if (scanner->token == '#' ||
|
||||||
|
scanner->token == '.')
|
||||||
{
|
{
|
||||||
|
gboolean is_class;
|
||||||
|
|
||||||
|
is_class = (scanner->token == '.');
|
||||||
|
|
||||||
g_scanner_get_next_token (scanner);
|
g_scanner_get_next_token (scanner);
|
||||||
|
|
||||||
if (scanner->token != G_TOKEN_IDENTIFIER)
|
if (scanner->token != G_TOKEN_IDENTIFIER)
|
||||||
@ -954,19 +985,25 @@ parse_selector (GtkCssProvider *css_provider,
|
|||||||
|
|
||||||
selector_path_prepend_glob (path);
|
selector_path_prepend_glob (path);
|
||||||
selector_path_prepend_combinator (path, COMBINATOR_CHILD);
|
selector_path_prepend_combinator (path, COMBINATOR_CHILD);
|
||||||
selector_path_prepend_name (path, scanner->value.v_identifier);
|
|
||||||
|
if (is_class)
|
||||||
|
selector_path_prepend_class (path, scanner->value.v_identifier);
|
||||||
|
else
|
||||||
|
selector_path_prepend_name (path, scanner->value.v_identifier);
|
||||||
}
|
}
|
||||||
else if (g_ascii_isupper (scanner->value.v_identifier[0]))
|
else if (g_ascii_isupper (scanner->value.v_identifier[0]))
|
||||||
{
|
{
|
||||||
gchar *pos;
|
gchar *pos;
|
||||||
|
|
||||||
pos = strchr (scanner->value.v_identifier, '#');
|
if ((pos = strchr (scanner->value.v_identifier, '#')) != NULL ||
|
||||||
|
(pos = strchr (scanner->value.v_identifier, '.')) != NULL)
|
||||||
if (pos)
|
|
||||||
{
|
{
|
||||||
gchar *type_name, *name;
|
gchar *type_name, *name;
|
||||||
|
gboolean is_class;
|
||||||
|
|
||||||
/* Widget type and name put together */
|
is_class = (*pos == '.');
|
||||||
|
|
||||||
|
/* Widget type and name/class put together */
|
||||||
name = pos + 1;
|
name = pos + 1;
|
||||||
*pos = '\0';
|
*pos = '\0';
|
||||||
type_name = scanner->value.v_identifier;
|
type_name = scanner->value.v_identifier;
|
||||||
@ -977,7 +1014,11 @@ parse_selector (GtkCssProvider *css_provider,
|
|||||||
* between widget type and its name.
|
* between widget type and its name.
|
||||||
*/
|
*/
|
||||||
selector_path_prepend_combinator (path, COMBINATOR_CHILD);
|
selector_path_prepend_combinator (path, COMBINATOR_CHILD);
|
||||||
selector_path_prepend_name (path, name);
|
|
||||||
|
if (is_class)
|
||||||
|
selector_path_prepend_class (path, name);
|
||||||
|
else
|
||||||
|
selector_path_prepend_name (path, name);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
selector_path_prepend_type (path, scanner->value.v_identifier);
|
selector_path_prepend_type (path, scanner->value.v_identifier);
|
||||||
|
Loading…
Reference in New Issue
Block a user