Fixed some bugs.
[llvm/zpu.git] / examples / OCaml-Kaleidoscope / Chapter6 / ast.ml
blob99088cfd2f516d8b898f0b0a6619f89800a825e8
1 (*===----------------------------------------------------------------------===
2 * Abstract Syntax Tree (aka Parse Tree)
3 *===----------------------------------------------------------------------===*)
5 (* expr - Base type for all expression nodes. *)
6 type expr =
7 (* variant for numeric literals like "1.0". *)
8 | Number of float
10 (* variant for referencing a variable, like "a". *)
11 | Variable of string
13 (* variant for a unary operator. *)
14 | Unary of char * expr
16 (* variant for a binary operator. *)
17 | Binary of char * expr * expr
19 (* variant for function calls. *)
20 | Call of string * expr array
22 (* variant for if/then/else. *)
23 | If of expr * expr * expr
25 (* variant for for/in. *)
26 | For of string * expr * expr * expr option * expr
28 (* proto - This type represents the "prototype" for a function, which captures
29 * its name, and its argument names (thus implicitly the number of arguments the
30 * function takes). *)
31 type proto =
32 | Prototype of string * string array
33 | BinOpPrototype of string * string array * int
35 (* func - This type represents a function definition itself. *)
36 type func = Function of proto * expr