blob: bf34f3f2f80bd862459c7557905d279c93bd5961 (
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
46
47
48
|
(.module:
lux
(lux (control [monad #+ do])
[macro]
(data text/format))
(luxc (lang [".L" module]
(host [python #+ Expression Statement @@])))
[//]
(// [".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-name [current-module name]]]
(case (macro.get-identifier-ann (name-of #.alias) metaV)
(#.Some real-def)
(do @
[[realT realA realV] (macro.find-def real-def)
_ (moduleL.define def-name [realT metaV realV])]
(wrap []))
_
(do @
[#let [def-name (referenceT.global def-name)]
_ (//.save (python.set! (list def-name) expressionO))
expressionV (evalT.eval (@@ def-name))
_ (moduleL.define def-name [expressionT metaV expressionV])
_ (if (macro.type? metaV)
(case (macro.declared-tags metaV)
#.Nil
(wrap [])
tags
(moduleL.declare-tags tags (macro.export? metaV) (:coerce Type expressionV)))
(wrap []))
#let [_ (log! (format "DEF " (%name def-name)))]]
(wrap []))
)))
(def: #export (translate-program programO)
(-> Expression (Meta Statement))
(macro.fail "translate-program NOT IMPLEMENTED YET")
## (hostT.save (format "var " (referenceT.variable +0) " = " runtimeT.lux//program-args "();"
## "(" programO ")(null);"))
)
|