diff options
author | Matthias Clasen <mclasen@redhat.com> | 2023-02-19 21:47:10 -0500 |
---|---|---|
committer | Matthias Clasen <mclasen@redhat.com> | 2023-02-19 21:48:56 -0500 |
commit | 3de10847b95268e51a3fea05174c3982f8c0da8a (patch) | |
tree | bbf0da865dd3c561781737a6fabba5b6911a71a6 | |
parent | 5105d607dea46b9c3dc98ece67b85329f3d771e0 (diff) | |
download | gtk+-3de10847b95268e51a3fea05174c3982f8c0da8a.tar.gz |
gtk4-builder-tool: Prefer child properties
Rewrite <child> elements to use child properties
where that is easily possible.
Fixes: #5609
-rw-r--r-- | testsuite/tools/simplify-data-3to4/paned.expected | 8 | ||||
-rw-r--r-- | testsuite/tools/simplify-data/test10.expected | 10 | ||||
-rw-r--r-- | testsuite/tools/simplify-data/test10.ui | 9 | ||||
-rw-r--r-- | testsuite/tools/simplify-data/test11.expected | 15 | ||||
-rw-r--r-- | testsuite/tools/simplify-data/test11.ui | 14 | ||||
-rw-r--r-- | testsuite/tools/simplify-data/test12.expected | 15 | ||||
-rw-r--r-- | testsuite/tools/simplify-data/test12.ui | 14 | ||||
-rw-r--r-- | testsuite/tools/simplify-data/test13.expected | 20 | ||||
-rw-r--r-- | testsuite/tools/simplify-data/test13.ui | 19 | ||||
-rw-r--r-- | testsuite/tools/simplify-data/test5.expected | 4 | ||||
-rw-r--r-- | testsuite/tools/simplify-data/test8.expected | 10 | ||||
-rw-r--r-- | testsuite/tools/simplify-data/test8.ui | 9 | ||||
-rw-r--r-- | testsuite/tools/simplify-data/test9.expected | 10 | ||||
-rw-r--r-- | testsuite/tools/simplify-data/test9.ui | 9 | ||||
-rw-r--r-- | tools/gtk-builder-tool-simplify.c | 182 |
15 files changed, 324 insertions, 24 deletions
diff --git a/testsuite/tools/simplify-data-3to4/paned.expected b/testsuite/tools/simplify-data-3to4/paned.expected index d767086ba8..117fd2d4b6 100644 --- a/testsuite/tools/simplify-data-3to4/paned.expected +++ b/testsuite/tools/simplify-data-3to4/paned.expected @@ -4,11 +4,11 @@ <object class="GtkPaned"> <property name="resize-end-child">0</property> <property name="shrink-start-child">0</property> - <child> + <property name="start-child"> <object class="GtkButton" id="button"/> - </child> - <child> + </property> + <property name="end-child"> <object class="GtkLabel" id="label"/> - </child> + </property> </object> </interface> diff --git a/testsuite/tools/simplify-data/test10.expected b/testsuite/tools/simplify-data/test10.expected new file mode 100644 index 0000000000..54dec91df8 --- /dev/null +++ b/testsuite/tools/simplify-data/test10.expected @@ -0,0 +1,10 @@ +<?xml version="1.0" encoding="UTF-8"?> +<interface> + <object class="GtkWindow"> + <property name="child"> + <object class="GtkLabel"> + <property name="label">start</property> + </object> + </property> + </object> +</interface> diff --git a/testsuite/tools/simplify-data/test10.ui b/testsuite/tools/simplify-data/test10.ui new file mode 100644 index 0000000000..3b5e171633 --- /dev/null +++ b/testsuite/tools/simplify-data/test10.ui @@ -0,0 +1,9 @@ +<interface> + <object class="GtkWindow"> + <child> + <object class="GtkLabel"> + <property name="label">start</property> + </object> + </child> + </object> +</interface> diff --git a/testsuite/tools/simplify-data/test11.expected b/testsuite/tools/simplify-data/test11.expected new file mode 100644 index 0000000000..d54c185bd6 --- /dev/null +++ b/testsuite/tools/simplify-data/test11.expected @@ -0,0 +1,15 @@ +<?xml version="1.0" encoding="UTF-8"?> +<interface> + <object class="GtkPaned"> + <property name="start-child"> + <object class="GtkLabel"> + <property name="label">start</property> + </object> + </property> + <property name="end-child"> + <object class="GtkLabel"> + <property name="label">end</property> + </object> + </property> + </object> +</interface> diff --git a/testsuite/tools/simplify-data/test11.ui b/testsuite/tools/simplify-data/test11.ui new file mode 100644 index 0000000000..1f546a1d08 --- /dev/null +++ b/testsuite/tools/simplify-data/test11.ui @@ -0,0 +1,14 @@ +<interface> + <object class="GtkPaned"> + <child> + <object class="GtkLabel"> + <property name="label">start</property> + </object> + </child> + <child> + <object class="GtkLabel"> + <property name="label">end</property> + </object> + </child> + </object> +</interface> diff --git a/testsuite/tools/simplify-data/test12.expected b/testsuite/tools/simplify-data/test12.expected new file mode 100644 index 0000000000..bc43c43753 --- /dev/null +++ b/testsuite/tools/simplify-data/test12.expected @@ -0,0 +1,15 @@ +<?xml version="1.0" encoding="UTF-8"?> +<interface> + <object class="GtkPaned"> + <property name="end-child"> + <object class="GtkLabel"> + <property name="label">end</property> + </object> + </property> + <property name="start-child"> + <object class="GtkLabel"> + <property name="label">start</property> + </object> + </property> + </object> +</interface> diff --git a/testsuite/tools/simplify-data/test12.ui b/testsuite/tools/simplify-data/test12.ui new file mode 100644 index 0000000000..865dfb41c4 --- /dev/null +++ b/testsuite/tools/simplify-data/test12.ui @@ -0,0 +1,14 @@ +<interface> + <object class="GtkPaned"> + <child type="end"> + <object class="GtkLabel"> + <property name="label">end</property> + </object> + </child> + <child type="start"> + <object class="GtkLabel"> + <property name="label">start</property> + </object> + </child> + </object> +</interface> diff --git a/testsuite/tools/simplify-data/test13.expected b/testsuite/tools/simplify-data/test13.expected new file mode 100644 index 0000000000..ef4a037789 --- /dev/null +++ b/testsuite/tools/simplify-data/test13.expected @@ -0,0 +1,20 @@ +<?xml version="1.0" encoding="UTF-8"?> +<interface> + <object class="GtkCenterBox"> + <property name="end-widget"> + <object class="GtkLabel"> + <property name="label">end</property> + </object> + </property> + <property name="center-widget"> + <object class="GtkLabel"> + <property name="label">center</property> + </object> + </property> + <property name="start-widget"> + <object class="GtkLabel"> + <property name="label">start</property> + </object> + </property> + </object> +</interface> diff --git a/testsuite/tools/simplify-data/test13.ui b/testsuite/tools/simplify-data/test13.ui new file mode 100644 index 0000000000..b8a1397938 --- /dev/null +++ b/testsuite/tools/simplify-data/test13.ui @@ -0,0 +1,19 @@ +<interface> + <object class="GtkCenterBox"> + <child type="end"> + <object class="GtkLabel"> + <property name="label">end</property> + </object> + </child> + <child type="center"> + <object class="GtkLabel"> + <property name="label">center</property> + </object> + </child> + <child type="start"> + <object class="GtkLabel"> + <property name="label">start</property> + </object> + </child> + </object> +</interface> diff --git a/testsuite/tools/simplify-data/test5.expected b/testsuite/tools/simplify-data/test5.expected index 24b18f4a52..73d04161ec 100644 --- a/testsuite/tools/simplify-data/test5.expected +++ b/testsuite/tools/simplify-data/test5.expected @@ -1,12 +1,12 @@ <?xml version="1.0" encoding="UTF-8"?> <interface> <object class="GtkWindow"> - <child> + <property name="child"> <object class="GtkBox"> <child> <placeholder/> </child> </object> - </child> + </property> </object> </interface> diff --git a/testsuite/tools/simplify-data/test8.expected b/testsuite/tools/simplify-data/test8.expected new file mode 100644 index 0000000000..8862b26584 --- /dev/null +++ b/testsuite/tools/simplify-data/test8.expected @@ -0,0 +1,10 @@ +<?xml version="1.0" encoding="UTF-8"?> +<interface> + <object class="GtkAspectFrame"> + <property name="child"> + <object class="GtkLabel"> + <property name="label">start</property> + </object> + </property> + </object> +</interface> diff --git a/testsuite/tools/simplify-data/test8.ui b/testsuite/tools/simplify-data/test8.ui new file mode 100644 index 0000000000..ef4f5061a8 --- /dev/null +++ b/testsuite/tools/simplify-data/test8.ui @@ -0,0 +1,9 @@ +<interface> + <object class="GtkAspectFrame"> + <child> + <object class="GtkLabel"> + <property name="label">start</property> + </object> + </child> + </object> +</interface> diff --git a/testsuite/tools/simplify-data/test9.expected b/testsuite/tools/simplify-data/test9.expected new file mode 100644 index 0000000000..1eb645aa4c --- /dev/null +++ b/testsuite/tools/simplify-data/test9.expected @@ -0,0 +1,10 @@ +<?xml version="1.0" encoding="UTF-8"?> +<interface> + <object class="GtkComboBox"> + <property name="child"> + <object class="GtkLabel"> + <property name="label">start</property> + </object> + </property> + </object> +</interface> diff --git a/testsuite/tools/simplify-data/test9.ui b/testsuite/tools/simplify-data/test9.ui new file mode 100644 index 0000000000..fa3ee56d95 --- /dev/null +++ b/testsuite/tools/simplify-data/test9.ui @@ -0,0 +1,9 @@ +<interface> + <object class="GtkComboBox"> + <child> + <object class="GtkLabel"> + <property name="label">start</property> + </object> + </child> + </object> +</interface> diff --git a/tools/gtk-builder-tool-simplify.c b/tools/gtk-builder-tool-simplify.c index b66b4143ce..d279aa526f 100644 --- a/tools/gtk-builder-tool-simplify.c +++ b/tools/gtk-builder-tool-simplify.c @@ -1279,6 +1279,114 @@ rewrite_paned (Element *element, } static void +replace_child_by_property (Element *element, + Element *child, + const char *property, + MyParserData *data) +{ + Element *obj, *elt; + + obj = child->children->data; + g_assert (obj && g_str_equal (obj->element_name, "object")); + child->children = g_list_remove (child->children, obj); + + elt = g_new0 (Element, 1); + elt->parent = element; + elt->element_name = g_strdup ("property"); + elt->attribute_names = g_new0 (char *, 2); + elt->attribute_names[0] = g_strdup ("name"); + elt->attribute_values = g_new0 (char *, 2); + elt->attribute_values[0] = g_strdup (property); + elt->children = g_list_prepend (NULL, obj); + + for (GList *l = element->children; l; l = l->next) + { + if (l->data == child) + { + l->data = elt; + elt = NULL; + free_element (child); + break; + } + } + + g_assert (elt == NULL); +} + +static void +rewrite_start_end_children (Element *element, + MyParserData *data) +{ + Element *start_child = NULL; + Element *end_child = NULL; + GList *l; + + for (l = element->children; l; l = l->next) + { + Element *child = l->data; + + if (!g_str_equal (child->element_name, "child")) + continue; + + if (has_attribute (child, "type", "start")) + start_child = child; + else if (has_attribute (child, "type", "end")) + end_child = child; + else if (start_child == NULL) + start_child = child; + else if (end_child == NULL) + end_child = child; + else + g_warning ("%s only accepts two children", get_class_name (element)); + } + + if (start_child) + replace_child_by_property (element, start_child, "start-child", data); + + if (end_child) + replace_child_by_property (element, end_child, "end-child", data); +} + +static void +rewrite_start_center_end_children (Element *element, + MyParserData *data) +{ + Element *start_child = NULL; + Element *center_child = NULL; + Element *end_child = NULL; + GList *l; + + for (l = element->children; l; l = l->next) + { + Element *child = l->data; + + if (has_attribute (child, "type", "start")) + start_child = child; + else if (has_attribute (child, "type", "center")) + center_child = child; + else if (has_attribute (child, "type", "end")) + end_child = child; + else if (start_child == NULL) + start_child = child; + else if (center_child == NULL) + center_child = child; + else if (end_child == NULL) + end_child = child; + else + g_warning ("%s only accepts three children", get_class_name (element)); + } + + if (start_child) + replace_child_by_property (element, start_child, "start-widget", data); + + if (center_child) + replace_child_by_property (element, center_child, "center-widget", data); + + if (end_child) + replace_child_by_property (element, end_child, "end-widget", data); +} + +static void rewrite_dialog (Element *element, MyParserData *data) { @@ -2004,8 +2112,8 @@ simplify_tree (MyParserData *data) } static gboolean -rewrite_element (Element *element, - MyParserData *data) +rewrite_element_3to4 (Element *element, + MyParserData *data) { GList *l; @@ -2014,7 +2122,7 @@ rewrite_element (Element *element, { GList *next = l->next; Element *child = l->data; - if (rewrite_element (child, data)) + if (rewrite_element_3to4 (child, data)) { element->children = g_list_remove (element->children, child); free_element (child); @@ -2070,6 +2178,52 @@ rewrite_element (Element *element, rewrite_fixed (element, data); if (element_is_object_or_template (element) && + g_str_equal (get_class_name (element), "GtkRadioButton")) + rewrite_radio_button (element, data); + + if (element_is_object_or_template (element) && + g_str_equal (get_class_name (element), "GtkScale")) + rewrite_scale (element, data); + + if (g_str_equal (element->element_name, "property")) + maybe_rename_property (element, data); + + if (g_str_equal (element->element_name, "property") && + property_has_been_removed (element, data)) + return TRUE; + + if (g_str_equal (element->element_name, "requires")) + rewrite_requires (element, data); + + return FALSE; +} + +static void +rewrite_tree_3to4 (MyParserData *data) +{ + rewrite_element_3to4 (data->root, data); +} + +static gboolean +rewrite_element (Element *element, + MyParserData *data) +{ + GList *l; + + l = element->children; + while (l) + { + GList *next = l->next; + Element *child = l->data; + if (rewrite_element (child, data)) + { + element->children = g_list_remove (element->children, child); + free_element (child); + } + l = next; + } + + if (element_is_object_or_template (element) && (g_str_equal (get_class_name (element), "GtkAspectFrame") || g_str_equal (get_class_name (element), "GtkComboBox") || g_str_equal (get_class_name (element), "GtkComboBoxText") || @@ -2087,22 +2241,12 @@ rewrite_element (Element *element, rewrite_bin_child (element, data); if (element_is_object_or_template (element) && - g_str_equal (get_class_name (element), "GtkRadioButton")) - rewrite_radio_button (element, data); + g_str_equal (get_class_name (element), "GtkPaned")) + rewrite_start_end_children (element, data); if (element_is_object_or_template (element) && - g_str_equal (get_class_name (element), "GtkScale")) - rewrite_scale (element, data); - - if (g_str_equal (element->element_name, "property")) - maybe_rename_property (element, data); - - if (g_str_equal (element->element_name, "property") && - property_has_been_removed (element, data)) - return TRUE; - - if (g_str_equal (element->element_name, "requires")) - rewrite_requires (element, data); + g_str_equal (get_class_name (element), "GtkCenterBox")) + rewrite_start_center_end_children (element, data); return FALSE; } @@ -2319,8 +2463,10 @@ simplify_file (const char *filename, if (data.convert3to4) { enhance_tree (&data); - rewrite_tree (&data); + rewrite_tree_3to4 (&data); } + + rewrite_tree (&data); simplify_tree (&data); dump_tree (&data); |