diff options
author | Matthias Clasen <mclasen@redhat.com> | 2016-01-03 14:02:00 -0500 |
---|---|---|
committer | Matthias Clasen <mclasen@redhat.com> | 2016-01-03 14:41:43 -0500 |
commit | 0c52eca34cd1edeb51b930f756652e359ed6ee10 (patch) | |
tree | 36b7b7bf7527610188979b184d202e860c96f08a /gtk/gtkcssnode.c | |
parent | 28e185dd1b8b5fcf90993e9d698110328c1d497d (diff) | |
download | gtk+-0c52eca34cd1edeb51b930f756652e359ed6ee10.tar.gz |
Move node printing to GtkCssNodeDeclaration
The node declaration has all the information we are printing
here (except for visibility). At the same time, redo the format
to print the information in selector format, and indicate
(in)visibility by enclosing the selector in square brackets.
Diffstat (limited to 'gtk/gtkcssnode.c')
-rw-r--r-- | gtk/gtkcssnode.c | 91 |
1 files changed, 9 insertions, 82 deletions
diff --git a/gtk/gtkcssnode.c b/gtk/gtkcssnode.c index 916b83b685..a828d9f8e1 100644 --- a/gtk/gtkcssnode.c +++ b/gtk/gtkcssnode.c @@ -1523,80 +1523,6 @@ gtk_css_node_get_style_provider (GtkCssNode *cssnode) return GTK_STYLE_PROVIDER_PRIVATE (_gtk_settings_get_style_cascade (gtk_settings_get_default (), 1)); } -static void -append_id (GtkCssNode *cssnode, - GString *string) -{ - const char *id; - - id = gtk_css_node_get_id (cssnode); - if (id) - { - g_string_append (string, " id="); - g_string_append (string, id); - } -} - -static void -append_visible (GtkCssNode *cssnode, - GString *string) -{ - g_string_append_printf (string, " visible=%d", gtk_css_node_get_visible (cssnode)); -} - -static void -append_state (GtkCssNode *cssnode, - GString *string) - -{ - GtkStateFlags state; - - state = gtk_css_node_get_state (cssnode); - if (state) - { - GFlagsClass *fclass; - gint i; - gboolean first = TRUE; - - g_string_append (string, " state="); - fclass = g_type_class_ref (GTK_TYPE_STATE_FLAGS); - for (i = 0; i < fclass->n_values; i++) - { - if (state & fclass->values[i].value) - { - if (first) - first = FALSE; - else - g_string_append_c (string, '|'); - g_string_append (string, fclass->values[i].value_nick); - } - } - g_type_class_unref (fclass); - } -} - -static void -append_classes (GtkCssNode *cssnode, - GString *string) -{ - const GQuark *classes; - guint n_classes; - - classes = gtk_css_node_list_classes (cssnode, &n_classes); - if (n_classes > 0) - { - int i; - - g_string_append (string, " classes="); - for (i = 0; i < n_classes; i++) - { - if (i > 0) - g_string_append_c (string, ','); - g_string_append (string, g_quark_to_string (classes[i])); - } - } -} - static gboolean gtk_css_node_has_initial_value (GtkCssNode *cssnode, GtkCssStyleProperty *prop) @@ -1690,14 +1616,15 @@ gtk_css_node_print (GtkCssNode *cssnode, GtkCssNode *node; g_string_append_printf (string, "%*s", indent, ""); - if (gtk_css_node_get_name (cssnode)) - g_string_append (string, gtk_css_node_get_name (cssnode)); - else - g_string_append (string, g_type_name (gtk_css_node_get_widget_type (cssnode))); - append_id (cssnode, string); - append_visible (cssnode, string); - append_state (cssnode, string); - append_classes (cssnode, string); + + if (!cssnode->visible) + g_string_append_c (string, '['); + + gtk_css_node_declaration_print (cssnode->decl, string); + + if (!cssnode->visible) + g_string_append_c (string, ']'); + g_string_append_c (string, '\n'); append_style (cssnode, flags, string, indent + 2); |