kconfig: change sym_choice_default() to take the choice menu
authorMasahiro Yamada <masahiroy@kernel.org>
Tue, 18 Jun 2024 10:35:24 +0000 (19:35 +0900)
committerMasahiro Yamada <masahiroy@kernel.org>
Mon, 15 Jul 2024 16:08:37 +0000 (01:08 +0900)
Change the argument of sym_choice_default() to ease further cleanups.

Signed-off-by: Masahiro Yamada <masahiroy@kernel.org>
scripts/kconfig/confdata.c
scripts/kconfig/lkc.h
scripts/kconfig/symbol.c

index 4359fbc..76193ce 100644 (file)
@@ -779,7 +779,7 @@ int conf_write_defconfig(const char *filename)
                if (choice) {
                        struct symbol *ds;
 
-                       ds = sym_choice_default(choice->sym);
+                       ds = sym_choice_default(choice);
                        if (sym == ds && sym_get_tristate_value(sym) == yes)
                                continue;
                }
index d820272..586a5e1 100644 (file)
@@ -109,7 +109,7 @@ void menu_get_ext_help(struct menu *menu, struct gstr *help);
 
 /* symbol.c */
 void sym_clear_all_valid(void);
-struct symbol *sym_choice_default(struct symbol *sym);
+struct symbol *sym_choice_default(struct menu *choice);
 struct symbol *sym_calc_choice(struct menu *choice);
 struct property *sym_get_range_prop(struct symbol *sym);
 const char *sym_get_string_default(struct symbol *sym);
index 344a241..3d68ab8 100644 (file)
@@ -255,14 +255,14 @@ static void sym_calc_visibility(struct symbol *sym)
  * Next locate the first visible choice value
  * Return NULL if none was found
  */
-struct symbol *sym_choice_default(struct symbol *sym)
+struct symbol *sym_choice_default(struct menu *choice)
 {
        struct symbol *def_sym;
        struct property *prop;
        struct expr *e;
 
        /* any of the defaults visible? */
-       for_all_defaults(sym, prop) {
+       for_all_defaults(choice->sym, prop) {
                prop->visible.tri = expr_calc_value(prop->visible.expr);
                if (prop->visible.tri == no)
                        continue;
@@ -272,7 +272,7 @@ struct symbol *sym_choice_default(struct symbol *sym)
        }
 
        /* just get the first visible value */
-       prop = sym_get_choice_prop(sym);
+       prop = sym_get_choice_prop(choice->sym);
        expr_list_for_each_sym(prop->expr, e, def_sym)
                if (def_sym->visible != no)
                        return def_sym;
@@ -312,7 +312,7 @@ struct symbol *sym_calc_choice(struct menu *choice)
         * explicitly set to 'n'.
         */
        if (!res) {
-               res = sym_choice_default(choice->sym);
+               res = sym_choice_default(choice);
                if (res && sym_has_value(res) && res->def[S_DEF_USER].tri == no)
                        res = NULL;
        }