]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
kconfig: gconf: remove parents[] array and indent variable
authorMasahiro Yamada <masahiroy@kernel.org>
Tue, 24 Jun 2025 15:05:06 +0000 (00:05 +0900)
committerMasahiro Yamada <masahiroy@kernel.org>
Tue, 1 Jul 2025 11:07:34 +0000 (20:07 +0900)
The parents[] array is used to store the GtkTreeIter of parent nodes,
but this can be simplified: we can pass a GtkTreeIter pointer down
when _display_tree() recurses.

Signed-off-by: Masahiro Yamada <masahiroy@kernel.org>
scripts/kconfig/gconf.c

index 3e632a325c100167b3ac3aa89c7dcc5e9a77b774..432a467e3250a98c669afc987285e416e0a8a8a0 100644 (file)
@@ -47,8 +47,6 @@ GdkColor color;
 
 GtkTreeStore *tree1, *tree2, *tree;
 GtkTreeModel *model1, *model2;
-static GtkTreeIter *parents[256];
-static gint indent;
 
 static struct menu *current; // current node for SINGLE view
 static struct menu *browsed; // browsed node for SPLIT view
@@ -153,8 +151,6 @@ static void init_main_window(const gchar *glade_file)
 
 static void init_tree_model(void)
 {
-       gint i;
-
        tree = tree2 = gtk_tree_store_new(COL_NUMBER,
                                          G_TYPE_STRING, G_TYPE_STRING,
                                          G_TYPE_STRING, G_TYPE_STRING,
@@ -166,9 +162,6 @@ static void init_tree_model(void)
                                          G_TYPE_BOOLEAN);
        model2 = GTK_TREE_MODEL(tree2);
 
-       for (parents[0] = NULL, i = 1; i < 256; i++)
-               parents[i] = (GtkTreeIter *) g_malloc(sizeof(GtkTreeIter));
-
        tree1 = gtk_tree_store_new(COL_NUMBER,
                                   G_TYPE_STRING, G_TYPE_STRING,
                                   G_TYPE_STRING, G_TYPE_STRING,
@@ -1131,18 +1124,6 @@ static void set_node(GtkTreeIter * node, struct menu *menu, gchar ** row)
        g_object_unref(pix);
 }
 
-
-/* Add a node to the tree */
-static void place_node(struct menu *menu, char **row)
-{
-       GtkTreeIter *parent = parents[indent - 1];
-       GtkTreeIter *node = parents[indent];
-
-       gtk_tree_store_append(tree, node, parent);
-       set_node(node, menu, row);
-}
-
-
 /* Find a node in the GTK+ tree */
 static GtkTreeIter found;
 
@@ -1193,9 +1174,6 @@ static void update_tree(struct menu *src, GtkTreeIter * dst)
        struct symbol *sym;
        struct menu *menu1, *menu2;
 
-       if (src == &rootmenu)
-               indent = 1;
-
        valid = gtk_tree_model_iter_children(model2, child2, dst);
        for (child1 = src->list; child1; child1 = child1->next) {
 
@@ -1253,9 +1231,7 @@ static void update_tree(struct menu *src, GtkTreeIter * dst)
                        set_node(child2, menu1, fill_row(menu1));
                }
 
-               indent++;
                update_tree(child1, child2);
-               indent--;
 
                valid = gtk_tree_model_iter_next(model2, child2);
        }
@@ -1263,16 +1239,15 @@ static void update_tree(struct menu *src, GtkTreeIter * dst)
 
 
 /* Display the whole tree (single/split/full view) */
-static void display_tree(struct menu *menu)
+static void _display_tree(struct menu *menu, GtkTreeIter *parent)
 {
        struct property *prop;
        struct menu *child;
        enum prop_type ptype;
+       GtkTreeIter iter;
 
-       if (menu == &rootmenu) {
-               indent = 1;
+       if (menu == &rootmenu)
                current = &rootmenu;
-       }
 
        for (child = menu->list; child; child = child->next) {
                prop = child->prompt;
@@ -1290,8 +1265,10 @@ static void display_tree(struct menu *menu)
 
                if ((opt_mode == OPT_NORMAL && menu_is_visible(child)) ||
                    (opt_mode == OPT_PROMPT && menu_has_prompt(child)) ||
-                   (opt_mode == OPT_ALL    && menu_get_prompt(child)))
-                       place_node(child, fill_row(child));
+                   (opt_mode == OPT_ALL    && menu_get_prompt(child))) {
+                       gtk_tree_store_append(tree, &iter, parent);
+                       set_node(&iter, child, fill_row(child));
+               }
 
                if ((view_mode != FULL_VIEW) && (ptype == P_MENU)
                    && (tree == tree2))
@@ -1308,14 +1285,16 @@ static void display_tree(struct menu *menu)
 
                if (((view_mode == SINGLE_VIEW) && (menu->flags & MENU_ROOT))
                    || (view_mode == FULL_VIEW)
-                   || (view_mode == SPLIT_VIEW)) {
-                       indent++;
-                       display_tree(child);
-                       indent--;
-               }
+                   || (view_mode == SPLIT_VIEW))
+                       _display_tree(child, &iter);
        }
 }
 
+static void display_tree(struct menu *menu)
+{
+       _display_tree(menu, NULL);
+}
+
 /* Display a part of the tree starting at current node (single/split view) */
 static void display_tree_part(void)
 {