blob: cc616f1f835d860a7110d20d87db724f0e23f289 [file] [log] [blame]
Eric Andersenc9f20d92002-12-05 08:41:41 +00001/*
2 * Copyright (C) 2002 Roman Zippel <zippel@linux-m68k.org>
3 * Released under the terms of the GNU GPL v2.0.
4 */
5
6#ifndef EXPR_H
7#define EXPR_H
8
9#ifdef __cplusplus
10extern "C" {
11#endif
12
13#include <stdio.h>
14#ifndef __cplusplus
15#include <stdbool.h>
16#endif
17
18struct file {
19 struct file *next;
20 struct file *parent;
Eric Andersenc9f20d92002-12-05 08:41:41 +000021 char *name;
22 int lineno;
23 int flags;
24};
25
26#define FILE_BUSY 0x0001
27#define FILE_SCANNED 0x0002
28#define FILE_PRINTED 0x0004
29
30typedef enum tristate {
31 no, mod, yes
32} tristate;
33
34enum expr_type {
Eric Andersen72d8e442003-08-05 02:18:25 +000035 E_NONE, E_OR, E_AND, E_NOT, E_EQUAL, E_UNEQUAL, E_CHOICE, E_SYMBOL, E_RANGE
Eric Andersenc9f20d92002-12-05 08:41:41 +000036};
37
38union expr_data {
39 struct expr *expr;
40 struct symbol *sym;
41};
42
43struct expr {
Eric Andersenc9f20d92002-12-05 08:41:41 +000044 enum expr_type type;
Eric Andersenc9f20d92002-12-05 08:41:41 +000045 union expr_data left, right;
46};
47
Eric Andersenc9f20d92002-12-05 08:41:41 +000048#define E_OR(dep1, dep2) (((dep1)>(dep2))?(dep1):(dep2))
49#define E_AND(dep1, dep2) (((dep1)<(dep2))?(dep1):(dep2))
50#define E_NOT(dep) (2-(dep))
51
52struct expr_value {
53 struct expr *expr;
54 tristate tri;
55};
56
Eric Andersenc9f20d92002-12-05 08:41:41 +000057struct symbol_value {
Eric Andersen72d8e442003-08-05 02:18:25 +000058 void *val;
Eric Andersenc9f20d92002-12-05 08:41:41 +000059 tristate tri;
60};
61
62enum symbol_type {
63 S_UNKNOWN, S_BOOLEAN, S_TRISTATE, S_INT, S_HEX, S_STRING, S_OTHER
64};
65
66struct symbol {
67 struct symbol *next;
68 char *name;
69 char *help;
Eric Andersenc9f20d92002-12-05 08:41:41 +000070 enum symbol_type type;
Eric Andersen72d8e442003-08-05 02:18:25 +000071 struct symbol_value curr, user;
Eric Andersenc9f20d92002-12-05 08:41:41 +000072 tristate visible;
73 int flags;
74 struct property *prop;
75 struct expr *dep, *dep2;
Eric Andersen72d8e442003-08-05 02:18:25 +000076 struct expr_value rev_dep;
Eric Andersenc9f20d92002-12-05 08:41:41 +000077};
78
79#define for_all_symbols(i, sym) for (i = 0; i < 257; i++) for (sym = symbol_hash[i]; sym; sym = sym->next) if (sym->type != S_OTHER)
80
Eric Andersenc9f20d92002-12-05 08:41:41 +000081#define SYMBOL_YES 0x0001
82#define SYMBOL_MOD 0x0002
83#define SYMBOL_NO 0x0004
84#define SYMBOL_CONST 0x0007
85#define SYMBOL_CHECK 0x0008
86#define SYMBOL_CHOICE 0x0010
87#define SYMBOL_CHOICEVAL 0x0020
88#define SYMBOL_PRINTED 0x0040
89#define SYMBOL_VALID 0x0080
90#define SYMBOL_OPTIONAL 0x0100
91#define SYMBOL_WRITE 0x0200
92#define SYMBOL_CHANGED 0x0400
93#define SYMBOL_NEW 0x0800
94#define SYMBOL_AUTO 0x1000
Eric Andersen72d8e442003-08-05 02:18:25 +000095#define SYMBOL_CHECKED 0x2000
96#define SYMBOL_CHECK_DONE 0x4000
97#define SYMBOL_WARNED 0x8000
Eric Andersenc9f20d92002-12-05 08:41:41 +000098
99#define SYMBOL_MAXLENGTH 256
100#define SYMBOL_HASHSIZE 257
101#define SYMBOL_HASHMASK 0xff
102
103enum prop_type {
Eric Andersen72d8e442003-08-05 02:18:25 +0000104 P_UNKNOWN, P_PROMPT, P_COMMENT, P_MENU, P_DEFAULT, P_CHOICE, P_SELECT, P_RANGE
Eric Andersenc9f20d92002-12-05 08:41:41 +0000105};
106
107struct property {
108 struct property *next;
109 struct symbol *sym;
Eric Andersenc9f20d92002-12-05 08:41:41 +0000110 enum prop_type type;
Eric Andersenc9f20d92002-12-05 08:41:41 +0000111 const char *text;
Eric Andersenc9f20d92002-12-05 08:41:41 +0000112 struct expr_value visible;
Eric Andersen72d8e442003-08-05 02:18:25 +0000113 struct expr *expr;
Eric Andersenc9f20d92002-12-05 08:41:41 +0000114 struct menu *menu;
115 struct file *file;
116 int lineno;
Eric Andersenc9f20d92002-12-05 08:41:41 +0000117};
118
119#define for_all_properties(sym, st, tok) \
120 for (st = sym->prop; st; st = st->next) \
121 if (st->type == (tok))
Eric Andersenc9f20d92002-12-05 08:41:41 +0000122#define for_all_defaults(sym, st) for_all_properties(sym, st, P_DEFAULT)
123#define for_all_choices(sym, st) for_all_properties(sym, st, P_CHOICE)
Eric Andersen72d8e442003-08-05 02:18:25 +0000124#define for_all_prompts(sym, st) \
125 for (st = sym->prop; st; st = st->next) \
126 if (st->text)
Eric Andersenc9f20d92002-12-05 08:41:41 +0000127
128struct menu {
129 struct menu *next;
130 struct menu *parent;
131 struct menu *list;
132 struct symbol *sym;
133 struct property *prompt;
134 struct expr *dep;
Eric Andersen72d8e442003-08-05 02:18:25 +0000135 unsigned int flags;
Eric Andersenc9f20d92002-12-05 08:41:41 +0000136 //char *help;
137 struct file *file;
138 int lineno;
139 void *data;
140};
141
Eric Andersen72d8e442003-08-05 02:18:25 +0000142#define MENU_CHANGED 0x0001
143#define MENU_ROOT 0x0002
144
Eric Andersenc9f20d92002-12-05 08:41:41 +0000145#ifndef SWIG
146
147extern struct file *file_list;
148extern struct file *current_file;
149struct file *lookup_file(const char *name);
150
151extern struct symbol symbol_yes, symbol_no, symbol_mod;
152extern struct symbol *modules_sym;
153extern int cdebug;
Eric Andersenc9f20d92002-12-05 08:41:41 +0000154struct expr *expr_alloc_symbol(struct symbol *sym);
Eric Andersenc9f20d92002-12-05 08:41:41 +0000155struct expr *expr_alloc_one(enum expr_type type, struct expr *ce);
156struct expr *expr_alloc_two(enum expr_type type, struct expr *e1, struct expr *e2);
157struct expr *expr_alloc_comp(enum expr_type type, struct symbol *s1, struct symbol *s2);
Eric Andersenc9f20d92002-12-05 08:41:41 +0000158struct expr *expr_alloc_and(struct expr *e1, struct expr *e2);
Eric Andersen72d8e442003-08-05 02:18:25 +0000159struct expr *expr_alloc_or(struct expr *e1, struct expr *e2);
Eric Andersenc9f20d92002-12-05 08:41:41 +0000160struct expr *expr_copy(struct expr *org);
161void expr_free(struct expr *e);
162int expr_eq(struct expr *e1, struct expr *e2);
163void expr_eliminate_eq(struct expr **ep1, struct expr **ep2);
164tristate expr_calc_value(struct expr *e);
165struct expr *expr_eliminate_yn(struct expr *e);
166struct expr *expr_trans_bool(struct expr *e);
167struct expr *expr_eliminate_dups(struct expr *e);
168struct expr *expr_transform(struct expr *e);
169int expr_contains_symbol(struct expr *dep, struct symbol *sym);
170bool expr_depends_symbol(struct expr *dep, struct symbol *sym);
171struct expr *expr_extract_eq_and(struct expr **ep1, struct expr **ep2);
172struct expr *expr_extract_eq_or(struct expr **ep1, struct expr **ep2);
173void expr_extract_eq(enum expr_type type, struct expr **ep, struct expr **ep1, struct expr **ep2);
174struct expr *expr_trans_compare(struct expr *e, enum expr_type type, struct symbol *sym);
175
176void expr_fprint(struct expr *e, FILE *out);
177void print_expr(int mask, struct expr *e, int prevtoken);
178
Eric Andersenc9f20d92002-12-05 08:41:41 +0000179static inline int expr_is_yes(struct expr *e)
180{
181 return !e || (e->type == E_SYMBOL && e->left.sym == &symbol_yes);
182}
183
184static inline int expr_is_no(struct expr *e)
185{
186 return e && (e->type == E_SYMBOL && e->left.sym == &symbol_no);
187}
188#endif
Eric Andersenc9f20d92002-12-05 08:41:41 +0000189
190#ifdef __cplusplus
191}
192#endif
193
194#endif /* EXPR_H */