-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathminiml_parse.mly
79 lines (71 loc) · 2.46 KB
/
miniml_parse.mly
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
(*
CS 51 Final Project
MiniML -- Parser
*)
%{
open Expr ;;
%}
%token EOF
%token OPEN CLOSE
%token LET DOT IN REC
%token NEGATE FLOATNEGATE
%token SIN COS TAN
%token PLUS FLOATPLUS MINUS FLOATMINUS
%token TIMES FLOATTIMES DIVIDE FLOATDIVIDE
%token POWER
%token LESSTHAN EQUALS GREATERTHAN
%token IF THEN ELSE
%token FUNCTION
%token RAISE
%token <string> ID
%token <int> INT
%token <float> FLOAT
%token <string> STRING
%token UNIT
%token TRUE FALSE
%nonassoc IF
%left LESSTHAN EQUALS GREATERTHAN
%left PLUS FLOATPLUS MINUS FLOATMINUS
%left TIMES FLOATTIMES DIVIDE FLOATDIVIDE
%right POWER
%nonassoc NEGATE FLOATNEGATE
%nonassoc SIN COS TAN
%start input
%type <Expr.expr> input
(* Grammar follows *)
%%
input: exp EOF { $1 }
exp: exp expnoapp { App($1, $2) }
| expnoapp { $1 }
expnoapp: INT { Num $1 }
| FLOAT { Float $1 }
| STRING { String $1 }
| TRUE { Bool true }
| FALSE { Bool false }
| ID { Var $1 }
| exp PLUS exp { Binop(Plus, $1, $3) }
| exp FLOATPLUS exp { Binop(FloatPlus, $1, $3) }
| exp MINUS exp { Binop(Minus, $1, $3) }
| exp FLOATMINUS exp { Binop(FloatMinus, $1, $3) }
| exp TIMES exp { Binop(Times, $1, $3) }
| exp FLOATTIMES exp { Binop(FloatTimes, $1, $3) }
| exp DIVIDE exp { Binop(Divide, $1, $3) }
| exp FLOATDIVIDE exp { Binop(FloatDivide, $1, $3) }
| exp POWER exp { Binop(Power, $1, $3) }
| exp EQUALS exp { Binop(Equals, $1, $3) }
| exp LESSTHAN exp { Binop(LessThan, $1, $3) }
| exp GREATERTHAN exp { Binop(GreaterThan, $1, $3) }
| NEGATE exp { Unop(Negate, $2) }
| FLOATNEGATE exp { Unop(FloatNegate, $2) }
| SIN exp { Unop(Sin, $2) }
| COS exp { Unop(Cos, $2) }
| TAN exp { Unop(Tan, $2) }
| IF exp THEN exp ELSE exp { Conditional($2, $4, $6) }
| LET ID EQUALS exp IN exp { Let($2, $4, $6) }
| LET REC ID EQUALS exp IN exp { Letrec($3, $5, $7) }
| FUNCTION ID DOT exp { Fun($2, $4) }
| RAISE { Raise }
| OPEN exp CLOSE { $2 }
| UNIT { Unit }
;
%%