-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathprinttree.sml
64 lines (55 loc) · 2.21 KB
/
printtree.sml
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
structure Printtree :
sig val printtree : TextIO.outstream * Tree.stm -> unit end =
struct
structure T = Tree
fun printtree (outstream, s0) =
let fun say s = TextIO.output(outstream,s)
fun sayln s= (say s; say "\n")
fun indent 0 = ()
| indent i = (say " "; indent(i-1))
fun stm(T.SEQ(a,b),d) =
(indent d; sayln "SEQ("; stm(a,d+1); sayln ","; stm(b,d+1); say ")")
| stm(T.LABEL lab, d) = (indent d; say "LABEL "; say (Symbol.name lab))
| stm(T.JUMP (e,_), d) = (indent d; sayln "JUMP("; exp(e,d+1); say ")")
| stm(T.CJUMP(r,a,b,t,f),d) = (indent d; say "CJUMP(";
relop r; sayln ",";
exp(a,d+1); sayln ","; exp(b,d+1); sayln ",";
indent(d+1); say(Symbol.name t);
say ","; say (Symbol.name f); say ")")
| stm(T.MOVE(a,b),d) = (indent d; sayln "MOVE("; exp(a,d+1); sayln ",";
exp(b,d+1); say ")")
| stm(T.EXP e, d) = (indent d; sayln "EXP("; exp(e,d+1); say ")")
and exp(T.BINOP(p,a,b),d) = (indent d; say "BINOP("; binop p; sayln ",";
exp(a,d+1); sayln ","; exp(b,d+1); say ")")
| exp(T.MEM(e),d) = (indent d; sayln "MEM("; exp(e,d+1); say ")")
| exp(T.TEMP t, d) = (indent d; say "TEMP t"; say(Int.toString t))
| exp(T.ESEQ(s,e),d) = (indent d; sayln "ESEQ("; stm(s,d+1); sayln ",";
exp(e,d+1); say ")")
| exp(T.NAME lab, d) = (indent d; say "NAME "; say (Symbol.name lab))
| exp(T.CONST i, d) = (indent d; say "CONST "; say(Int.toString i))
| exp(T.CALL(e,el),d) = (indent d; sayln "CALL("; exp(e,d+1);
app (fn a => (sayln ","; exp(a,d+2))) el;
say ")")
and binop T.PLUS = say "PLUS"
| binop T.MINUS = say "MINUS"
| binop T.MUL = say "MUL"
| binop T.DIV = say "DIV"
| binop T.AND = say "AND"
| binop T.OR = say "OR"
| binop T.LSHIFT = say "LSHIFT"
| binop T.RSHIFT = say "RSHIFT"
| binop T.ARSHIFT = say "ARSHIFT"
| binop T.XOR = say "XOR"
and relop T.EQ = say "EQ"
| relop T.NE = say "NE"
| relop T.LT = say "LT"
| relop T.GT = say "GT"
| relop T.LE = say "LE"
| relop T.GE = say "GE"
| relop T.ULT = say "ULT"
| relop T.ULE = say "ULE"
| relop T.UGT = say "UGT"
| relop T.UGE = say "UGE"
in stm(s0,0); sayln ""; TextIO.flushOut outstream
end
end