Lines Matching +full:tri +full:- +full:default
1 // SPDX-License-Identifier: GPL-2.0
3 * Copyright (C) 2002 Roman Zippel <zippel@linux-m68k.org>
47 enum symbol_type type = sym->type; in sym_get_type()
50 if (sym_is_choice_value(sym) && sym->visible == yes) in sym_get_type()
91 prop->visible.tri = expr_calc_value(prop->visible.expr); in sym_get_default_prop()
92 if (prop->visible.tri != no) in sym_get_default_prop()
103 prop->visible.tri = expr_calc_value(prop->visible.expr); in sym_get_range_prop()
104 if (prop->visible.tri != no) in sym_get_range_prop()
113 switch (sym->type) { in sym_get_range_val()
120 default: in sym_get_range_val()
123 return strtoll(sym->curr.val, NULL, base); in sym_get_range_val()
133 switch (sym->type) { in sym_validate_range()
140 default: in sym_validate_range()
146 val = strtoll(sym->curr.val, NULL, base); in sym_validate_range()
147 range_sym = prop->expr->left.sym; in sym_validate_range()
150 range_sym = prop->expr->right.sym; in sym_validate_range()
155 sym->curr.val = range_sym->curr.val; in sym_validate_range()
162 sym->flags |= SYMBOL_CHANGED; in sym_set_changed()
163 for (prop = sym->prop; prop; prop = prop->next) { in sym_set_changed()
164 if (prop->menu) in sym_set_changed()
165 prop->menu->flags |= MENU_CHANGED; in sym_set_changed()
182 tristate tri; in sym_calc_visibility() local
185 tri = no; in sym_calc_visibility()
191 prop->visible.tri = expr_calc_value(prop->visible.expr); in sym_calc_visibility()
197 if (choice_sym && sym->type == S_TRISTATE && in sym_calc_visibility()
198 prop->visible.tri == mod && choice_sym->curr.tri == yes) in sym_calc_visibility()
199 prop->visible.tri = no; in sym_calc_visibility()
201 tri = EXPR_OR(tri, prop->visible.tri); in sym_calc_visibility()
203 if (tri == mod && (sym->type != S_TRISTATE || modules_val == no)) in sym_calc_visibility()
204 tri = yes; in sym_calc_visibility()
205 if (sym->visible != tri) { in sym_calc_visibility()
206 sym->visible = tri; in sym_calc_visibility()
212 tri = yes; in sym_calc_visibility()
213 if (sym->dir_dep.expr) in sym_calc_visibility()
214 tri = expr_calc_value(sym->dir_dep.expr); in sym_calc_visibility()
215 if (tri == mod && sym_get_type(sym) == S_BOOLEAN) in sym_calc_visibility()
216 tri = yes; in sym_calc_visibility()
217 if (sym->dir_dep.tri != tri) { in sym_calc_visibility()
218 sym->dir_dep.tri = tri; in sym_calc_visibility()
221 tri = no; in sym_calc_visibility()
222 if (sym->rev_dep.expr) in sym_calc_visibility()
223 tri = expr_calc_value(sym->rev_dep.expr); in sym_calc_visibility()
224 if (tri == mod && sym_get_type(sym) == S_BOOLEAN) in sym_calc_visibility()
225 tri = yes; in sym_calc_visibility()
226 if (sym->rev_dep.tri != tri) { in sym_calc_visibility()
227 sym->rev_dep.tri = tri; in sym_calc_visibility()
230 tri = no; in sym_calc_visibility()
231 if (sym->implied.expr) in sym_calc_visibility()
232 tri = expr_calc_value(sym->implied.expr); in sym_calc_visibility()
233 if (tri == mod && sym_get_type(sym) == S_BOOLEAN) in sym_calc_visibility()
234 tri = yes; in sym_calc_visibility()
235 if (sym->implied.tri != tri) { in sym_calc_visibility()
236 sym->implied.tri = tri; in sym_calc_visibility()
242 * Find the default symbol for a choice.
243 * First try the default values for the choice symbol
255 prop->visible.tri = expr_calc_value(prop->visible.expr); in sym_choice_default()
256 if (prop->visible.tri == no) in sym_choice_default()
259 if (def_sym->visible != no) in sym_choice_default()
265 expr_list_for_each_sym(prop->expr, e, def_sym) in sym_choice_default()
266 if (def_sym->visible != no) in sym_choice_default()
281 flags = sym->flags; in sym_calc_choice()
283 expr_list_for_each_sym(prop->expr, e, def_sym) { in sym_calc_choice()
285 if (def_sym->visible != no) in sym_calc_choice()
286 flags &= def_sym->flags; in sym_calc_choice()
289 sym->flags &= flags | ~SYMBOL_DEF_USER; in sym_calc_choice()
292 def_sym = sym->def[S_DEF_USER].val; in sym_calc_choice()
293 if (def_sym && def_sym->visible != no) in sym_calc_choice()
300 sym->curr.tri = no; in sym_calc_choice()
311 sym->name); in sym_warn_unmet_dep()
314 sym->dir_dep.tri == mod ? 'm' : 'n'); in sym_warn_unmet_dep()
315 expr_gstr_print(sym->dir_dep.expr, &gs); in sym_warn_unmet_dep()
318 expr_gstr_print_revdep(sym->rev_dep.expr, &gs, yes, in sym_warn_unmet_dep()
320 expr_gstr_print_revdep(sym->rev_dep.expr, &gs, mod, in sym_warn_unmet_dep()
344 if (sym->flags & SYMBOL_VALID) in sym_calc_value()
348 sym->flags & SYMBOL_NEED_SET_CHOICE_VALUES) { in sym_calc_value()
349 sym->flags &= ~SYMBOL_NEED_SET_CHOICE_VALUES; in sym_calc_value()
354 sym->flags |= SYMBOL_VALID; in sym_calc_value()
356 oldval = sym->curr; in sym_calc_value()
358 switch (sym->type) { in sym_calc_value()
368 default: in sym_calc_value()
369 sym->curr.val = sym->name; in sym_calc_value()
370 sym->curr.tri = no; in sym_calc_value()
373 sym->flags &= ~SYMBOL_WRITE; in sym_calc_value()
377 if (sym->visible != no) in sym_calc_value()
378 sym->flags |= SYMBOL_WRITE; in sym_calc_value()
380 /* set default if recursively called */ in sym_calc_value()
381 sym->curr = newval; in sym_calc_value()
386 if (sym_is_choice_value(sym) && sym->visible == yes) { in sym_calc_value()
388 newval.tri = (prop_get_symbol(prop)->curr.val == sym) ? yes : no; in sym_calc_value()
390 if (sym->visible != no) { in sym_calc_value()
392 * if available, otherwise try the default value in sym_calc_value()
395 newval.tri = EXPR_AND(sym->def[S_DEF_USER].tri, in sym_calc_value()
396 sym->visible); in sym_calc_value()
400 if (sym->rev_dep.tri != no) in sym_calc_value()
401 sym->flags |= SYMBOL_WRITE; in sym_calc_value()
405 newval.tri = EXPR_AND(expr_calc_value(prop->expr), in sym_calc_value()
406 prop->visible.tri); in sym_calc_value()
407 if (newval.tri != no) in sym_calc_value()
408 sym->flags |= SYMBOL_WRITE; in sym_calc_value()
410 if (sym->implied.tri != no) { in sym_calc_value()
411 sym->flags |= SYMBOL_WRITE; in sym_calc_value()
412 newval.tri = EXPR_OR(newval.tri, sym->implied.tri); in sym_calc_value()
413 newval.tri = EXPR_AND(newval.tri, in sym_calc_value()
414 sym->dir_dep.tri); in sym_calc_value()
418 if (sym->dir_dep.tri < sym->rev_dep.tri) in sym_calc_value()
420 newval.tri = EXPR_OR(newval.tri, sym->rev_dep.tri); in sym_calc_value()
422 if (newval.tri == mod && sym_get_type(sym) == S_BOOLEAN) in sym_calc_value()
423 newval.tri = yes; in sym_calc_value()
428 if (sym->visible != no && sym_has_value(sym)) { in sym_calc_value()
429 newval.val = sym->def[S_DEF_USER].val; in sym_calc_value()
436 sym->flags |= SYMBOL_WRITE; in sym_calc_value()
438 newval.val = ds->curr.val; in sym_calc_value()
442 default: in sym_calc_value()
446 sym->curr = newval; in sym_calc_value()
447 if (sym_is_choice(sym) && newval.tri == yes) in sym_calc_value()
448 sym->curr.val = sym_calc_choice(sym); in sym_calc_value()
451 if (memcmp(&oldval, &sym->curr, sizeof(oldval))) { in sym_calc_value()
455 modules_val = modules_sym->curr.tri; in sym_calc_value()
463 expr_list_for_each_sym(prop->expr, e, choice_sym) { in sym_calc_value()
464 if ((sym->flags & SYMBOL_WRITE) && in sym_calc_value()
465 choice_sym->visible != no) in sym_calc_value()
466 choice_sym->flags |= SYMBOL_WRITE; in sym_calc_value()
467 if (sym->flags & SYMBOL_CHANGED) in sym_calc_value()
472 if (sym->flags & SYMBOL_NO_WRITE) in sym_calc_value()
473 sym->flags &= ~SYMBOL_WRITE; in sym_calc_value()
475 if (sym->flags & SYMBOL_NEED_SET_CHOICE_VALUES) in sym_calc_value()
485 sym->flags &= ~SYMBOL_VALID; in sym_clear_all_valid()
494 if (sym->visible == no) in sym_tristate_within_range()
502 if (sym->visible <= sym->rev_dep.tri) in sym_tristate_within_range()
504 if (sym_is_choice_value(sym) && sym->visible == yes) in sym_tristate_within_range()
506 return val >= sym->rev_dep.tri && val <= sym->visible; in sym_tristate_within_range()
516 if (!(sym->flags & SYMBOL_DEF_USER)) { in sym_set_tristate_value()
517 sym->flags |= SYMBOL_DEF_USER; in sym_set_tristate_value()
529 cs->def[S_DEF_USER].val = sym; in sym_set_tristate_value()
530 cs->flags |= SYMBOL_DEF_USER; in sym_set_tristate_value()
532 for (e = prop->expr; e; e = e->left.expr) { in sym_set_tristate_value()
533 if (e->right.sym->visible != no) in sym_set_tristate_value()
534 e->right.sym->flags |= SYMBOL_DEF_USER; in sym_set_tristate_value()
538 sym->def[S_DEF_USER].tri = val; in sym_set_tristate_value()
572 switch (sym->type) { in sym_string_valid()
577 if (ch == '-') in sym_string_valid()
606 default: in sym_string_valid()
616 switch (sym->type) { in sym_string_within_range()
626 return val >= sym_get_range_val(prop->expr->left.sym, 10) && in sym_string_within_range()
627 val <= sym_get_range_val(prop->expr->right.sym, 10); in sym_string_within_range()
635 return val >= sym_get_range_val(prop->expr->left.sym, 16) && in sym_string_within_range()
636 val <= sym_get_range_val(prop->expr->right.sym, 16); in sym_string_within_range()
648 default: in sym_string_within_range()
659 switch (sym->type) { in sym_set_string_value()
671 default: in sym_set_string_value()
678 if (!(sym->flags & SYMBOL_DEF_USER)) { in sym_set_string_value()
679 sym->flags |= SYMBOL_DEF_USER; in sym_set_string_value()
683 oldval = sym->def[S_DEF_USER].val; in sym_set_string_value()
685 if (sym->type == S_HEX && (newval[0] != '0' || (newval[1] != 'x' && newval[1] != 'X'))) { in sym_set_string_value()
687 sym->def[S_DEF_USER].val = val = xmalloc(size); in sym_set_string_value()
691 sym->def[S_DEF_USER].val = val = xmalloc(size); in sym_set_string_value()
703 * Find the default value associated to a symbol.
706 * If the symbol does not have any default then fallback
707 * to the fixed default values.
718 val = symbol_no.curr.tri; in sym_get_string_default()
721 /* If symbol has a default value look it up */ in sym_get_string_default()
724 switch (sym->type) { in sym_get_string_default()
728 val = EXPR_AND(expr_calc_value(prop->expr), prop->visible.tri); in sym_get_string_default()
730 default: in sym_get_string_default()
733 * where a default value is further limited by in sym_get_string_default()
739 str = (const char *)ds->curr.val; in sym_get_string_default()
745 val = EXPR_OR(val, sym->rev_dep.tri); in sym_get_string_default()
749 if (!sym_is_choice_value(sym) && modules_sym->curr.tri == no) in sym_get_string_default()
753 if (sym->type == S_BOOLEAN && val == mod) in sym_get_string_default()
756 /* adjust the default value if this symbol is implied by another */ in sym_get_string_default()
757 if (val < sym->implied.tri) in sym_get_string_default()
758 val = sym->implied.tri; in sym_get_string_default()
760 switch (sym->type) { in sym_get_string_default()
783 switch (sym->type) { in sym_get_string_value()
796 default: in sym_get_string_value()
799 return (const char *)sym->curr.val; in sym_get_string_value()
804 return sym->visible > sym->rev_dep.tri; in sym_is_changeable()
832 for (symbol = symbol_hash[hash]; symbol; symbol = symbol->next) { in sym_lookup()
833 if (symbol->name && in sym_lookup()
834 !strcmp(symbol->name, name) && in sym_lookup()
835 (flags ? symbol->flags & flags in sym_lookup()
836 : !(symbol->flags & (SYMBOL_CONST|SYMBOL_CHOICE)))) in sym_lookup()
847 symbol->name = new_name; in sym_lookup()
848 symbol->type = S_UNKNOWN; in sym_lookup()
849 symbol->flags = flags; in sym_lookup()
851 symbol->next = symbol_hash[hash]; in sym_lookup()
874 for (symbol = symbol_hash[hash]; symbol; symbol = symbol->next) { in sym_find()
875 if (symbol->name && in sym_find()
876 !strcmp(symbol->name, name) && in sym_find()
877 !(symbol->flags & SYMBOL_CONST)) in sym_find()
890 * - first, symbols that match exactly
891 * - then, alphabetical sort
900 * - if matched length on symbol s1 is the length of that symbol, in sym_rel_comp()
902 * - if matched length on symbol s2 is the length of that symbol, in sym_rel_comp()
908 exact1 = (s1->eo - s1->so) == strlen(s1->sym->name); in sym_rel_comp()
909 exact2 = (s2->eo - s2->so) == strlen(s2->sym->name); in sym_rel_comp()
911 return -1; in sym_rel_comp()
916 return strcmp(s1->sym->name, s2->sym->name); in sym_rel_comp()
935 if (sym->flags & SYMBOL_CONST || !sym->name) in sym_re_search()
937 if (regexec(&re, sym->name, 1, match, 0)) in sym_re_search()
989 check_top->next = stack; in dep_stack_insert()
990 stack->prev = check_top; in dep_stack_insert()
991 stack->sym = sym; in dep_stack_insert()
997 check_top = check_top->prev; in dep_stack_remove()
999 check_top->next = NULL; in dep_stack_remove()
1005 * the ->prev pointer to locate the bottom of the stack.
1020 for (stack = check_top; stack != NULL; stack = stack->prev) in sym_check_print_recursive()
1021 if (stack->sym == last_sym) in sym_check_print_recursive()
1028 for (; stack; stack = stack->next) { in sym_check_print_recursive()
1029 sym = stack->sym; in sym_check_print_recursive()
1030 next_sym = stack->next ? stack->next->sym : last_sym; in sym_check_print_recursive()
1031 prop = stack->prop; in sym_check_print_recursive()
1033 prop = stack->sym->prop; in sym_check_print_recursive()
1037 for (prop = sym->prop; prop; prop = prop->next) { in sym_check_print_recursive()
1038 menu = prop->menu; in sym_check_print_recursive()
1039 if (prop->menu) in sym_check_print_recursive()
1043 if (stack->sym == last_sym) in sym_check_print_recursive()
1045 prop->file->name, prop->lineno); in sym_check_print_recursive()
1049 menu->file->name, menu->lineno, in sym_check_print_recursive()
1050 sym->name ? sym->name : "<choice>", in sym_check_print_recursive()
1051 next_sym->name ? next_sym->name : "<choice>"); in sym_check_print_recursive()
1054 menu->file->name, menu->lineno, in sym_check_print_recursive()
1055 sym->name ? sym->name : "<choice>", in sym_check_print_recursive()
1056 next_sym->name ? next_sym->name : "<choice>"); in sym_check_print_recursive()
1057 } else if (stack->expr == &sym->dir_dep.expr) { in sym_check_print_recursive()
1059 prop->file->name, prop->lineno, in sym_check_print_recursive()
1060 sym->name ? sym->name : "<choice>", in sym_check_print_recursive()
1061 next_sym->name ? next_sym->name : "<choice>"); in sym_check_print_recursive()
1062 } else if (stack->expr == &sym->rev_dep.expr) { in sym_check_print_recursive()
1064 prop->file->name, prop->lineno, in sym_check_print_recursive()
1065 sym->name ? sym->name : "<choice>", in sym_check_print_recursive()
1066 next_sym->name ? next_sym->name : "<choice>"); in sym_check_print_recursive()
1067 } else if (stack->expr == &sym->implied.expr) { in sym_check_print_recursive()
1069 prop->file->name, prop->lineno, in sym_check_print_recursive()
1070 sym->name ? sym->name : "<choice>", in sym_check_print_recursive()
1071 next_sym->name ? next_sym->name : "<choice>"); in sym_check_print_recursive()
1072 } else if (stack->expr) { in sym_check_print_recursive()
1074 prop->file->name, prop->lineno, in sym_check_print_recursive()
1075 sym->name ? sym->name : "<choice>", in sym_check_print_recursive()
1076 prop_get_type_name(prop->type), in sym_check_print_recursive()
1077 next_sym->name ? next_sym->name : "<choice>"); in sym_check_print_recursive()
1080 prop->file->name, prop->lineno, in sym_check_print_recursive()
1081 sym->name ? sym->name : "<choice>", in sym_check_print_recursive()
1082 prop_get_type_name(prop->type), in sym_check_print_recursive()
1083 next_sym->name ? next_sym->name : "<choice>"); in sym_check_print_recursive()
1088 "For a resolution refer to Documentation/kbuild/kconfig-language.rst\n" in sym_check_print_recursive()
1102 switch (e->type) { in sym_check_expr_deps()
1105 sym = sym_check_expr_deps(e->left.expr); in sym_check_expr_deps()
1108 return sym_check_expr_deps(e->right.expr); in sym_check_expr_deps()
1110 return sym_check_expr_deps(e->left.expr); in sym_check_expr_deps()
1117 sym = sym_check_deps(e->left.sym); in sym_check_expr_deps()
1120 return sym_check_deps(e->right.sym); in sym_check_expr_deps()
1122 return sym_check_deps(e->left.sym); in sym_check_expr_deps()
1123 default: in sym_check_expr_deps()
1126 fprintf(stderr, "Oops! How to check %d?\n", e->type); in sym_check_expr_deps()
1139 stack.expr = &sym->dir_dep.expr; in sym_check_sym_deps()
1140 sym2 = sym_check_expr_deps(sym->dir_dep.expr); in sym_check_sym_deps()
1144 stack.expr = &sym->rev_dep.expr; in sym_check_sym_deps()
1145 sym2 = sym_check_expr_deps(sym->rev_dep.expr); in sym_check_sym_deps()
1149 stack.expr = &sym->implied.expr; in sym_check_sym_deps()
1150 sym2 = sym_check_expr_deps(sym->implied.expr); in sym_check_sym_deps()
1156 for (prop = sym->prop; prop; prop = prop->next) { in sym_check_sym_deps()
1157 if (prop->type == P_CHOICE || prop->type == P_SELECT || in sym_check_sym_deps()
1158 prop->type == P_IMPLY) in sym_check_sym_deps()
1161 sym2 = sym_check_expr_deps(prop->visible.expr); in sym_check_sym_deps()
1164 if (prop->type != P_DEFAULT || sym_is_choice(sym)) in sym_check_sym_deps()
1166 stack.expr = &prop->expr; in sym_check_sym_deps()
1167 sym2 = sym_check_expr_deps(prop->expr); in sym_check_sym_deps()
1189 expr_list_for_each_sym(prop->expr, e, sym) in sym_check_choice_deps()
1190 sym->flags |= (SYMBOL_CHECK | SYMBOL_CHECKED); in sym_check_choice_deps()
1192 choice->flags |= (SYMBOL_CHECK | SYMBOL_CHECKED); in sym_check_choice_deps()
1194 choice->flags &= ~SYMBOL_CHECK; in sym_check_choice_deps()
1198 expr_list_for_each_sym(prop->expr, e, sym) { in sym_check_choice_deps()
1204 expr_list_for_each_sym(prop->expr, e, sym) in sym_check_choice_deps()
1205 sym->flags &= ~SYMBOL_CHECK; in sym_check_choice_deps()
1221 if (sym->flags & SYMBOL_CHECK) { in sym_check_deps()
1225 if (sym->flags & SYMBOL_CHECKED) in sym_check_deps()
1239 sym->flags |= (SYMBOL_CHECK | SYMBOL_CHECKED); in sym_check_deps()
1241 sym->flags &= ~SYMBOL_CHECK; in sym_check_deps()
1249 if (prop->expr && (prop->expr->type == E_SYMBOL || in prop_get_symbol()
1250 prop->expr->type == E_LIST)) in prop_get_symbol()
1251 return prop->expr->left.sym; in prop_get_symbol()
1265 return "default"; in prop_get_type_name()