Mercurial > hg-old > index.cgi
annotate lwasm/expr.h @ 276:23034db7dd8a 2.5
fixed expression 'slots' to not store null on a pass 1 store
author | lost |
---|---|
date | Mon, 31 Aug 2009 08:39:36 +0000 |
parents | 427e268e876b |
children |
rev | line source |
---|---|
13
05d4115b4860
Started work on new expression evaluator system and major code re-work for next release
lost
parents:
diff
changeset
|
1 /* |
05d4115b4860
Started work on new expression evaluator system and major code re-work for next release
lost
parents:
diff
changeset
|
2 expr.h |
05d4115b4860
Started work on new expression evaluator system and major code re-work for next release
lost
parents:
diff
changeset
|
3 Copyright © 2008 William Astle |
05d4115b4860
Started work on new expression evaluator system and major code re-work for next release
lost
parents:
diff
changeset
|
4 |
05d4115b4860
Started work on new expression evaluator system and major code re-work for next release
lost
parents:
diff
changeset
|
5 This file is part of LWASM. |
05d4115b4860
Started work on new expression evaluator system and major code re-work for next release
lost
parents:
diff
changeset
|
6 |
05d4115b4860
Started work on new expression evaluator system and major code re-work for next release
lost
parents:
diff
changeset
|
7 LWASM is free software: you can redistribute it and/or modify it under the |
05d4115b4860
Started work on new expression evaluator system and major code re-work for next release
lost
parents:
diff
changeset
|
8 terms of the GNU General Public License as published by the Free Software |
05d4115b4860
Started work on new expression evaluator system and major code re-work for next release
lost
parents:
diff
changeset
|
9 Foundation, either version 3 of the License, or (at your option) any later |
05d4115b4860
Started work on new expression evaluator system and major code re-work for next release
lost
parents:
diff
changeset
|
10 version. |
05d4115b4860
Started work on new expression evaluator system and major code re-work for next release
lost
parents:
diff
changeset
|
11 |
05d4115b4860
Started work on new expression evaluator system and major code re-work for next release
lost
parents:
diff
changeset
|
12 This program is distributed in the hope that it will be useful, but WITHOUT |
05d4115b4860
Started work on new expression evaluator system and major code re-work for next release
lost
parents:
diff
changeset
|
13 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
05d4115b4860
Started work on new expression evaluator system and major code re-work for next release
lost
parents:
diff
changeset
|
14 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for |
05d4115b4860
Started work on new expression evaluator system and major code re-work for next release
lost
parents:
diff
changeset
|
15 more details. |
05d4115b4860
Started work on new expression evaluator system and major code re-work for next release
lost
parents:
diff
changeset
|
16 |
05d4115b4860
Started work on new expression evaluator system and major code re-work for next release
lost
parents:
diff
changeset
|
17 You should have received a copy of the GNU General Public License along with |
05d4115b4860
Started work on new expression evaluator system and major code re-work for next release
lost
parents:
diff
changeset
|
18 this program. If not, see <http://www.gnu.org/licenses/>. |
05d4115b4860
Started work on new expression evaluator system and major code re-work for next release
lost
parents:
diff
changeset
|
19 */ |
05d4115b4860
Started work on new expression evaluator system and major code re-work for next release
lost
parents:
diff
changeset
|
20 |
05d4115b4860
Started work on new expression evaluator system and major code re-work for next release
lost
parents:
diff
changeset
|
21 /* |
15 | 22 Definitions for expression evaluator |
13
05d4115b4860
Started work on new expression evaluator system and major code re-work for next release
lost
parents:
diff
changeset
|
23 */ |
05d4115b4860
Started work on new expression evaluator system and major code re-work for next release
lost
parents:
diff
changeset
|
24 |
05d4115b4860
Started work on new expression evaluator system and major code re-work for next release
lost
parents:
diff
changeset
|
25 #ifndef __expr_h_seen__ |
05d4115b4860
Started work on new expression evaluator system and major code re-work for next release
lost
parents:
diff
changeset
|
26 #define __expr_h_seen__ |
05d4115b4860
Started work on new expression evaluator system and major code re-work for next release
lost
parents:
diff
changeset
|
27 |
14 | 28 #ifndef __expr_c_seen__ |
15 | 29 #define __expr_E__ extern |
14 | 30 #else |
15 | 31 #define __expr_E__ |
14 | 32 #endif |
33 | |
17 | 34 // term types |
35 #define LWASM_TERM_NONE 0 | |
36 #define LWASM_TERM_OPER 1 // an operator | |
37 #define LWASM_TERM_INT 2 // 32 bit signed integer | |
38 #define LWASM_TERM_SYM 3 // symbol reference | |
91
718998b673ee
Added incomplete references to object output and added support for section base terms in expression handler
lost
parents:
76
diff
changeset
|
39 #define LWASM_TERM_SECBASE 4 // section base reference |
17 | 40 |
41 // operator types | |
42 #define LWASM_OPER_NONE 0 | |
43 #define LWASM_OPER_PLUS 1 // + | |
44 #define LWASM_OPER_MINUS 2 // - | |
45 #define LWASM_OPER_TIMES 3 // * | |
46 #define LWASM_OPER_DIVIDE 4 // / | |
47 #define LWASM_OPER_MOD 5 // % | |
18 | 48 #define LWASM_OPER_INTDIV 6 // \ (don't end line with \) |
17 | 49 #define LWASM_OPER_BWAND 7 // bitwise AND |
50 #define LWASM_OPER_BWOR 8 // bitwise OR | |
51 #define LWASM_OPER_BWXOR 9 // bitwise XOR | |
52 #define LWASM_OPER_AND 10 // boolean AND | |
53 #define LWASM_OPER_OR 11 // boolean OR | |
23 | 54 #define LWASM_OPER_NEG 12 // - unary negation (2's complement) |
55 #define LWASM_OPER_COM 13 // ^ unary 1's complement | |
17 | 56 |
14 | 57 |
17 | 58 // term structure |
59 typedef struct lwasm_expr_term_s | |
60 { | |
61 int term_type; // type of term (see above) | |
62 char *symbol; // name of a symbol | |
63 int value; // value of the term (int) or operator number (OPER) | |
64 } lwasm_expr_term_t; | |
65 | |
66 // type for an expression evaluation stack | |
67 typedef struct lwasm_expr_stack_node_s lwasm_expr_stack_node_t; | |
68 struct lwasm_expr_stack_node_s | |
69 { | |
70 lwasm_expr_term_t *term; | |
71 lwasm_expr_stack_node_t *prev; | |
72 lwasm_expr_stack_node_t *next; | |
73 }; | |
74 | |
75 typedef struct lwasm_expr_stack_s | |
76 { | |
77 lwasm_expr_stack_node_t *head; | |
78 lwasm_expr_stack_node_t *tail; | |
79 } lwasm_expr_stack_t; | |
80 | |
81 __expr_E__ void lwasm_expr_term_free(lwasm_expr_term_t *t); | |
82 __expr_E__ lwasm_expr_term_t *lwasm_expr_term_create_oper(int oper); | |
83 __expr_E__ lwasm_expr_term_t *lwasm_expr_term_create_sym(char *sym); | |
84 __expr_E__ lwasm_expr_term_t *lwasm_expr_term_create_int(int val); | |
91
718998b673ee
Added incomplete references to object output and added support for section base terms in expression handler
lost
parents:
76
diff
changeset
|
85 __expr_E__ lwasm_expr_term_t *lwasm_expr_term_create_secbase(void); |
17 | 86 __expr_E__ lwasm_expr_term_t *lwasm_expr_term_dup(lwasm_expr_term_t *t); |
87 | |
88 __expr_E__ void lwasm_expr_stack_free(lwasm_expr_stack_t *s); | |
89 __expr_E__ lwasm_expr_stack_t *lwasm_expr_stack_create(void); | |
90 | |
91 __expr_E__ void lwasm_expr_stack_push(lwasm_expr_stack_t *s, lwasm_expr_term_t *t); | |
92 __expr_E__ lwasm_expr_term_t *lwasm_expr_stack_pop(lwasm_expr_stack_t *s); | |
13
05d4115b4860
Started work on new expression evaluator system and major code re-work for next release
lost
parents:
diff
changeset
|
93 |
18 | 94 /* |
95 Evaluate an expression. The result is an lwasm_expr_stack_t pointer. If the | |
96 expression evaluates to a constant result, the stack will contain exactly one | |
97 value which will be a constant. Otherwise, the stack will contain the | |
98 expression with all operations that can be evaluated completely evaluated. | |
99 You must call lwasm_expr_stack_free() on the result when you are finished | |
100 with it. | |
101 */ | |
76 | 102 __expr_E__ lwasm_expr_stack_t *lwasm_expr_eval(const char *inp, const char **outp, lwasm_expr_stack_t *(*sfunc)(char *sym, void *state), void *state); |
18 | 103 |
104 // simplify expression | |
76 | 105 __expr_E__ int lwasm_expr_reval(lwasm_expr_stack_t *s, lwasm_expr_stack_t *(*sfunc)(char *sym, void *state), void *state); |
18 | 106 |
107 // useful macros | |
108 // is the expression "simple" (one term)? | |
109 #define lwasm_expr_is_simple(s) ((s) -> head == (s) -> tail) | |
110 | |
111 // is the expression constant? | |
67 | 112 #define lwasm_expr_is_constant(s) (lwasm_expr_is_simple(s) && (!((s) -> head) || (s) -> head -> term -> term_type == LWASM_TERM_INT)) |
18 | 113 |
114 // get the constant value of an expression or 0 if not constant | |
67 | 115 #define lwasm_expr_get_value(s) (lwasm_expr_is_constant(s) ? ((s) -> head ? (s) -> head -> term -> value : 0) : 0) |
18 | 116 |
15 | 117 #undef __expr_E__ |
118 | |
119 #endif // __expr_h_seen__ |