Lines Matching +full:prop +full:-
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() argument
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()
132 struct property *prop; in menu_add_prop() local
134 prop = xmalloc(sizeof(*prop)); in menu_add_prop()
135 memset(prop, 0, sizeof(*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()
147 for (propp = ¤t_entry->sym->prop; in menu_add_prop()
149 propp = &(*propp)->next) in menu_add_prop()
151 *propp = prop; in menu_add_prop()
154 return prop; in menu_add_prop()
160 struct property *prop = menu_add_prop(type, NULL, dep); in menu_add_prompt() local
163 prop_warn(prop, "leading whitespace ignored"); in menu_add_prompt()
167 if (current_entry->prompt) in menu_add_prompt()
168 prop_warn(prop, "prompt redefined"); 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()
196 return prop; 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() local
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()
232 prop_warn(prop, 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()
237 sym2 = prop_get_symbol(prop); in sym_check_prop()
238 if (sym->type == S_HEX || sym->type == S_INT) { in sym_check_prop()
240 prop_warn(prop, in sym_check_prop()
242 sym->name); in sym_check_prop()
250 prop_warn(prop, in sym_check_prop()
252 sym2->name); in sym_check_prop()
257 use = prop->type == P_SELECT ? "select" : "imply"; in sym_check_prop()
258 sym2 = prop_get_symbol(prop); in sym_check_prop()
259 if (sym->type != S_BOOLEAN && sym->type != S_TRISTATE) in sym_check_prop()
260 prop_warn(prop, 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()
266 prop_warn(prop, 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()
273 prop_warn(prop, "range is only allowed " 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()
277 prop_warn(prop, "range is invalid"); in sym_check_prop()
289 struct property *prop; in menu_finalize() local
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()
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()
355 for (; prop; prop = prop->next) { in menu_finalize()
356 if (prop->menu != menu) in menu_finalize()
361 * and so isn't location-specific, in menu_finalize()
379 dep = rewrite_m(prop->visible.expr); in menu_finalize()
383 prop->visible.expr = dep; in menu_finalize()
389 if (prop->type == P_SELECT) { in menu_finalize()
390 struct symbol *es = prop_get_symbol(prop); in menu_finalize()
391 es->rev_dep.expr = expr_alloc_or(es->rev_dep.expr, in menu_finalize()
392 expr_alloc_and(expr_alloc_symbol(menu->sym), expr_copy(dep))); in menu_finalize()
393 } else if (prop->type == P_IMPLY) { in menu_finalize()
394 struct symbol *es = prop_get_symbol(prop); in menu_finalize()
395 es->implied.expr = expr_alloc_or(es->implied.expr, in menu_finalize()
396 expr_alloc_and(expr_alloc_symbol(menu->sym), expr_copy(dep))); in menu_finalize()
408 for (menu = parent->list; menu; menu = menu->next) in menu_finalize()
418 * +-A in menu_finalize()
419 * +-B in menu_finalize()
420 * +-C in menu_finalize()
427 * +-A in menu_finalize()
428 * | +-B in menu_finalize()
429 * +-C in menu_finalize()
433 basedep = parent->prompt ? parent->prompt->visible.expr : NULL; in menu_finalize()
439 for (menu = parent->next; menu; menu = menu->next) { in menu_finalize()
440 dep = menu->prompt ? menu->prompt->visible.expr : menu->dep; in menu_finalize()
471 menu->parent = parent; in menu_finalize()
476 parent->list = parent->next; in menu_finalize()
477 parent->next = last_menu->next; in menu_finalize()
478 last_menu->next = NULL; in menu_finalize()
481 sym->dir_dep.expr = expr_alloc_or(sym->dir_dep.expr, parent->dep); in menu_finalize()
483 for (menu = parent->list; menu; menu = menu->next) { in menu_finalize()
485 menu->sym && !sym_is_choice_value(menu->sym)) { in menu_finalize()
487 menu->sym->flags |= SYMBOL_CHOICEVAL; in menu_finalize()
488 if (!menu->prompt) in menu_finalize()
490 for (prop = menu->sym->prop; prop; prop = prop->next) { in menu_finalize()
491 if (prop->type == P_DEFAULT) in menu_finalize()
492 prop_warn(prop, "defaults for choice " in menu_finalize()
494 if (prop->menu == menu) in menu_finalize()
496 if (prop->type == P_PROMPT && in menu_finalize()
497 prop->menu->parent->sym != sym) in menu_finalize()
498 prop_warn(prop, "choice value used outside its choice group"); in menu_finalize()
500 /* Non-tristate choice values of tristate choices must in menu_finalize()
503 * properties above, so the change here must be re- in menu_finalize()
506 if (sym->type == S_TRISTATE && menu->sym->type != S_TRISTATE) { in menu_finalize()
508 menu->dep = expr_alloc_and(basedep, menu->dep); in menu_finalize()
509 for (prop = menu->sym->prop; prop; prop = prop->next) { in menu_finalize()
510 if (prop->menu != menu) in menu_finalize()
512 prop->visible.expr = expr_alloc_and(expr_copy(basedep), in menu_finalize()
513 prop->visible.expr); in menu_finalize()
517 prop = sym_get_choice_prop(sym); in menu_finalize()
518 for (ep = &prop->expr; *ep; ep = &(*ep)->left.expr) in menu_finalize()
521 (*ep)->right.sym = menu->sym; in menu_finalize()
540 * +-B in menu_finalize()
541 * +-C in menu_finalize()
552 if (menu->list && (!menu->prompt || !menu->prompt->text)) { in menu_finalize()
553 for (last_menu = menu->list; ; last_menu = last_menu->next) { in menu_finalize()
554 last_menu->parent = parent; in menu_finalize()
555 if (!last_menu->next) in menu_finalize()
558 last_menu->next = menu->next; in menu_finalize()
559 menu->next = menu->list; in menu_finalize()
560 menu->list = NULL; in menu_finalize()
564 if (sym && !(sym->flags & SYMBOL_WARNED)) { in menu_finalize()
565 if (sym->type == S_UNKNOWN) in menu_finalize()
568 if (sym_is_choice(sym) && !parent->prompt) in menu_finalize()
573 sym->flags |= SYMBOL_WARNED; in menu_finalize()
577 * For non-optional choices, add a reverse dependency (corresponding to in menu_finalize()
581 * This would also work for non-choice symbols, but only non-optional in menu_finalize()
585 if (sym && !sym_is_optional(sym) && parent->prompt) { in menu_finalize()
586 sym->rev_dep.expr = expr_alloc_or(sym->rev_dep.expr, in menu_finalize()
587 expr_alloc_and(parent->prompt->visible.expr, in menu_finalize()
594 if (!menu->prompt) in menu_has_prompt()
608 for (child = menu->list; child; child = child->next) { in menu_is_empty()
621 if (!menu->prompt) in menu_is_visible()
624 if (menu->visibility) { in menu_is_visible()
625 if (expr_calc_value(menu->visibility) == no) in menu_is_visible()
629 sym = menu->sym; in menu_is_visible()
632 visible = menu->prompt->visible.tri; in menu_is_visible()
634 visible = menu->prompt->visible.tri = expr_calc_value(menu->prompt->visible.expr); in menu_is_visible()
639 if (!sym || sym_get_tristate_value(menu->sym) == no) in menu_is_visible()
642 for (child = menu->list; child; child = child->next) { in menu_is_visible()
645 sym->flags |= SYMBOL_DEF_USER; in menu_is_visible()
655 if (menu->prompt) in menu_get_prompt()
656 return menu->prompt->text; in menu_get_prompt()
657 else if (menu->sym) in menu_get_prompt()
658 return menu->sym->name; in menu_get_prompt()
666 for (; menu != &rootmenu; menu = menu->parent) { in menu_get_parent_menu()
667 type = menu->prompt ? menu->prompt->type : 0; in menu_get_parent_menu()
676 return menu->help != NULL; in menu_has_help()
681 if (menu->help) in menu_get_help()
682 return menu->help; in menu_get_help()
690 menu->file->name, menu->lineno); in get_def_str()
704 return -1; in get_jump_key_char()
707 static void get_prompt_str(struct gstr *r, struct property *prop, in get_prompt_str() argument
714 str_printf(r, " Prompt: %s\n", prop->text); in get_prompt_str()
716 get_dep_str(r, prop->menu->dep, " Depends on: "); in get_prompt_str()
725 if (!expr_eq(prop->menu->dep, prop->visible.expr)) in get_prompt_str()
726 get_dep_str(r, prop->visible.expr, " Visible if: "); in get_prompt_str()
728 menu = prop->menu; in get_prompt_str()
729 for (i = 0; menu != &rootmenu && i < 8; menu = menu->parent) { in get_prompt_str()
736 jump->target = location; in get_prompt_str()
737 list_add_tail(&jump->entries, head); in get_prompt_str()
741 for (j = 0; --i >= 0; j++) { in get_prompt_str()
742 int jk = -1; in get_prompt_str()
747 jump->offset = strlen(r->s); in get_prompt_str()
753 indent -= 3; in get_prompt_str()
756 str_printf(r, "%*c-> %s", indent, ' ', menu_get_prompt(menu)); in get_prompt_str()
757 if (menu->sym) { in get_prompt_str()
758 str_printf(r, " (%s [=%s])", menu->sym->name ? in get_prompt_str()
759 menu->sym->name : "<choice>", in get_prompt_str()
760 sym_get_string_value(menu->sym)); in get_prompt_str()
770 struct property *prop; in get_symbol_props_str() local
772 for_all_properties(sym, prop, tok) { in get_symbol_props_str()
778 expr_gstr_print(prop->expr, r); in get_symbol_props_str()
790 struct property *prop; in get_symbol_str() local
792 if (sym && sym->name) { in get_symbol_str()
793 str_printf(r, "Symbol: %s [=%s]\n", sym->name, in get_symbol_str()
795 str_printf(r, "Type : %s\n", sym_type_name(sym->type)); in get_symbol_str()
796 if (sym->type == S_INT || sym->type == S_HEX) { in get_symbol_str()
797 prop = sym_get_range_prop(sym); in get_symbol_str()
798 if (prop) { in get_symbol_str()
800 expr_gstr_print(prop->expr, r); in get_symbol_str()
807 for_all_properties(sym, prop, P_SYMBOL) { in get_symbol_str()
808 if (prop->menu->prompt) { in get_symbol_str()
809 get_def_str(r, prop->menu); in get_symbol_str()
810 get_prompt_str(r, prop->menu->prompt, head); in get_symbol_str()
814 for_all_properties(sym, prop, P_SYMBOL) { in get_symbol_str()
815 if (!prop->menu->prompt) { in get_symbol_str()
816 get_def_str(r, prop->menu); in get_symbol_str()
817 get_dep_str(r, prop->menu->dep, " Depends on: "); in get_symbol_str()
822 if (sym->rev_dep.expr) { in get_symbol_str()
823 expr_gstr_print_revdep(sym->rev_dep.expr, r, yes, "Selected by [y]:\n"); in get_symbol_str()
824 expr_gstr_print_revdep(sym->rev_dep.expr, r, mod, "Selected by [m]:\n"); in get_symbol_str()
825 expr_gstr_print_revdep(sym->rev_dep.expr, r, no, "Selected by [n]:\n"); in get_symbol_str()
829 if (sym->implied.expr) { in get_symbol_str()
830 expr_gstr_print_revdep(sym->implied.expr, r, yes, "Implied by [y]:\n"); in get_symbol_str()
831 expr_gstr_print_revdep(sym->implied.expr, r, mod, "Implied by [m]:\n"); in get_symbol_str()
832 expr_gstr_print_revdep(sym->implied.expr, r, no, "Implied by [n]:\n"); in get_symbol_str()
854 struct symbol *sym = menu->sym; in menu_get_ext_help()
858 if (sym->name) in menu_get_ext_help()
859 str_printf(help, "%s%s:\n\n", CONFIG_, sym->name); in menu_get_ext_help()