blob: 9752dd2e9b17658644bbb32443974139bbd5f3ac (
plain)
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
|
(*s Syntax for arithmetic *)
Infix 6 "<" lt.
Infix 6 "<=" le.
Infix 6 ">" gt.
Infix 6 ">=" ge.
(*i Infix 7 "+" plus. i*)
Grammar constr lassoc_constr4 :=
squash_sum
[ lassoc_constr4($c1) "+" lassoc_constr4($c2) ] ->
case [$c2] of
(SQUASH $T2) ->
case [$c1] of
(SQUASH $T1) -> [ (sumbool $T1 $T2) ] (* {T1}+{T2} *)
| $_ -> [ (sumor $c1 $T2) ] (* c1+{T2} *)
esac
| $_ -> [ (add $c1 $c2) ] (* c1+c2 *)
esac.
Syntax constr
level 4:
sum [ (add $t1 $t2) ] -> [ [<hov 0> $t1:E [0 1] "+" $t2:L ] ]
.
|