1*0a9064fbSMasahiro Yamada /* 2*0a9064fbSMasahiro Yamada * Copyright (C) 2002 Roman Zippel <zippel@linux-m68k.org> 3*0a9064fbSMasahiro Yamada * Released under the terms of the GNU GPL v2.0. 4*0a9064fbSMasahiro Yamada */ 5*0a9064fbSMasahiro Yamada 6*0a9064fbSMasahiro Yamada #ifndef EXPR_H 7*0a9064fbSMasahiro Yamada #define EXPR_H 8*0a9064fbSMasahiro Yamada 9*0a9064fbSMasahiro Yamada #ifdef __cplusplus 10*0a9064fbSMasahiro Yamada extern "C" { 11*0a9064fbSMasahiro Yamada #endif 12*0a9064fbSMasahiro Yamada 13*0a9064fbSMasahiro Yamada #include <assert.h> 14*0a9064fbSMasahiro Yamada #include <stdio.h> 15*0a9064fbSMasahiro Yamada #include "list.h" 16*0a9064fbSMasahiro Yamada #ifndef __cplusplus 17*0a9064fbSMasahiro Yamada #include <stdbool.h> 18*0a9064fbSMasahiro Yamada #endif 19*0a9064fbSMasahiro Yamada 20*0a9064fbSMasahiro Yamada struct file { 21*0a9064fbSMasahiro Yamada struct file *next; 22*0a9064fbSMasahiro Yamada struct file *parent; 23*0a9064fbSMasahiro Yamada const char *name; 24*0a9064fbSMasahiro Yamada int lineno; 25*0a9064fbSMasahiro Yamada }; 26*0a9064fbSMasahiro Yamada 27*0a9064fbSMasahiro Yamada typedef enum tristate { 28*0a9064fbSMasahiro Yamada no, mod, yes 29*0a9064fbSMasahiro Yamada } tristate; 30*0a9064fbSMasahiro Yamada 31*0a9064fbSMasahiro Yamada enum expr_type { 32*0a9064fbSMasahiro Yamada E_NONE, E_OR, E_AND, E_NOT, E_EQUAL, E_UNEQUAL, E_LIST, E_SYMBOL, E_RANGE 33*0a9064fbSMasahiro Yamada }; 34*0a9064fbSMasahiro Yamada 35*0a9064fbSMasahiro Yamada union expr_data { 36*0a9064fbSMasahiro Yamada struct expr *expr; 37*0a9064fbSMasahiro Yamada struct symbol *sym; 38*0a9064fbSMasahiro Yamada }; 39*0a9064fbSMasahiro Yamada 40*0a9064fbSMasahiro Yamada struct expr { 41*0a9064fbSMasahiro Yamada enum expr_type type; 42*0a9064fbSMasahiro Yamada union expr_data left, right; 43*0a9064fbSMasahiro Yamada }; 44*0a9064fbSMasahiro Yamada 45*0a9064fbSMasahiro Yamada #define EXPR_OR(dep1, dep2) (((dep1)>(dep2))?(dep1):(dep2)) 46*0a9064fbSMasahiro Yamada #define EXPR_AND(dep1, dep2) (((dep1)<(dep2))?(dep1):(dep2)) 47*0a9064fbSMasahiro Yamada #define EXPR_NOT(dep) (2-(dep)) 48*0a9064fbSMasahiro Yamada 49*0a9064fbSMasahiro Yamada #define expr_list_for_each_sym(l, e, s) \ 50*0a9064fbSMasahiro Yamada for (e = (l); e && (s = e->right.sym); e = e->left.expr) 51*0a9064fbSMasahiro Yamada 52*0a9064fbSMasahiro Yamada struct expr_value { 53*0a9064fbSMasahiro Yamada struct expr *expr; 54*0a9064fbSMasahiro Yamada tristate tri; 55*0a9064fbSMasahiro Yamada }; 56*0a9064fbSMasahiro Yamada 57*0a9064fbSMasahiro Yamada struct symbol_value { 58*0a9064fbSMasahiro Yamada void *val; 59*0a9064fbSMasahiro Yamada tristate tri; 60*0a9064fbSMasahiro Yamada }; 61*0a9064fbSMasahiro Yamada 62*0a9064fbSMasahiro Yamada enum symbol_type { 63*0a9064fbSMasahiro Yamada S_UNKNOWN, S_BOOLEAN, S_TRISTATE, S_INT, S_HEX, S_STRING, S_OTHER 64*0a9064fbSMasahiro Yamada }; 65*0a9064fbSMasahiro Yamada 66*0a9064fbSMasahiro Yamada /* enum values are used as index to symbol.def[] */ 67*0a9064fbSMasahiro Yamada enum { 68*0a9064fbSMasahiro Yamada S_DEF_USER, /* main user value */ 69*0a9064fbSMasahiro Yamada S_DEF_AUTO, /* values read from auto.conf */ 70*0a9064fbSMasahiro Yamada S_DEF_DEF3, /* Reserved for UI usage */ 71*0a9064fbSMasahiro Yamada S_DEF_DEF4, /* Reserved for UI usage */ 72*0a9064fbSMasahiro Yamada S_DEF_COUNT 73*0a9064fbSMasahiro Yamada }; 74*0a9064fbSMasahiro Yamada 75*0a9064fbSMasahiro Yamada struct symbol { 76*0a9064fbSMasahiro Yamada struct symbol *next; 77*0a9064fbSMasahiro Yamada char *name; 78*0a9064fbSMasahiro Yamada enum symbol_type type; 79*0a9064fbSMasahiro Yamada struct symbol_value curr; 80*0a9064fbSMasahiro Yamada struct symbol_value def[S_DEF_COUNT]; 81*0a9064fbSMasahiro Yamada tristate visible; 82*0a9064fbSMasahiro Yamada int flags; 83*0a9064fbSMasahiro Yamada struct property *prop; 84*0a9064fbSMasahiro Yamada struct expr_value dir_dep; 85*0a9064fbSMasahiro Yamada struct expr_value rev_dep; 86*0a9064fbSMasahiro Yamada }; 87*0a9064fbSMasahiro Yamada 88*0a9064fbSMasahiro Yamada #define for_all_symbols(i, sym) for (i = 0; i < SYMBOL_HASHSIZE; i++) for (sym = symbol_hash[i]; sym; sym = sym->next) if (sym->type != S_OTHER) 89*0a9064fbSMasahiro Yamada 90*0a9064fbSMasahiro Yamada #define SYMBOL_CONST 0x0001 /* symbol is const */ 91*0a9064fbSMasahiro Yamada #define SYMBOL_CHECK 0x0008 /* used during dependency checking */ 92*0a9064fbSMasahiro Yamada #define SYMBOL_CHOICE 0x0010 /* start of a choice block (null name) */ 93*0a9064fbSMasahiro Yamada #define SYMBOL_CHOICEVAL 0x0020 /* used as a value in a choice block */ 94*0a9064fbSMasahiro Yamada #define SYMBOL_VALID 0x0080 /* set when symbol.curr is calculated */ 95*0a9064fbSMasahiro Yamada #define SYMBOL_OPTIONAL 0x0100 /* choice is optional - values can be 'n' */ 96*0a9064fbSMasahiro Yamada #define SYMBOL_WRITE 0x0200 /* write symbol to file (KCONFIG_CONFIG) */ 97*0a9064fbSMasahiro Yamada #define SYMBOL_CHANGED 0x0400 /* ? */ 98*0a9064fbSMasahiro Yamada #define SYMBOL_AUTO 0x1000 /* value from environment variable */ 99*0a9064fbSMasahiro Yamada #define SYMBOL_CHECKED 0x2000 /* used during dependency checking */ 100*0a9064fbSMasahiro Yamada #define SYMBOL_WARNED 0x8000 /* warning has been issued */ 101*0a9064fbSMasahiro Yamada 102*0a9064fbSMasahiro Yamada /* Set when symbol.def[] is used */ 103*0a9064fbSMasahiro Yamada #define SYMBOL_DEF 0x10000 /* First bit of SYMBOL_DEF */ 104*0a9064fbSMasahiro Yamada #define SYMBOL_DEF_USER 0x10000 /* symbol.def[S_DEF_USER] is valid */ 105*0a9064fbSMasahiro Yamada #define SYMBOL_DEF_AUTO 0x20000 /* symbol.def[S_DEF_AUTO] is valid */ 106*0a9064fbSMasahiro Yamada #define SYMBOL_DEF3 0x40000 /* symbol.def[S_DEF_3] is valid */ 107*0a9064fbSMasahiro Yamada #define SYMBOL_DEF4 0x80000 /* symbol.def[S_DEF_4] is valid */ 108*0a9064fbSMasahiro Yamada 109*0a9064fbSMasahiro Yamada /* choice values need to be set before calculating this symbol value */ 110*0a9064fbSMasahiro Yamada #define SYMBOL_NEED_SET_CHOICE_VALUES 0x100000 111*0a9064fbSMasahiro Yamada 112*0a9064fbSMasahiro Yamada /* Set symbol to y if allnoconfig; used for symbols that hide others */ 113*0a9064fbSMasahiro Yamada #define SYMBOL_ALLNOCONFIG_Y 0x200000 114*0a9064fbSMasahiro Yamada 115*0a9064fbSMasahiro Yamada #define SYMBOL_MAXLENGTH 256 116*0a9064fbSMasahiro Yamada #define SYMBOL_HASHSIZE 9973 117*0a9064fbSMasahiro Yamada 118*0a9064fbSMasahiro Yamada /* A property represent the config options that can be associated 119*0a9064fbSMasahiro Yamada * with a config "symbol". 120*0a9064fbSMasahiro Yamada * Sample: 121*0a9064fbSMasahiro Yamada * config FOO 122*0a9064fbSMasahiro Yamada * default y 123*0a9064fbSMasahiro Yamada * prompt "foo prompt" 124*0a9064fbSMasahiro Yamada * select BAR 125*0a9064fbSMasahiro Yamada * config BAZ 126*0a9064fbSMasahiro Yamada * int "BAZ Value" 127*0a9064fbSMasahiro Yamada * range 1..255 128*0a9064fbSMasahiro Yamada */ 129*0a9064fbSMasahiro Yamada enum prop_type { 130*0a9064fbSMasahiro Yamada P_UNKNOWN, 131*0a9064fbSMasahiro Yamada P_PROMPT, /* prompt "foo prompt" or "BAZ Value" */ 132*0a9064fbSMasahiro Yamada P_COMMENT, /* text associated with a comment */ 133*0a9064fbSMasahiro Yamada P_MENU, /* prompt associated with a menuconfig option */ 134*0a9064fbSMasahiro Yamada P_DEFAULT, /* default y */ 135*0a9064fbSMasahiro Yamada P_CHOICE, /* choice value */ 136*0a9064fbSMasahiro Yamada P_SELECT, /* select BAR */ 137*0a9064fbSMasahiro Yamada P_RANGE, /* range 7..100 (for a symbol) */ 138*0a9064fbSMasahiro Yamada P_ENV, /* value from environment variable */ 139*0a9064fbSMasahiro Yamada P_SYMBOL, /* where a symbol is defined */ 140*0a9064fbSMasahiro Yamada }; 141*0a9064fbSMasahiro Yamada 142*0a9064fbSMasahiro Yamada struct property { 143*0a9064fbSMasahiro Yamada struct property *next; /* next property - null if last */ 144*0a9064fbSMasahiro Yamada struct symbol *sym; /* the symbol for which the property is associated */ 145*0a9064fbSMasahiro Yamada enum prop_type type; /* type of property */ 146*0a9064fbSMasahiro Yamada const char *text; /* the prompt value - P_PROMPT, P_MENU, P_COMMENT */ 147*0a9064fbSMasahiro Yamada struct expr_value visible; 148*0a9064fbSMasahiro Yamada struct expr *expr; /* the optional conditional part of the property */ 149*0a9064fbSMasahiro Yamada struct menu *menu; /* the menu the property are associated with 150*0a9064fbSMasahiro Yamada * valid for: P_SELECT, P_RANGE, P_CHOICE, 151*0a9064fbSMasahiro Yamada * P_PROMPT, P_DEFAULT, P_MENU, P_COMMENT */ 152*0a9064fbSMasahiro Yamada struct file *file; /* what file was this property defined */ 153*0a9064fbSMasahiro Yamada int lineno; /* what lineno was this property defined */ 154*0a9064fbSMasahiro Yamada }; 155*0a9064fbSMasahiro Yamada 156*0a9064fbSMasahiro Yamada #define for_all_properties(sym, st, tok) \ 157*0a9064fbSMasahiro Yamada for (st = sym->prop; st; st = st->next) \ 158*0a9064fbSMasahiro Yamada if (st->type == (tok)) 159*0a9064fbSMasahiro Yamada #define for_all_defaults(sym, st) for_all_properties(sym, st, P_DEFAULT) 160*0a9064fbSMasahiro Yamada #define for_all_choices(sym, st) for_all_properties(sym, st, P_CHOICE) 161*0a9064fbSMasahiro Yamada #define for_all_prompts(sym, st) \ 162*0a9064fbSMasahiro Yamada for (st = sym->prop; st; st = st->next) \ 163*0a9064fbSMasahiro Yamada if (st->text) 164*0a9064fbSMasahiro Yamada 165*0a9064fbSMasahiro Yamada struct menu { 166*0a9064fbSMasahiro Yamada struct menu *next; 167*0a9064fbSMasahiro Yamada struct menu *parent; 168*0a9064fbSMasahiro Yamada struct menu *list; 169*0a9064fbSMasahiro Yamada struct symbol *sym; 170*0a9064fbSMasahiro Yamada struct property *prompt; 171*0a9064fbSMasahiro Yamada struct expr *visibility; 172*0a9064fbSMasahiro Yamada struct expr *dep; 173*0a9064fbSMasahiro Yamada unsigned int flags; 174*0a9064fbSMasahiro Yamada char *help; 175*0a9064fbSMasahiro Yamada struct file *file; 176*0a9064fbSMasahiro Yamada int lineno; 177*0a9064fbSMasahiro Yamada void *data; 178*0a9064fbSMasahiro Yamada }; 179*0a9064fbSMasahiro Yamada 180*0a9064fbSMasahiro Yamada #define MENU_CHANGED 0x0001 181*0a9064fbSMasahiro Yamada #define MENU_ROOT 0x0002 182*0a9064fbSMasahiro Yamada 183*0a9064fbSMasahiro Yamada struct jump_key { 184*0a9064fbSMasahiro Yamada struct list_head entries; 185*0a9064fbSMasahiro Yamada size_t offset; 186*0a9064fbSMasahiro Yamada struct menu *target; 187*0a9064fbSMasahiro Yamada int index; 188*0a9064fbSMasahiro Yamada }; 189*0a9064fbSMasahiro Yamada 190*0a9064fbSMasahiro Yamada #define JUMP_NB 9 191*0a9064fbSMasahiro Yamada 192*0a9064fbSMasahiro Yamada extern struct file *file_list; 193*0a9064fbSMasahiro Yamada extern struct file *current_file; 194*0a9064fbSMasahiro Yamada struct file *lookup_file(const char *name); 195*0a9064fbSMasahiro Yamada 196*0a9064fbSMasahiro Yamada extern struct symbol symbol_yes, symbol_no, symbol_mod; 197*0a9064fbSMasahiro Yamada extern struct symbol *modules_sym; 198*0a9064fbSMasahiro Yamada extern struct symbol *sym_defconfig_list; 199*0a9064fbSMasahiro Yamada extern int cdebug; 200*0a9064fbSMasahiro Yamada struct expr *expr_alloc_symbol(struct symbol *sym); 201*0a9064fbSMasahiro Yamada struct expr *expr_alloc_one(enum expr_type type, struct expr *ce); 202*0a9064fbSMasahiro Yamada struct expr *expr_alloc_two(enum expr_type type, struct expr *e1, struct expr *e2); 203*0a9064fbSMasahiro Yamada struct expr *expr_alloc_comp(enum expr_type type, struct symbol *s1, struct symbol *s2); 204*0a9064fbSMasahiro Yamada struct expr *expr_alloc_and(struct expr *e1, struct expr *e2); 205*0a9064fbSMasahiro Yamada struct expr *expr_alloc_or(struct expr *e1, struct expr *e2); 206*0a9064fbSMasahiro Yamada struct expr *expr_copy(const struct expr *org); 207*0a9064fbSMasahiro Yamada void expr_free(struct expr *e); 208*0a9064fbSMasahiro Yamada int expr_eq(struct expr *e1, struct expr *e2); 209*0a9064fbSMasahiro Yamada void expr_eliminate_eq(struct expr **ep1, struct expr **ep2); 210*0a9064fbSMasahiro Yamada tristate expr_calc_value(struct expr *e); 211*0a9064fbSMasahiro Yamada struct expr *expr_eliminate_yn(struct expr *e); 212*0a9064fbSMasahiro Yamada struct expr *expr_trans_bool(struct expr *e); 213*0a9064fbSMasahiro Yamada struct expr *expr_eliminate_dups(struct expr *e); 214*0a9064fbSMasahiro Yamada struct expr *expr_transform(struct expr *e); 215*0a9064fbSMasahiro Yamada int expr_contains_symbol(struct expr *dep, struct symbol *sym); 216*0a9064fbSMasahiro Yamada bool expr_depends_symbol(struct expr *dep, struct symbol *sym); 217*0a9064fbSMasahiro Yamada struct expr *expr_extract_eq_and(struct expr **ep1, struct expr **ep2); 218*0a9064fbSMasahiro Yamada struct expr *expr_extract_eq_or(struct expr **ep1, struct expr **ep2); 219*0a9064fbSMasahiro Yamada void expr_extract_eq(enum expr_type type, struct expr **ep, struct expr **ep1, struct expr **ep2); 220*0a9064fbSMasahiro Yamada struct expr *expr_trans_compare(struct expr *e, enum expr_type type, struct symbol *sym); 221*0a9064fbSMasahiro Yamada struct expr *expr_simplify_unmet_dep(struct expr *e1, struct expr *e2); 222*0a9064fbSMasahiro Yamada 223*0a9064fbSMasahiro Yamada void expr_fprint(struct expr *e, FILE *out); 224*0a9064fbSMasahiro Yamada struct gstr; /* forward */ 225*0a9064fbSMasahiro Yamada void expr_gstr_print(struct expr *e, struct gstr *gs); 226*0a9064fbSMasahiro Yamada 227*0a9064fbSMasahiro Yamada static inline int expr_is_yes(struct expr *e) 228*0a9064fbSMasahiro Yamada { 229*0a9064fbSMasahiro Yamada return !e || (e->type == E_SYMBOL && e->left.sym == &symbol_yes); 230*0a9064fbSMasahiro Yamada } 231*0a9064fbSMasahiro Yamada 232*0a9064fbSMasahiro Yamada static inline int expr_is_no(struct expr *e) 233*0a9064fbSMasahiro Yamada { 234*0a9064fbSMasahiro Yamada return e && (e->type == E_SYMBOL && e->left.sym == &symbol_no); 235*0a9064fbSMasahiro Yamada } 236*0a9064fbSMasahiro Yamada 237*0a9064fbSMasahiro Yamada #ifdef __cplusplus 238*0a9064fbSMasahiro Yamada } 239*0a9064fbSMasahiro Yamada #endif 240*0a9064fbSMasahiro Yamada 241*0a9064fbSMasahiro Yamada #endif /* EXPR_H */ 242