aboutsummaryrefslogtreecommitdiff
path: root/stdlib/source/lux/tool
diff options
context:
space:
mode:
authorEduardo Julian2019-03-02 23:55:31 -0400
committerEduardo Julian2019-03-02 23:55:31 -0400
commitd117adb8fd8869cdff9c9ba0f9e5f14304c285d8 (patch)
tree920044c08b9262a728dca183d216c7c87f7a68a7 /stdlib/source/lux/tool
parent8a629bbbb0bd4950fb0f3c6d14c1a9a0ba057174 (diff)
Small fixes and improvements.
Diffstat (limited to 'stdlib/source/lux/tool')
-rw-r--r--stdlib/source/lux/tool/compiler/phase/translation/common/reference.lux2
-rw-r--r--stdlib/source/lux/tool/compiler/phase/translation/js/case.lux9
-rw-r--r--stdlib/source/lux/tool/compiler/phase/translation/js/function.lux2
-rw-r--r--stdlib/source/lux/tool/compiler/phase/translation/js/runtime.lux25
-rw-r--r--stdlib/source/lux/tool/compiler/phase/translation/js/structure.lux5
5 files changed, 20 insertions, 23 deletions
diff --git a/stdlib/source/lux/tool/compiler/phase/translation/common/reference.lux b/stdlib/source/lux/tool/compiler/phase/translation/common/reference.lux
index 033effdfe..7cd24b23d 100644
--- a/stdlib/source/lux/tool/compiler/phase/translation/common/reference.lux
+++ b/stdlib/source/lux/tool/compiler/phase/translation/common/reference.lux
@@ -32,7 +32,7 @@
(All [expression]
(-> Text (-> Text expression)
(-> Register expression)))
- (|>> .int %i (format prefix) variable))
+ (|>> %n (format prefix) variable))
(def: #export foreign
(All [expression]
diff --git a/stdlib/source/lux/tool/compiler/phase/translation/js/case.lux b/stdlib/source/lux/tool/compiler/phase/translation/js/case.lux
index 0eee5383b..499486ff9 100644
--- a/stdlib/source/lux/tool/compiler/phase/translation/js/case.lux
+++ b/stdlib/source/lux/tool/compiler/phase/translation/js/case.lux
@@ -32,10 +32,11 @@
(do ////.monad
[valueO (translate valueS)
bodyO (translate bodyS)]
- (wrap (<| (_.closure (list))
- ($_ _.then
- (_.define (..register register) valueO)
- (_.return bodyO))))))
+ (wrap (_.apply/* (<| (_.closure (list))
+ ($_ _.then
+ (_.define (..register register) valueO)
+ (_.return bodyO)))
+ (list)))))
(def: #export (record-get translate valueS pathP)
(-> Phase Synthesis (List [Nat Bit])
diff --git a/stdlib/source/lux/tool/compiler/phase/translation/js/function.lux b/stdlib/source/lux/tool/compiler/phase/translation/js/function.lux
index 741e66573..5c17ed3d3 100644
--- a/stdlib/source/lux/tool/compiler/phase/translation/js/function.lux
+++ b/stdlib/source/lux/tool/compiler/phase/translation/js/function.lux
@@ -103,7 +103,7 @@
(_.define @curried all-inputs)
(_.return (_.closure (list)
(let [@missing all-inputs]
- (_.return (apply-poly (_.do ".concat" (list @missing) @curried)
+ (_.return (apply-poly (_.do "concat" (list @missing) @curried)
@self))))))))
)))
))
diff --git a/stdlib/source/lux/tool/compiler/phase/translation/js/runtime.lux b/stdlib/source/lux/tool/compiler/phase/translation/js/runtime.lux
index a7b8a5a05..e2014c064 100644
--- a/stdlib/source/lux/tool/compiler/phase/translation/js/runtime.lux
+++ b/stdlib/source/lux/tool/compiler/phase/translation/js/runtime.lux
@@ -17,7 +17,9 @@
["_" js (#+ Expression Var Computation Statement)]]]
["." ///
["//." //
- ["." synthesis]]]
+ ["." synthesis]
+ [//
+ ["/////." name]]]]
)
(do-template [<name> <base>]
@@ -69,23 +71,14 @@
(-> Expression Computation)
(..variant (_.i32 +1) (flag #1)))
-(def: sanitize
- (-> Text Text)
- (|>> (text.replace-all "/" "_SL")
- (text.replace-all "-" "_DS")
- (text.replace-all "^" "_CR")
- (text.replace-all "=" "_EQ")
- (text.replace-all "+" "_PL")
- (text.replace-all "*" "_ST")))
-
(def: variable
(-> Text Var)
- (|>> ..sanitize
+ (|>> /////name.normalize
_.var))
(def: runtime-name
(-> Text Var)
- (|>> ..sanitize
+ (|>> /////name.normalize
(format prefix "$")
_.var))
@@ -101,7 +94,7 @@
(wrap (list (` (let [(~+ (|> vars
(list/map (function (_ var)
(list (code.local-identifier var)
- (` (_.var (~ (code.text var)))))))
+ (` (_.var (~ (code.text (/////name.normalize var))))))))
list.concat))]
(~ body))))))
@@ -233,8 +226,8 @@
@sum//get
))
-(def: #export i64-high-field Text "H")
-(def: #export i64-low-field Text "L")
+(def: #export i64-high-field Text "_lux_high")
+(def: #export i64-low-field Text "_lux_low")
(runtime: (i64//new high low)
(_.return (_.object (list [..i64-high-field high]
@@ -594,8 +587,8 @@
@i64//2^64
@i64//2^63
@i64//unsigned-low
- @i64//zero
@i64//new
+ @i64//zero
@i64//min
@i64//max
@i64//one
diff --git a/stdlib/source/lux/tool/compiler/phase/translation/js/structure.lux b/stdlib/source/lux/tool/compiler/phase/translation/js/structure.lux
index ec60f6292..5a3a24175 100644
--- a/stdlib/source/lux/tool/compiler/phase/translation/js/structure.lux
+++ b/stdlib/source/lux/tool/compiler/phase/translation/js/structure.lux
@@ -28,5 +28,8 @@
(def: #export (variant translate [lefts right? valueS])
(-> Phase (Variant Synthesis) (Operation Expression))
(:: ////.monad map
- (//runtime.variant (_.i32 (.int lefts)) (//runtime.flag right?))
+ (//runtime.variant (_.i32 (.int (if right?
+ (inc lefts)
+ lefts)))
+ (//runtime.flag right?))
(translate valueS)))