12 extern const char *fieldspec_str
[];
13 extern const char *binop_str
[];
14 extern const char *unop_str
[];
37 //NOTE: DON'T CHANGE THIS ORDER
38 enum {dcomp
, dvardecl
, dfundecl
} type
;
42 struct fundecl
**decls
;
50 enum {sassign
, sif
, sreturn
, sexpr
, svardecl
, swhile
} type
;
65 struct vardecl
*svardecl
;
77 binor
, binand
, eq
, neq
, leq
, le
, geq
, ge
, cons
, plus
, minus
, times
,
78 divide
, modulo
, power
,
80 enum fieldspec
{fst
,snd
,hd
,tl
};
81 enum unop
{negate
,inverse
};
83 enum {ebinop
, ebool
, echar
, efuncall
, eident
, eint
, enil
, etuple
,
98 enum fieldspec
*fields
;
104 enum fieldspec
*fields
;
121 struct ast
*ast(struct list
*decls
);
123 struct vardecl
*vardecl(struct type
*type
, char *ident
, struct expr
*expr
);
124 struct fundecl
*fundecl(char *ident
, struct list
*args
, struct list
*atypes
,
125 struct type
*rtype
, struct list
*body
);
127 struct decl
*decl_fun(struct fundecl
*fundecl
);
128 struct decl
*decl_var(struct vardecl
*vardecl
);
130 struct stmt
*stmt_assign(char *ident
, struct list
*fields
, struct expr
*expr
);
131 struct stmt
*stmt_if(struct expr
*pred
, struct list
*then
, struct list
*els
);
132 struct stmt
*stmt_return(struct expr
*rtrn
);
133 struct stmt
*stmt_expr(struct expr
*expr
);
134 struct stmt
*stmt_vardecl(struct vardecl
*vardecl
);
135 struct stmt
*stmt_while(struct expr
*pred
, struct list
*body
);
137 struct expr
*expr_binop(struct expr
*l
, enum binop op
, struct expr
*r
);
138 struct expr
*expr_bool(bool b
);
139 struct expr
*expr_char(char *c
);
140 struct expr
*expr_funcall(char *ident
, struct list
*args
, struct list
*fields
);
141 struct expr
*expr_int(int integer
);
142 struct expr
*expr_ident(char *ident
, struct list
*fields
);
143 struct expr
*expr_nil();
144 struct expr
*expr_tuple(struct expr
*left
, struct expr
*right
);
145 struct expr
*expr_string(char *str
);
146 struct expr
*expr_unop(enum unop op
, struct expr
*l
);
148 void ast_print(struct ast
*, FILE *out
);
149 void vardecl_print(struct vardecl
*decl
, int indent
, FILE *out
);
150 void fundecl_print(struct fundecl
*decl
, FILE *out
);
151 void decl_print(struct decl
*ast
, FILE *out
);
152 void stmt_print(struct stmt
*ast
, int indent
, FILE *out
);
153 void expr_print(struct expr
*ast
, FILE *out
);
155 void ast_free(struct ast
*);
156 void vardecl_free(struct vardecl
*decl
);
157 void fundecl_free(struct fundecl
*fundecl
);
158 void decl_free(struct decl
*ast
);
159 void stmt_free(struct stmt
*ast
);
160 void expr_free(struct expr
*ast
);