Lines Matching +full:bool +full:- +full:property
1 // SPDX-License-Identifier: GPL-2.0
3 * Copyright (C) 2002 Roman Zippel <zippel@linux-m68k.org>
26 fprintf(stderr, "%s:%d:warning: ", menu->file->name, menu->lineno); in menu_warn()
32 static void prop_warn(struct property *prop, const char *fmt, ...) in prop_warn()
36 fprintf(stderr, "%s:%d:warning: ", prop->file->name, prop->lineno); in prop_warn()
54 menu->sym = sym; in menu_add_entry()
55 menu->parent = current_menu; in menu_add_entry()
56 menu->file = current_file; in menu_add_entry()
57 menu->lineno = zconf_lineno(); in menu_add_entry()
60 last_entry_ptr = &menu->next; in menu_add_entry()
68 last_entry_ptr = ¤t_entry->list; in menu_add_menu()
75 last_entry_ptr = ¤t_menu->next; in menu_end_menu()
76 current_menu = current_menu->parent; in menu_end_menu()
88 switch (e->type) { in rewrite_m()
90 e->left.expr = rewrite_m(e->left.expr); in rewrite_m()
94 e->left.expr = rewrite_m(e->left.expr); in rewrite_m()
95 e->right.expr = rewrite_m(e->right.expr); in rewrite_m()
99 if (e->left.sym == &symbol_mod) in rewrite_m()
110 current_entry->dep = expr_alloc_and(current_entry->dep, dep); in menu_add_dep()
115 struct symbol *sym = current_entry->sym; in menu_set_type()
117 if (sym->type == type) in menu_set_type()
119 if (sym->type == S_UNKNOWN) { in menu_set_type()
120 sym->type = type; in menu_set_type()
125 sym->name ? sym->name : "<choice>", in menu_set_type()
126 sym_type_name(sym->type), sym_type_name(type)); in menu_set_type()
129 static struct property *menu_add_prop(enum prop_type type, struct expr *expr, in menu_add_prop()
132 struct property *prop; in menu_add_prop()
136 prop->type = type; in menu_add_prop()
137 prop->file = current_file; in menu_add_prop()
138 prop->lineno = zconf_lineno(); in menu_add_prop()
139 prop->menu = current_entry; in menu_add_prop()
140 prop->expr = expr; in menu_add_prop()
141 prop->visible.expr = dep; in menu_add_prop()
143 /* append property to the prop list of symbol */ in menu_add_prop()
144 if (current_entry->sym) { in menu_add_prop()
145 struct property **propp; in menu_add_prop()
147 for (propp = ¤t_entry->sym->prop; in menu_add_prop()
149 propp = &(*propp)->next) in menu_add_prop()
157 struct property *menu_add_prompt(enum prop_type type, char *prompt, in menu_add_prompt()
160 struct property *prop = menu_add_prop(type, NULL, dep); in menu_add_prompt()
167 if (current_entry->prompt) in menu_add_prompt()
174 while ((menu = menu->parent) != NULL) { in menu_add_prompt()
177 if (!menu->visibility) in menu_add_prompt()
186 dup_expr = expr_copy(menu->visibility); in menu_add_prompt()
188 prop->visible.expr = expr_alloc_and(prop->visible.expr, in menu_add_prompt()
193 current_entry->prompt = prop; in menu_add_prompt()
194 prop->text = prompt; in menu_add_prompt()
201 current_entry->visibility = expr_alloc_and(current_entry->visibility, in menu_add_visibility()
217 return sym2->type == S_INT || sym2->type == S_HEX || in menu_validate_number()
218 (sym2->type == S_UNKNOWN && sym_string_valid(sym, sym2->name)); in menu_validate_number()
223 struct property *prop; in sym_check_prop()
227 for (prop = sym->prop; prop; prop = prop->next) { in sym_check_prop()
228 switch (prop->type) { in sym_check_prop()
230 if ((sym->type == S_STRING || sym->type == S_INT || sym->type == S_HEX) && in sym_check_prop()
231 prop->expr->type != E_SYMBOL) in sym_check_prop()
234 " must be a single symbol", sym->name); in sym_check_prop()
235 if (prop->expr->type != E_SYMBOL) in sym_check_prop()
238 if (sym->type == S_HEX || sym->type == S_INT) { in sym_check_prop()
242 sym->name); in sym_check_prop()
245 struct property *choice_prop = in sym_check_prop()
252 sym2->name); in sym_check_prop()
257 use = prop->type == P_SELECT ? "select" : "imply"; in sym_check_prop()
259 if (sym->type != S_BOOLEAN && sym->type != S_TRISTATE) in sym_check_prop()
262 "not bool or tristate", sym->name, use); in sym_check_prop()
263 else if (sym2->type != S_UNKNOWN && in sym_check_prop()
264 sym2->type != S_BOOLEAN && in sym_check_prop()
265 sym2->type != S_TRISTATE) in sym_check_prop()
268 "accept arguments of bool and " in sym_check_prop()
269 "tristate type", sym2->name, use); in sym_check_prop()
272 if (sym->type != S_INT && sym->type != S_HEX) in sym_check_prop()
275 if (!menu_validate_number(sym, prop->expr->left.sym) || in sym_check_prop()
276 !menu_validate_number(sym, prop->expr->right.sym)) in sym_check_prop()
289 struct property *prop; in menu_finalize()
292 sym = parent->sym; in menu_finalize()
293 if (parent->list) { in menu_finalize()
300 if (sym->type == S_UNKNOWN) { in menu_finalize()
303 for (menu = parent->list; menu; menu = menu->next) { in menu_finalize()
304 if (menu->sym && menu->sym->type != S_UNKNOWN) { in menu_finalize()
305 menu_set_type(menu->sym->type); in menu_finalize()
311 for (menu = parent->list; menu; menu = menu->next) { in menu_finalize()
313 if (menu->sym && menu->sym->type == S_UNKNOWN) in menu_finalize()
314 menu_set_type(sym->type); in menu_finalize()
326 parentdep = parent->dep; in menu_finalize()
330 for (menu = parent->list; menu; menu = menu->next) { in menu_finalize()
335 basedep = rewrite_m(menu->dep); in menu_finalize()
339 menu->dep = basedep; in menu_finalize()
341 if (menu->sym) in menu_finalize()
344 * too in the symbol's own property list in menu_finalize()
346 prop = menu->sym->prop; in menu_finalize()
349 * For non-symbol menu nodes, we just need to in menu_finalize()
352 prop = menu->prompt; in menu_finalize()
354 /* For each property... */ in menu_finalize()
355 for (; prop; prop = prop->next) { in menu_finalize()
356 if (prop->menu != menu) in menu_finalize()
360 * 1. The property lacks dependencies in menu_finalize()
361 * and so isn't location-specific, in menu_finalize()
364 * 2. The property belongs to a symbol in menu_finalize()
370 * Skip the property. in menu_finalize()
376 * property's condition, rewriting and in menu_finalize()
379 dep = rewrite_m(prop->visible.expr); in menu_finalize()
383 if (menu->sym && menu->sym->type != S_TRISTATE) in menu_finalize()
385 prop->visible.expr = dep; in menu_finalize()
391 if (prop->type == P_SELECT) { in menu_finalize()
393 es->rev_dep.expr = expr_alloc_or(es->rev_dep.expr, in menu_finalize()
394 expr_alloc_and(expr_alloc_symbol(menu->sym), expr_copy(dep))); in menu_finalize()
395 } else if (prop->type == P_IMPLY) { in menu_finalize()
397 es->implied.expr = expr_alloc_or(es->implied.expr, in menu_finalize()
398 expr_alloc_and(expr_alloc_symbol(menu->sym), expr_copy(dep))); in menu_finalize()
410 for (menu = parent->list; menu; menu = menu->next) in menu_finalize()
420 * +-A in menu_finalize()
421 * +-B in menu_finalize()
422 * +-C in menu_finalize()
429 * +-A in menu_finalize()
430 * | +-B in menu_finalize()
431 * +-C in menu_finalize()
435 basedep = parent->prompt ? parent->prompt->visible.expr : NULL; in menu_finalize()
441 for (menu = parent->next; menu; menu = menu->next) { in menu_finalize()
442 dep = menu->prompt ? menu->prompt->visible.expr : menu->dep; in menu_finalize()
473 menu->parent = parent; in menu_finalize()
478 parent->list = parent->next; in menu_finalize()
479 parent->next = last_menu->next; in menu_finalize()
480 last_menu->next = NULL; in menu_finalize()
483 sym->dir_dep.expr = expr_alloc_or(sym->dir_dep.expr, parent->dep); in menu_finalize()
485 for (menu = parent->list; menu; menu = menu->next) { in menu_finalize()
487 menu->sym && !sym_is_choice_value(menu->sym)) { in menu_finalize()
489 menu->sym->flags |= SYMBOL_CHOICEVAL; in menu_finalize()
490 if (!menu->prompt) in menu_finalize()
492 for (prop = menu->sym->prop; prop; prop = prop->next) { in menu_finalize()
493 if (prop->type == P_DEFAULT) in menu_finalize()
496 if (prop->menu == menu) in menu_finalize()
498 if (prop->type == P_PROMPT && in menu_finalize()
499 prop->menu->parent->sym != sym) in menu_finalize()
502 /* Non-tristate choice values of tristate choices must in menu_finalize()
505 * properties above, so the change here must be re- in menu_finalize()
508 if (sym->type == S_TRISTATE && menu->sym->type != S_TRISTATE) { in menu_finalize()
510 menu->dep = expr_alloc_and(basedep, menu->dep); in menu_finalize()
511 for (prop = menu->sym->prop; prop; prop = prop->next) { in menu_finalize()
512 if (prop->menu != menu) in menu_finalize()
514 prop->visible.expr = expr_alloc_and(expr_copy(basedep), in menu_finalize()
515 prop->visible.expr); in menu_finalize()
520 for (ep = &prop->expr; *ep; ep = &(*ep)->left.expr) in menu_finalize()
523 (*ep)->right.sym = menu->sym; in menu_finalize()
542 * +-B in menu_finalize()
543 * +-C in menu_finalize()
554 if (menu->list && (!menu->prompt || !menu->prompt->text)) { in menu_finalize()
555 for (last_menu = menu->list; ; last_menu = last_menu->next) { in menu_finalize()
556 last_menu->parent = parent; in menu_finalize()
557 if (!last_menu->next) in menu_finalize()
560 last_menu->next = menu->next; in menu_finalize()
561 menu->next = menu->list; in menu_finalize()
562 menu->list = NULL; in menu_finalize()
566 if (sym && !(sym->flags & SYMBOL_WARNED)) { in menu_finalize()
567 if (sym->type == S_UNKNOWN) in menu_finalize()
570 if (sym_is_choice(sym) && !parent->prompt) in menu_finalize()
575 sym->flags |= SYMBOL_WARNED; in menu_finalize()
579 * For non-optional choices, add a reverse dependency (corresponding to in menu_finalize()
583 * This would also work for non-choice symbols, but only non-optional in menu_finalize()
587 if (sym && !sym_is_optional(sym) && parent->prompt) { in menu_finalize()
588 sym->rev_dep.expr = expr_alloc_or(sym->rev_dep.expr, in menu_finalize()
589 expr_alloc_and(parent->prompt->visible.expr, in menu_finalize()
594 bool menu_has_prompt(struct menu *menu) in menu_has_prompt()
596 if (!menu->prompt) in menu_has_prompt()
606 bool menu_is_empty(struct menu *menu) in menu_is_empty()
610 for (child = menu->list; child; child = child->next) { in menu_is_empty()
617 bool menu_is_visible(struct menu *menu) in menu_is_visible()
623 if (!menu->prompt) in menu_is_visible()
626 if (menu->visibility) { in menu_is_visible()
627 if (expr_calc_value(menu->visibility) == no) in menu_is_visible()
631 sym = menu->sym; in menu_is_visible()
634 visible = menu->prompt->visible.tri; in menu_is_visible()
636 visible = menu->prompt->visible.tri = expr_calc_value(menu->prompt->visible.expr); in menu_is_visible()
641 if (!sym || sym_get_tristate_value(menu->sym) == no) in menu_is_visible()
644 for (child = menu->list; child; child = child->next) { in menu_is_visible()
647 sym->flags |= SYMBOL_DEF_USER; in menu_is_visible()
657 if (menu->prompt) in menu_get_prompt()
658 return menu->prompt->text; in menu_get_prompt()
659 else if (menu->sym) in menu_get_prompt()
660 return menu->sym->name; in menu_get_prompt()
673 for (; menu != &rootmenu; menu = menu->parent) { in menu_get_parent_menu()
674 type = menu->prompt ? menu->prompt->type : 0; in menu_get_parent_menu()
681 bool menu_has_help(struct menu *menu) in menu_has_help()
683 return menu->help != NULL; in menu_has_help()
688 if (menu->help) in menu_get_help()
689 return menu->help; in menu_get_help()
697 menu->file->name, menu->lineno); in get_def_str()
709 static void get_prompt_str(struct gstr *r, struct property *prop, in get_prompt_str()
716 str_printf(r, " Prompt: %s\n", prop->text); in get_prompt_str()
718 get_dep_str(r, prop->menu->dep, " Depends on: "); in get_prompt_str()
727 if (!expr_eq(prop->menu->dep, prop->visible.expr)) in get_prompt_str()
728 get_dep_str(r, prop->visible.expr, " Visible if: "); in get_prompt_str()
730 menu = prop->menu->parent; in get_prompt_str()
731 for (i = 0; menu != &rootmenu && i < 8; menu = menu->parent) { in get_prompt_str()
732 bool accessible = menu_is_visible(menu); in get_prompt_str()
741 if (menu_is_visible(prop->menu)) { in get_prompt_str()
748 jump->target = prop->menu; in get_prompt_str()
750 jump->target = location; in get_prompt_str()
753 jump->index = 0; in get_prompt_str()
755 jump->index = list_entry(head->prev, struct jump_key, in get_prompt_str()
756 entries)->index + 1; in get_prompt_str()
758 list_add_tail(&jump->entries, head); in get_prompt_str()
763 for (j = 4; --i >= 0; j += 2) { in get_prompt_str()
766 jump->offset = strlen(r->s); in get_prompt_str()
767 str_printf(r, "%*c-> %s", j, ' ', in get_prompt_str()
769 if (menu->sym) { in get_prompt_str()
770 str_printf(r, " (%s [=%s])", menu->sym->name ? in get_prompt_str()
771 menu->sym->name : "<choice>", in get_prompt_str()
772 sym_get_string_value(menu->sym)); in get_prompt_str()
782 bool hit = false; in get_symbol_props_str()
783 struct property *prop; in get_symbol_props_str()
791 expr_gstr_print(prop->expr, r); in get_symbol_props_str()
803 struct property *prop; in get_symbol_str()
805 if (sym && sym->name) { in get_symbol_str()
806 str_printf(r, "Symbol: %s [=%s]\n", sym->name, in get_symbol_str()
808 str_printf(r, "Type : %s\n", sym_type_name(sym->type)); in get_symbol_str()
809 if (sym->type == S_INT || sym->type == S_HEX) { in get_symbol_str()
813 expr_gstr_print(prop->expr, r); in get_symbol_str()
821 if (prop->menu->prompt) { in get_symbol_str()
822 get_def_str(r, prop->menu); in get_symbol_str()
823 get_prompt_str(r, prop->menu->prompt, head); in get_symbol_str()
828 if (!prop->menu->prompt) { in get_symbol_str()
829 get_def_str(r, prop->menu); in get_symbol_str()
830 get_dep_str(r, prop->menu->dep, " Depends on: "); in get_symbol_str()
835 if (sym->rev_dep.expr) { in get_symbol_str()
836 expr_gstr_print_revdep(sym->rev_dep.expr, r, yes, "Selected by [y]:\n"); in get_symbol_str()
837 expr_gstr_print_revdep(sym->rev_dep.expr, r, mod, "Selected by [m]:\n"); in get_symbol_str()
838 expr_gstr_print_revdep(sym->rev_dep.expr, r, no, "Selected by [n]:\n"); in get_symbol_str()
842 if (sym->implied.expr) { in get_symbol_str()
843 expr_gstr_print_revdep(sym->implied.expr, r, yes, "Implied by [y]:\n"); in get_symbol_str()
844 expr_gstr_print_revdep(sym->implied.expr, r, mod, "Implied by [m]:\n"); in get_symbol_str()
845 expr_gstr_print_revdep(sym->implied.expr, r, no, "Implied by [n]:\n"); in get_symbol_str()
867 struct symbol *sym = menu->sym; in menu_get_ext_help()
871 if (sym->name) in menu_get_ext_help()
872 str_printf(help, "%s%s:\n\n", CONFIG_, sym->name); in menu_get_ext_help()