f33d1e06edbc84d9afec504ebc1ddcf041c38a5a
[uebersetzerbau-ss10.git] / codea / tree.h
1 #ifndef __TREE_H
2 #define __TREE_H
3
4 #define TREENULL (struct treenode *)NULL
5 #define TREESIZE (sizeof(struct treenode))
6 #define TREECAST struct treenode *
7
8 #ifndef BFEHAX
9 typedef struct burm_state *STATEPTR_TYPE;
10 #endif
11
12 enum {
13         O_RET=1,
14         O_NULL,
15         O_SUB,
16         O_MUL,
17         O_OR,
18         O_LESS,
19         O_EQ,
20         O_ID,
21         O_ADD,
22         O_NUM,
23         O_FIELD
24 };
25
26 static char *o_names[] = {
27         "",
28         "O_RET",
29         "O_NULL",
30         "O_SUB",
31         "O_MUL",
32         "O_OR",
33         "O_LESS",
34         "O_EQ",
35         "O_ID",
36         "O_ADD",
37         "O_NUM",
38         "O_FIELD"
39 };
40
41 struct treenode {
42         int op;
43         struct treenode *kids[2];
44         STATEPTR_TYPE label;
45         char *name;
46         long val;
47         char *reg;
48         struct treenode *parent;
49         int skip;
50         int param_index;
51         int exprcount;
52         int soffset;
53 };
54
55 typedef struct treenode *treenodep;
56
57 #define NODEPTR_TYPE treenodep
58 #define OP_LABEL(p) ((p)->op)
59 #define LEFT_CHILD(p) ((p)->kids[0])
60 #define RIGHT_CHILD(p) ((p)->kids[1])
61 #define STATE_LABEL(p) ((p)->label)
62 #define PANIC printf
63
64 struct treenode *new_node(int op, struct treenode *l, struct treenode *r, int exprcount);
65 struct treenode *new_number(long val, int exprcount);
66 struct treenode *new_param(int op, char *name, struct treenode *l, struct treenode *r, int param_index, int exprcount);
67 struct treenode *new_field(char *name, struct treenode *l, struct treenode *r, int soffset, int exprcount);
68 void write_tree(struct treenode *node, int ident);
69
70 #endif