9778d367b695d84c9644c9a5791ad1a77c067677
[cparser] / ast_t.h
1 #ifndef AST_T_H
2 #define AST_T_H
3
4 #include "ast.h"
5 #include "symbol.h"
6 #include "token_t.h"
7 #include "type.h"
8 #include "adt/obst.h"
9
10 extern struct obstack ast_obstack;
11
12 typedef enum {
13         EXPR_INVALID = 0,
14         EXPR_REFERENCE,
15         EXPR_CONST,
16         EXPR_STRING_LITERAL,
17         EXPR_CALL,
18         EXPR_UNARY,
19         EXPR_BINARY,
20         EXPR_CONDITIONAL,
21         EXPR_SELECT,
22         EXPR_ARRAY_ACCESS,
23         EXPR_SIZEOF,
24
25         EXPR_FUNCTION,
26         EXPR_PRETTY_FUNCTION,
27         EXPR_BUILTIN_SYMBOL,
28         EXPR_OFFSETOF,
29         EXPR_VA_ARG,
30         EXPR_STATEMENT
31 } expresion_type_t;
32
33 struct context_t {
34         declaration_t   *declarations;
35         compound_type_t *structs;
36         compound_type_t *unions;
37         enum_type_t     *enums;
38 };
39
40 struct expression_t {
41         expresion_type_t   type;
42         type_t            *datatype;
43         source_position_t  source_position;
44 };
45
46 struct const_t {
47         expression_t  expression;
48         union {
49                 int         int_value;
50                 long double float_value;
51         } v;
52 };
53
54 struct string_literal_t {
55         expression_t  expression;
56         const char   *value;
57 };
58
59 struct builtin_symbol_expression_t {
60         expression_t  expression;
61         symbol_t     *symbol;
62 };
63
64 struct reference_expression_t {
65         expression_t   expression;
66         symbol_t      *symbol;
67         declaration_t *declaration;
68 };
69
70 struct call_argument_t {
71         expression_t    *expression;
72         call_argument_t *next;
73 };
74
75 struct call_expression_t {
76         expression_t     expression;
77         expression_t    *method;
78         call_argument_t *arguments;
79 };
80
81 typedef enum {
82         UNEXPR_INVALID = 0,
83         UNEXPR_NEGATE,
84         UNEXPR_PLUS,
85         UNEXPR_BITWISE_NEGATE,
86         UNEXPR_NOT,
87         UNEXPR_DEREFERENCE,
88         UNEXPR_TAKE_ADDRESS,
89         UNEXPR_POSTFIX_INCREMENT,
90         UNEXPR_POSTFIX_DECREMENT,
91         UNEXPR_PREFIX_INCREMENT,
92         UNEXPR_PREFIX_DECREMENT,
93         UNEXPR_CAST
94 } unary_expression_type_t;
95
96 struct unary_expression_t {
97         expression_t             expression;
98         unary_expression_type_t  type;
99         expression_t            *value;
100 };
101
102 typedef enum {
103         BINEXPR_INVALID = 0,
104         BINEXPR_ADD,
105         BINEXPR_SUB,
106         BINEXPR_MUL,
107         BINEXPR_DIV,
108         BINEXPR_MOD,
109         BINEXPR_EQUAL,
110         BINEXPR_NOTEQUAL,
111         BINEXPR_LESS,
112         BINEXPR_LESSEQUAL,
113         BINEXPR_GREATER,
114         BINEXPR_GREATEREQUAL,
115         BINEXPR_BITWISE_AND,
116         BINEXPR_BITWISE_OR,
117         BINEXPR_BITWISE_XOR,
118         BINEXPR_LOGICAL_AND,
119         BINEXPR_LOGICAL_OR,
120         BINEXPR_SHIFTLEFT,
121         BINEXPR_SHIFTRIGHT,
122         BINEXPR_ASSIGN,
123         BINEXPR_MUL_ASSIGN,
124         BINEXPR_DIV_ASSIGN,
125         BINEXPR_MOD_ASSIGN,
126         BINEXPR_ADD_ASSIGN,
127         BINEXPR_SUB_ASSIGN,
128         BINEXPR_SHIFTLEFT_ASSIGN,
129         BINEXPR_SHIFTRIGHT_ASSIGN,
130         BINEXPR_BITWISE_AND_ASSIGN,
131         BINEXPR_BITWISE_XOR_ASSIGN,
132         BINEXPR_BITWISE_OR_ASSIGN,
133         BINEXPR_COMMA
134 } binary_expression_type_t;
135
136 struct binary_expression_t {
137         expression_t              expression;
138         binary_expression_type_t  type;
139         expression_t             *left;
140         expression_t             *right;
141 };
142
143 struct select_expression_t {
144         expression_t   expression;
145         expression_t  *compound;
146         symbol_t      *symbol;
147
148         declaration_t *compound_entry;
149 };
150
151 struct array_access_expression_t {
152         expression_t  expression;
153         expression_t *array_ref;
154         expression_t *index;
155 };
156
157 struct sizeof_expression_t {
158         expression_t  expression;
159         type_t       *type;
160         expression_t *size_expression;
161 };
162
163 struct designator_t {
164         symbol_t     *symbol;
165         expression_t *array_access;
166         designator_t *next;
167 };
168
169 struct offsetof_expression_t {
170         expression_t  expression;
171         type_t       *type;
172         designator_t *designator;
173 };
174
175 struct va_arg_expression_t {
176         expression_t  expression;
177         expression_t *arg;
178         type_t       *type;
179 };
180
181 struct conditional_expression_t {
182         expression_t  expression;
183         expression_t *condition;
184         expression_t *true_expression;
185         expression_t *false_expression;
186 };
187
188 struct statement_expression_t {
189         expression_t  expression;
190         statement_t  *statement;
191 };
192
193 typedef enum {
194         STORAGE_CLASS_NONE,
195         STORAGE_CLASS_TYPEDEF,
196         STORAGE_CLASS_EXTERN,
197         STORAGE_CLASS_STATIC,
198         STORAGE_CLASS_AUTO,
199         STORAGE_CLASS_REGISTER,
200         STORAGE_CLASS_ENUM_ENTRY
201 } storage_class_t;
202
203 typedef enum {
204         INITIALIZER_VALUE,
205         INITIALIZER_LIST,
206 } initializer_type_t;
207
208 struct initializer_t {
209         initializer_type_t type;
210         designator_t      *designator;
211         union {
212                 initializer_t *list;
213                 expression_t  *value;
214         } v;
215         initializer_t *next;
216 };
217
218 struct declaration_t {
219         storage_class_t     storage_class;
220         type_t             *type;
221         symbol_t           *symbol;
222         statement_t        *statement;
223         initializer_t      *initializer;
224         source_position_t   source_position;
225         context_t           context;
226
227         declaration_t      *next;
228 };
229
230 typedef enum {
231         STATEMENT_INVALID,
232         STATEMENT_COMPOUND,
233         STATEMENT_RETURN,
234         STATEMENT_DECLARATION,
235         STATEMENT_IF,
236         STATEMENT_SWITCH,
237         STATEMENT_EXPRESSION,
238         STATEMENT_CONTINUE,
239         STATEMENT_BREAK,
240         STATEMENT_GOTO,
241         STATEMENT_LABEL,
242         STATEMENT_CASE_LABEL,
243         STATEMENT_WHILE,
244         STATEMENT_DO_WHILE,
245         STATEMENT_FOR
246 } statement_type_t;
247
248 struct statement_t {
249         statement_type_t   type;
250         statement_t       *next;
251         source_position_t  source_position;
252 };
253
254 struct return_statement_t {
255         statement_t   statement;
256         expression_t *return_value;
257 };
258
259 struct compound_statement_t {
260         statement_t  statement;
261         statement_t *statements;
262         context_t    context;
263 };
264
265 struct declaration_statement_t {
266         statement_t    statement;
267         declaration_t *declarations_begin;
268         declaration_t *declarations_end;
269
270         int            value_number; /**< filled in by semantic phase */
271         int            refs;
272 };
273
274 struct if_statement_t {
275         statement_t   statement;
276         expression_t *condition;
277         statement_t  *true_statement;
278         statement_t  *false_statement;
279 };
280
281 struct switch_statement_t {
282         statement_t   statement;
283         expression_t *expression;
284         statement_t  *body;
285 };
286
287 struct goto_statement_t {
288         statement_t        statement;
289         symbol_t          *label_symbol;
290         label_statement_t *label;
291 };
292
293 struct case_label_statement_t {
294         statement_t   statement;
295         expression_t *expression;
296 };
297
298 struct label_statement_t {
299         statement_t        statement;
300         symbol_t          *symbol;
301 };
302
303 struct expression_statement_t {
304         statement_t   statement;
305         expression_t *expression;
306 };
307
308 struct while_statement_t {
309         statement_t   statement;
310         expression_t *condition;
311         statement_t  *body;
312 };
313
314 struct do_while_statement_t {
315         statement_t   statement;
316         expression_t *condition;
317         statement_t  *body;
318 };
319
320 struct for_statement_t {
321         statement_t   statement;
322         expression_t  *initialisation;
323         expression_t  *condition;
324         expression_t  *step;
325         statement_t   *body;
326         context_t      context;
327 };
328
329 struct translation_unit_t {
330         context_t context;
331 };
332
333 static inline
334 void *_allocate_ast(size_t size)
335 {
336         return obstack_alloc(&ast_obstack, size);
337 }
338
339 #define allocate_ast(size)                 _allocate_ast(size)
340
341 #endif