blob: 62349abcf3ff4f8c07c47efa13406a1ce4db2dc8 (
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
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
|
(.module:
lux
(lux (control [monad #+ do])
[macro]
(data text/format))
(luxc (lang [".L" module]
(host [r #+ Expression @@])))
[//]
(// [".T" runtime]
[".T" reference]
[".T" eval]))
(def: #export (translate-def name expressionT expressionO metaV)
(-> Text Type Expression Code (Meta Any))
(do macro.Monad<Meta>
[current-module macro.current-module-name
#let [def-ident [current-module name]]]
(case (macro.get-symbol-ann (ident-for #.alias) metaV)
(#.Some real-def)
(do @
[[realT realA realV] (macro.find-def real-def)
_ (moduleL.define def-ident [realT metaV realV])]
(wrap []))
_
(do @
[#let [def-name (referenceT.global def-ident)]
_ (//.save (r.set! def-name expressionO))
expressionV (evalT.eval (@@ def-name))
_ (moduleL.define def-ident [expressionT metaV expressionV])
_ (if (macro.type? metaV)
(case (macro.declared-tags metaV)
#.Nil
(wrap [])
tags
(moduleL.declare-tags tags (macro.export? metaV) (:! Type expressionV)))
(wrap []))
#let [_ (log! (format "DEF " (%ident def-ident)))]]
(wrap []))
)))
(def: #export (translate-program programO)
(-> Expression (Meta Expression))
(macro.fail "translate-program NOT IMPLEMENTED YET"))
|