24f1a3ae4c0cf5bb706caaf93a8f3b943e7ba7a8
[uebersetzerbau-ss10.git] / codeb / 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, O_NULL, O_SUB, O_MUL,
14         O_OR=5, O_LESS, O_EQ, O_ID, O_ADD,
15         O_NUM=10, O_FIELD, O_MTWO, O_MFOUR, O_MEIGHT,
16         O_MONE=15
17 };
18
19 static char *o_names[] = {
20         "", "O_RET", "O_NULL", "O_SUB", "O_MUL",
21         "O_OR", "O_LESS", "O_EQ", "O_ID", "O_ADD",
22         "O_NUM", "O_FIELD", "O_MTWO", "O_MFOUR", "O_MEIGHT",
23         "O_MONE"
24 };
25
26 struct treenode {
27         int op;
28         struct treenode *kids[2];
29         STATEPTR_TYPE label;
30         char *name;
31         long val;
32         char *reg;
33         struct treenode *parent;
34         int param_index;
35         int soffset;
36 };
37
38 typedef struct treenode *treenodep;
39
40 #define NODEPTR_TYPE treenodep
41 #define OP_LABEL(p) ((p)->op)
42 #define LEFT_CHILD(p) ((p)->kids[0])
43 #define RIGHT_CHILD(p) ((p)->kids[1])
44 #define STATE_LABEL(p) ((p)->label)
45 #define PANIC printf
46
47 struct treenode *new_node(int op, struct treenode *l, struct treenode *r);
48 struct treenode *new_number(long val);
49 struct treenode *new_param(int op, char *name, struct treenode *l, struct treenode *r, int param_index);
50 struct treenode *new_field(char *name, struct treenode *l, struct treenode *r, int soffset);
51 void write_tree(struct treenode *node, int ident);
52
53 #endif