blob: 20c3acaeb5097befe3c18fd4ce9426301e963e67 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
(;module:
lux
(lux (control [monad #+ do])
[meta])
(luxc ["&" lang]
(lang (analysis [";A" expression])
(synthesis [";S" expression])
(translation [";T" expression]
[";T" eval]))))
(def: #export (eval type exprC)
&;Eval
(do meta;Monad<Meta>
[exprA (&;with-expected-type type
(expressionA;analyser eval exprC))
#let [exprS (expressionS;synthesize exprA)]
exprI (expressionT;translate exprS)]
(evalT;eval exprI)))
|