blob: 82c355151e162491d6c55a9abc743eb687d0ec07 (
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 (analysis [";A" expression])
(synthesis [";S" expression])
(translation [";T" expression]
[";T" eval])))
[../base])
(def: #export (eval type exprC)
../base;Eval
(do meta;Monad<Meta>
[exprA (../base;with-expected-type type
(expressionA;analyser eval exprC))
#let [exprS (expressionS;synthesize exprA)]
exprI (expressionT;generate exprS)]
(evalT;eval exprI)))
|