aboutsummaryrefslogtreecommitdiff
path: root/stdlib
diff options
context:
space:
mode:
authorEduardo Julian2019-05-28 18:48:01 -0400
committerEduardo Julian2019-05-28 18:48:01 -0400
commit926c3e1dcc392dc21b77a93200fa3e01eb113cf2 (patch)
tree72a57dde416f7d263514190950a6686714008dee /stdlib
parenta420abd8ef1d5a008a5a0b6f75590cab2a9baac5 (diff)
Applied several tweaks to make the code easier to process by the new compiler.
Diffstat (limited to 'stdlib')
-rw-r--r--stdlib/source/lux.lux32
-rw-r--r--stdlib/source/lux/control/concurrency/actor.lux10
-rw-r--r--stdlib/source/lux/control/region.lux16
-rw-r--r--stdlib/source/lux/control/thread.lux14
-rw-r--r--stdlib/source/lux/control/writer.lux11
-rw-r--r--stdlib/source/lux/data/collection/tree/zipper.lux104
-rw-r--r--stdlib/source/lux/data/text/regex.lux2
-rw-r--r--stdlib/source/lux/tool/compiler/analysis.lux5
-rw-r--r--stdlib/source/lux/tool/compiler/default/init.lux4
-rw-r--r--stdlib/source/lux/tool/compiler/name.lux5
-rw-r--r--stdlib/source/lux/tool/compiler/phase/generation/common-lisp.lux1
-rw-r--r--stdlib/source/lux/tool/compiler/phase/generation/common-lisp/case.lux7
-rw-r--r--stdlib/source/lux/tool/compiler/phase/generation/common-lisp/extension/common.lux4
-rw-r--r--stdlib/source/lux/tool/compiler/phase/generation/js.lux1
-rw-r--r--stdlib/source/lux/tool/compiler/phase/generation/js/case.lux7
-rw-r--r--stdlib/source/lux/tool/compiler/phase/generation/js/extension/common.lux4
-rw-r--r--stdlib/source/lux/tool/compiler/phase/generation/lua.lux1
-rw-r--r--stdlib/source/lux/tool/compiler/phase/generation/lua/case.lux7
-rw-r--r--stdlib/source/lux/tool/compiler/phase/generation/lua/extension/common.lux4
-rw-r--r--stdlib/source/lux/tool/compiler/phase/generation/php.lux1
-rw-r--r--stdlib/source/lux/tool/compiler/phase/generation/php/case.lux7
-rw-r--r--stdlib/source/lux/tool/compiler/phase/generation/php/extension/common.lux4
-rw-r--r--stdlib/source/lux/tool/compiler/phase/generation/python.lux1
-rw-r--r--stdlib/source/lux/tool/compiler/phase/generation/python/case.lux7
-rw-r--r--stdlib/source/lux/tool/compiler/phase/generation/python/extension/common.lux4
-rw-r--r--stdlib/source/lux/tool/compiler/phase/generation/ruby.lux1
-rw-r--r--stdlib/source/lux/tool/compiler/phase/generation/ruby/case.lux7
-rw-r--r--stdlib/source/lux/tool/compiler/phase/generation/ruby/extension/common.lux4
-rw-r--r--stdlib/source/lux/tool/compiler/phase/generation/scheme.lux1
-rw-r--r--stdlib/source/lux/tool/compiler/phase/generation/scheme/case.lux7
-rw-r--r--stdlib/source/lux/tool/compiler/phase/generation/scheme/extension/common.lux4
-rw-r--r--stdlib/source/lux/tool/compiler/phase/statement.lux1
-rw-r--r--stdlib/source/lux/tool/compiler/phase/synthesis.lux4
-rw-r--r--stdlib/source/test/lux/control/parser.lux2
-rw-r--r--stdlib/source/test/lux/control/security/policy.lux1
-rw-r--r--stdlib/source/test/lux/data/collection/sequence.lux1
-rw-r--r--stdlib/source/test/lux/data/identity.lux2
-rw-r--r--stdlib/source/test/lux/data/number/complex.lux2
-rw-r--r--stdlib/source/test/lux/math.lux2
-rw-r--r--stdlib/source/test/lux/tool/compiler/default/syntax.lux16
40 files changed, 166 insertions, 152 deletions
diff --git a/stdlib/source/lux.lux b/stdlib/source/lux.lux
index 9e370f12b..b75b5bebe 100644
--- a/stdlib/source/lux.lux
+++ b/stdlib/source/lux.lux
@@ -5568,12 +5568,19 @@
(def: (multi-level-case$ g!_ [[init-pattern levels] body])
(-> Code [Multi-Level-Case Code] (List Code))
(let [inner-pattern-body (list@fold (function (_ [calculation pattern] success)
- (` (case (~ calculation)
- (~ pattern)
- (~ success)
-
- (~ g!_)
- #.None)))
+ (let [bind? (case pattern
+ [_ (#.Identifier _)]
+ #1
+
+ _
+ #0)]
+ (` (case (~ calculation)
+ (~ pattern)
+ (~ success)
+
+ (~+ (if bind?
+ (list)
+ (list g!_ (` #.None))))))))
(` (#.Some (~ body)))
(: (List [Code Code]) (list@reverse levels)))]
(list init-pattern inner-pattern-body)))
@@ -5601,6 +5608,12 @@
(^ (list& [_meta (#Form levels)] body next-branches))
(do meta-monad
[mlc (multi-level-case^ levels)
+ #let [initial-bind? (case mlc
+ [[_ (#.Identifier _)] _]
+ #1
+
+ _
+ #0)]
expected get-expected-type
g!temp (gensym "temp")]
(let [output (list g!temp
@@ -5613,9 +5626,10 @@
("lux check" (#.Apply (~ (type-to-code expected)) Maybe)
(case (~ g!temp)
(~+ (multi-level-case$ g!temp [mlc body]))
-
- (~ g!temp)
- #.None)))))]
+
+ (~+ (if initial-bind?
+ (list)
+ (list g!temp (` #.None)))))))))]
(wrap output)))
_
diff --git a/stdlib/source/lux/control/concurrency/actor.lux b/stdlib/source/lux/control/concurrency/actor.lux
index 6c0d1928e..09ef7e625 100644
--- a/stdlib/source/lux/control/concurrency/actor.lux
+++ b/stdlib/source/lux/control/concurrency/actor.lux
@@ -57,9 +57,9 @@
(abstract: #export (Actor s)
{#.doc "An actor, defined as all the necessities it requires."}
- {#mailbox (Atom <Mailbox>)
- #obituary [(Promise <Obituary>)
- (Resolver <Obituary>)]}
+ {#obituary [(Promise <Obituary>)
+ (Resolver <Obituary>)]
+ #mailbox (Atom <Mailbox>)}
## TODO: Delete after new-luxc becomes the new standard compiler.
(def: (actor mailbox obituary)
@@ -68,8 +68,8 @@
[(Promise <Obituary>)
(Resolver <Obituary>)]
(Actor s)))
- (:abstraction {#mailbox mailbox
- #obituary obituary}))
+ (:abstraction {#obituary obituary
+ #mailbox mailbox}))
(type: #export (Message s)
<Message>)
diff --git a/stdlib/source/lux/control/region.lux b/stdlib/source/lux/control/region.lux
index 0671e1c08..56e64f1ed 100644
--- a/stdlib/source/lux/control/region.lux
+++ b/stdlib/source/lux/control/region.lux
@@ -98,12 +98,16 @@
(do Monad<m>
[[cleaners ef] (ff [region cleaners])
[cleaners ea] (fa [region cleaners])]
- (case [ef ea]
- [(#error.Success f) (#error.Success a)]
- (wrap [cleaners (#error.Success (f a))])
-
- (^or [(#error.Failure error) _]
- [_ (#error.Failure error)])
+ (case ef
+ (#error.Success f)
+ (case ea
+ (#error.Success a)
+ (wrap [cleaners (#error.Success (f a))])
+
+ (#error.Failure error)
+ (wrap [cleaners (#error.Failure error)]))
+
+ (#error.Failure error)
(wrap [cleaners (#error.Failure error)]))))))
(structure: #export (monad Monad<m>)
diff --git a/stdlib/source/lux/control/thread.lux b/stdlib/source/lux/control/thread.lux
index ec9650664..b27e56395 100644
--- a/stdlib/source/lux/control/thread.lux
+++ b/stdlib/source/lux/control/thread.lux
@@ -32,7 +32,15 @@
(All [! a] (-> (Box ! a) (Thread ! a)))
(function (_ !)
(`` (for {(~~ (static @.old))
- ("jvm aaload" (:representation box) 0)}))))
+ ("jvm aaload" (:representation box) 0)
+
+ (~~ (static @.jvm))
+ ("jvm array read object"
+ (|> 0
+ (:coerce (primitive "java.lang.Long"))
+ "jvm object cast"
+ "jvm conversion long-to-int")
+ (:representation box))}))))
(def: #export (write value box)
(All [a] (-> a (All [!] (-> (Box ! a) (Thread ! Any)))))
@@ -46,11 +54,11 @@
a))
(thread []))
-(def: #export (io thread)
+(def: #export io
(All [a]
(-> (All [!] (Thread ! a))
(IO a)))
- (io.io (..run thread)))
+ (|>> ..run io.io))
(structure: #export functor
(All [!] (Functor (Thread !)))
diff --git a/stdlib/source/lux/control/writer.lux b/stdlib/source/lux/control/writer.lux
index bbca0faa0..866fe0b18 100644
--- a/stdlib/source/lux/control/writer.lux
+++ b/stdlib/source/lux/control/writer.lux
@@ -1,5 +1,6 @@
(.module:
[lux #*
+ ["@" target]
[abstract
monoid
["." functor (#+ Functor)]
@@ -59,10 +60,12 @@
(def: (join MlMla)
(do monad
- [## TODO: Remove once new-luxc is the standard compiler.
- [l1 Mla] (: (($ 1) (Writer ($ 0) (($ 1) (Writer ($ 0) ($ 2)))))
- MlMla)
- ## [l1 Mla] MlMla
+ [[l1 Mla] (`` (for {(~~ (static @.old))
+ (: (($ 1) (Writer ($ 0) (($ 1) (Writer ($ 0) ($ 2)))))
+ MlMla)
+
+ (~~ (static @.jvm))
+ MlMla}))
[l2 a] Mla]
(wrap [(:: monoid compose l1 l2) a]))))
diff --git a/stdlib/source/lux/data/collection/tree/zipper.lux b/stdlib/source/lux/data/collection/tree/zipper.lux
index 1c94d734e..f6a8ad8f0 100644
--- a/stdlib/source/lux/data/collection/tree/zipper.lux
+++ b/stdlib/source/lux/data/collection/tree/zipper.lux
@@ -1,5 +1,7 @@
(.module:
[lux #*
+ ["@" target]
+ [type (#+ :share)]
[abstract
functor
comonad
@@ -92,20 +94,21 @@
zipper
(#.Some parent)
- (|> parent
- ## TODO: Remove once new-luxc becomes the standard compiler.
- (update@ #node (: (-> (Tree ($ 0)) (Tree ($ 0)))
- (function (_ node)
- (set@ #//.children (list@compose (list.reverse (get@ #lefts zipper))
- (#.Cons (get@ #node zipper)
- (get@ #rights zipper)))
- node))))
- ## (update@ #node (function (_ node)
- ## (set@ #//.children (list@compose (list.reverse (get@ #lefts zipper))
- ## (#.Cons (get@ #node zipper)
- ## (get@ #rights zipper)))
- ## node)))
- )))
+ (update@ #node (`` (for {(~~ (static @.old))
+ (: (-> (Tree ($ 0)) (Tree ($ 0)))
+ (set@ #//.children (list@compose (list.reverse (get@ #lefts zipper))
+ (#.Cons (get@ #node zipper)
+ (get@ #rights zipper)))))
+
+ (~~ (static @.jvm))
+ (:share [a]
+ {(Zipper a)
+ zipper}
+ {(-> (Tree a) (Tree a))
+ (set@ #//.children (list@compose (list.reverse (get@ #lefts zipper))
+ (#.Cons (get@ #node zipper)
+ (get@ #rights zipper))))})}))
+ parent)))
(def: #export (start zipper)
(All [a] (-> (Zipper a) (Zipper a)))
@@ -198,13 +201,13 @@
(All [a] (-> a (Zipper a) (Zipper a)))
(update@ [#node #//.children]
(function (_ children)
- ## TODO: Remove once new-luxc becomes the standard compiler.
- (list& (: (Tree ($ 0))
- (//.tree [value {}]))
- children)
- ## (list& (//.tree [value {}])
- ## children)
- )
+ (list& (`` (for {(~~ (static @.old))
+ (: (Tree ($ 0))
+ (//.tree [value {}]))
+
+ (~~ (static @.jvm))
+ (//.tree [value {}])}))
+ children))
zipper))
(def: #export (append-child value zipper)
@@ -212,11 +215,12 @@
(update@ [#node #//.children]
(function (_ children)
(list@compose children
- ## TODO: Remove once new-luxc becomes the standard compiler.
- (list (: (Tree ($ 0))
- (//.tree [value {}])))
- ## (list (//.tree [value {}]))
- ))
+ (list (`` (for {(~~ (static @.old))
+ (: (Tree ($ 0))
+ (//.tree [value {}]))
+
+ (~~ (static @.jvm))
+ (//.tree [value {}])})))))
zipper))
(def: #export (remove zipper)
@@ -246,13 +250,13 @@
_
(#.Some (|> zipper
(update@ <side> (function (_ side)
- ## TODO: Remove once new-luxc becomes the standard compiler.
- (#.Cons (: (Tree ($ 0))
- (//.tree [value {}]))
- side)
- ## (#.Cons (//.tree [value {}])
- ## side)
- ))))))]
+ (#.Cons (`` (for {(~~ (static @.old))
+ (: (Tree ($ 0))
+ (//.tree [value {}]))
+
+ (~~ (static @.jvm))
+ (//.tree [value {}])}))
+ side)))))))]
[insert-left #lefts]
[insert-right #rights]
@@ -265,18 +269,22 @@
#rights (|> fa (get@ #rights) (list@map (//@map f)))
#node (//@map f (get@ #node fa))}))
-## TODO: Add again once new-luxc becomes the standard compiler.
-## (structure: #export comonad (CoMonad Zipper)
-## (def: &functor ..functor)
-
-## (def: unwrap (get@ [#node #//.value]))
-
-## (def: (split wa)
-## (let [tree-splitter (function (tree-splitter tree)
-## {#//.value (zip tree)
-## #//.children (list@map tree-splitter
-## (get@ #//.children tree))})]
-## {#parent (|> wa (get@ #parent) (maybe@map split))
-## #lefts (|> wa (get@ #lefts) (list@map tree-splitter))
-## #rights (|> wa (get@ #rights) (list@map tree-splitter))
-## #node (|> fa (get@ #node) tree-splitter)})))
+(`` (for {(~~ (static @.old))
+ (as-is)
+
+ (~~ (static @.jvm))
+ (structure: #export comonad (CoMonad Zipper)
+ (def: &functor ..functor)
+
+ (def: unwrap (get@ [#node #//.value]))
+
+ (def: (split [parent lefts rights node])
+ (let [tree-splitter (: (All [a] (-> (Tree a) (Tree (Zipper a))))
+ (function (tree-splitter tree)
+ {#//.value (zip tree)
+ #//.children (list@map tree-splitter
+ (get@ #//.children tree))}))]
+ {#parent (maybe@map split parent)
+ #lefts (list@map tree-splitter lefts)
+ #rights (list@map tree-splitter rights)
+ #node (tree-splitter node)})))}))
diff --git a/stdlib/source/lux/data/text/regex.lux b/stdlib/source/lux/data/text/regex.lux
index fea8835b6..964c90613 100644
--- a/stdlib/source/lux/data/text/regex.lux
+++ b/stdlib/source/lux/data/text/regex.lux
@@ -487,7 +487,7 @@
do-something-else))}
(with-gensyms [g!temp]
(wrap (list& (` (^multi (~ g!temp)
- [((~! l.run) (regex (~ (code.text pattern))) (~ g!temp))
+ [((~! l.run) (..regex (~ (code.text pattern))) (~ g!temp))
(#error.Success (~ (maybe.default g!temp bindings)))]))
body
branches))))
diff --git a/stdlib/source/lux/tool/compiler/analysis.lux b/stdlib/source/lux/tool/compiler/analysis.lux
index 2c4cdbc53..998306d4a 100644
--- a/stdlib/source/lux/tool/compiler/analysis.lux
+++ b/stdlib/source/lux/tool/compiler/analysis.lux
@@ -78,9 +78,8 @@
)
(template [<name> <type> <tag>]
- [(def: #export <name>
- (-> <type> Analysis)
- (|>> <tag> #..Primitive))]
+ [(template: #export (<name> value)
+ (#..Primitive (<tag> value)))]
[bit Bit #..Bit]
[nat Nat #..Nat]
diff --git a/stdlib/source/lux/tool/compiler/default/init.lux b/stdlib/source/lux/tool/compiler/default/init.lux
index 5cb857d65..a7a861289 100644
--- a/stdlib/source/lux/tool/compiler/default/init.lux
+++ b/stdlib/source/lux/tool/compiler/default/init.lux
@@ -91,10 +91,10 @@
(-> Source Reader (///analysis.Operation [Source Code]))
(function (_ [bundle compiler])
(case (reader source)
- (#error.Failure [source' error])
+ (#.Left [source' error])
(#error.Failure error)
- (#error.Success [source' output])
+ (#.Right [source' output])
(let [[cursor _] output]
(#error.Success [[bundle (|> compiler
(set@ #.source source')
diff --git a/stdlib/source/lux/tool/compiler/name.lux b/stdlib/source/lux/tool/compiler/name.lux
index d2841d849..252d57051 100644
--- a/stdlib/source/lux/tool/compiler/name.lux
+++ b/stdlib/source/lux/tool/compiler/name.lux
@@ -40,7 +40,10 @@
output ""]
(if (n/< name/size idx)
(recur (inc idx)
- (|> name ("lux text char" idx) !sanitize (format output)))
+ (|> name
+ ("lux text char" idx)
+ !sanitize
+ (format output)))
output))))
(def: #export (definition [module short])
diff --git a/stdlib/source/lux/tool/compiler/phase/generation/common-lisp.lux b/stdlib/source/lux/tool/compiler/phase/generation/common-lisp.lux
index 480c473bf..6d3500416 100644
--- a/stdlib/source/lux/tool/compiler/phase/generation/common-lisp.lux
+++ b/stdlib/source/lux/tool/compiler/phase/generation/common-lisp.lux
@@ -13,6 +13,7 @@
["." ///
["." extension]
[//
+ [analysis (#+)]
["." synthesis]]]])
(def: #export (generate synthesis)
diff --git a/stdlib/source/lux/tool/compiler/phase/generation/common-lisp/case.lux b/stdlib/source/lux/tool/compiler/phase/generation/common-lisp/case.lux
index dd5b89e38..6f24f6c23 100644
--- a/stdlib/source/lux/tool/compiler/phase/generation/common-lisp/case.lux
+++ b/stdlib/source/lux/tool/compiler/phase/generation/common-lisp/case.lux
@@ -97,8 +97,6 @@
(def: fail! (_.return-from ..@fail _.nil))
-(exception: #export unrecognized-path)
-
(def: (multi-pop! pops)
(-> Nat (Expression Any))
(_.setq @cursor (_.nthcdr/2 [(_.int (.int pops)) @cursor])))
@@ -188,10 +186,7 @@
post! (pattern-matching' generate postP)]
(wrap (<combinator> pre! post!))))
([/////synthesis.path/alt ..alternation]
- [/////synthesis.path/seq _.progn])
-
- _
- (////.throw unrecognized-path [])))
+ [/////synthesis.path/seq _.progn])))
(def: (pattern-matching generate pathP)
(-> Phase Path (Operation (Expression Any)))
diff --git a/stdlib/source/lux/tool/compiler/phase/generation/common-lisp/extension/common.lux b/stdlib/source/lux/tool/compiler/phase/generation/common-lisp/extension/common.lux
index a72239982..8f323544e 100644
--- a/stdlib/source/lux/tool/compiler/phase/generation/common-lisp/extension/common.lux
+++ b/stdlib/source/lux/tool/compiler/phase/generation/common-lisp/extension/common.lux
@@ -63,8 +63,8 @@
)))
(import: #long java/lang/Double
- (#static MIN_VALUE Double)
- (#static MAX_VALUE Double))
+ (#static MIN_VALUE double)
+ (#static MAX_VALUE double))
(template [<name> <const>]
[(def: (<name> _)
diff --git a/stdlib/source/lux/tool/compiler/phase/generation/js.lux b/stdlib/source/lux/tool/compiler/phase/generation/js.lux
index 37a8d1bc6..c0cd734b3 100644
--- a/stdlib/source/lux/tool/compiler/phase/generation/js.lux
+++ b/stdlib/source/lux/tool/compiler/phase/generation/js.lux
@@ -13,6 +13,7 @@
["." ///
["." extension]
[//
+ [analysis (#+)]
["." synthesis]]]])
(def: #export (generate synthesis)
diff --git a/stdlib/source/lux/tool/compiler/phase/generation/js/case.lux b/stdlib/source/lux/tool/compiler/phase/generation/js/case.lux
index edfa2d038..e1182c4b5 100644
--- a/stdlib/source/lux/tool/compiler/phase/generation/js/case.lux
+++ b/stdlib/source/lux/tool/compiler/phase/generation/js/case.lux
@@ -100,8 +100,6 @@
(def: fail-pm! _.break)
-(exception: #export unrecognized-path)
-
(def: (multi-pop-cursor! pops)
(-> Nat Statement)
(.let [popsJS (_.i32 (.int pops))]
@@ -200,10 +198,7 @@
right! (pattern-matching' generate rightP)]
(wrap (<combinator> left! right!))))
([/////synthesis.path/seq _.then]
- [/////synthesis.path/alt alternation])
-
- _
- (////.throw unrecognized-path [])))
+ [/////synthesis.path/alt alternation])))
(def: (pattern-matching generate pathP)
(-> Phase Path (Operation Statement))
diff --git a/stdlib/source/lux/tool/compiler/phase/generation/js/extension/common.lux b/stdlib/source/lux/tool/compiler/phase/generation/js/extension/common.lux
index 7a38dc5cd..5253ffe19 100644
--- a/stdlib/source/lux/tool/compiler/phase/generation/js/extension/common.lux
+++ b/stdlib/source/lux/tool/compiler/phase/generation/js/extension/common.lux
@@ -33,8 +33,8 @@
## [[Numbers]]
(import: #long java/lang/Double
- (#static MIN_VALUE Double)
- (#static MAX_VALUE Double))
+ (#static MIN_VALUE double)
+ (#static MAX_VALUE double))
(template [<name> <const>]
[(def: (<name> _)
diff --git a/stdlib/source/lux/tool/compiler/phase/generation/lua.lux b/stdlib/source/lux/tool/compiler/phase/generation/lua.lux
index 480c473bf..6d3500416 100644
--- a/stdlib/source/lux/tool/compiler/phase/generation/lua.lux
+++ b/stdlib/source/lux/tool/compiler/phase/generation/lua.lux
@@ -13,6 +13,7 @@
["." ///
["." extension]
[//
+ [analysis (#+)]
["." synthesis]]]])
(def: #export (generate synthesis)
diff --git a/stdlib/source/lux/tool/compiler/phase/generation/lua/case.lux b/stdlib/source/lux/tool/compiler/phase/generation/lua/case.lux
index 1e2e7d254..d69668611 100644
--- a/stdlib/source/lux/tool/compiler/phase/generation/lua/case.lux
+++ b/stdlib/source/lux/tool/compiler/phase/generation/lua/case.lux
@@ -104,8 +104,6 @@
(def: fail! _.break)
-(exception: #export unrecognized-path)
-
(template [<name> <flag> <prep>]
[(def: (<name> simple? idx)
(-> Bit Nat Statement)
@@ -188,10 +186,7 @@
post! (pattern-matching' generate postP)]
(wrap (<combinator> pre! post!))))
([/////synthesis.path/seq _.then]
- [/////synthesis.path/alt ..alternation])
-
- _
- (////.throw unrecognized-path [])))
+ [/////synthesis.path/alt ..alternation])))
(def: (pattern-matching generate pathP)
(-> Phase Path (Operation Statement))
diff --git a/stdlib/source/lux/tool/compiler/phase/generation/lua/extension/common.lux b/stdlib/source/lux/tool/compiler/phase/generation/lua/extension/common.lux
index e9aafeef6..25159b2a7 100644
--- a/stdlib/source/lux/tool/compiler/phase/generation/lua/extension/common.lux
+++ b/stdlib/source/lux/tool/compiler/phase/generation/lua/extension/common.lux
@@ -57,8 +57,8 @@
(bundle.install "char" (unary (!unary "string.char"))))))
(import: #long java/lang/Double
- (#static MIN_VALUE Double)
- (#static MAX_VALUE Double))
+ (#static MIN_VALUE double)
+ (#static MAX_VALUE double))
(template [<name> <const>]
[(def: (<name> _)
diff --git a/stdlib/source/lux/tool/compiler/phase/generation/php.lux b/stdlib/source/lux/tool/compiler/phase/generation/php.lux
index 480c473bf..6d3500416 100644
--- a/stdlib/source/lux/tool/compiler/phase/generation/php.lux
+++ b/stdlib/source/lux/tool/compiler/phase/generation/php.lux
@@ -13,6 +13,7 @@
["." ///
["." extension]
[//
+ [analysis (#+)]
["." synthesis]]]])
(def: #export (generate synthesis)
diff --git a/stdlib/source/lux/tool/compiler/phase/generation/php/case.lux b/stdlib/source/lux/tool/compiler/phase/generation/php/case.lux
index 4e672e600..4bd86c94e 100644
--- a/stdlib/source/lux/tool/compiler/phase/generation/php/case.lux
+++ b/stdlib/source/lux/tool/compiler/phase/generation/php/case.lux
@@ -100,8 +100,6 @@
(def: fail! _.break)
-(exception: #export unrecognized-path)
-
(def: (multi-pop! pops)
(-> Nat Statement)
(_.; (_.array-splice/3 [@cursor
@@ -198,10 +196,7 @@
post! (pattern-matching' generate postP)]
(wrap (<combinator> pre! post!))))
([/////synthesis.path/seq _.then]
- [/////synthesis.path/alt ..alternation])
-
- _
- (////.throw unrecognized-path [])))
+ [/////synthesis.path/alt ..alternation])))
(def: (pattern-matching generate pathP)
(-> Phase Path (Operation Statement))
diff --git a/stdlib/source/lux/tool/compiler/phase/generation/php/extension/common.lux b/stdlib/source/lux/tool/compiler/phase/generation/php/extension/common.lux
index bdda1861b..74f61fd22 100644
--- a/stdlib/source/lux/tool/compiler/phase/generation/php/extension/common.lux
+++ b/stdlib/source/lux/tool/compiler/phase/generation/php/extension/common.lux
@@ -55,8 +55,8 @@
(bundle.install "char" (unary _.chr/1)))))
(import: #long java/lang/Double
- (#static MIN_VALUE Double)
- (#static MAX_VALUE Double))
+ (#static MIN_VALUE double)
+ (#static MAX_VALUE double))
(template [<name> <const>]
[(def: (<name> _)
diff --git a/stdlib/source/lux/tool/compiler/phase/generation/python.lux b/stdlib/source/lux/tool/compiler/phase/generation/python.lux
index 37a8d1bc6..c0cd734b3 100644
--- a/stdlib/source/lux/tool/compiler/phase/generation/python.lux
+++ b/stdlib/source/lux/tool/compiler/phase/generation/python.lux
@@ -13,6 +13,7 @@
["." ///
["." extension]
[//
+ [analysis (#+)]
["." synthesis]]]])
(def: #export (generate synthesis)
diff --git a/stdlib/source/lux/tool/compiler/phase/generation/python/case.lux b/stdlib/source/lux/tool/compiler/phase/generation/python/case.lux
index 3e07a6730..d0f887385 100644
--- a/stdlib/source/lux/tool/compiler/phase/generation/python/case.lux
+++ b/stdlib/source/lux/tool/compiler/phase/generation/python/case.lux
@@ -98,8 +98,6 @@
(def: fail-pm! _.break)
-(exception: #export unrecognized-path)
-
(def: (multi-pop! pops)
(-> Nat (Statement Any))
(_.delete (_.slice-from (_.int (i/* -1 (.int pops))) @cursor)))
@@ -195,10 +193,7 @@
post! (pattern-matching' generate postP)]
(wrap (<combinator> pre! post!))))
([/////synthesis.path/seq _.then]
- [/////synthesis.path/alt ..alternation])
-
- _
- (////.throw unrecognized-path [])))
+ [/////synthesis.path/alt ..alternation])))
(def: (pattern-matching generate pathP)
(-> Phase Path (Operation (Statement Any)))
diff --git a/stdlib/source/lux/tool/compiler/phase/generation/python/extension/common.lux b/stdlib/source/lux/tool/compiler/phase/generation/python/extension/common.lux
index 7e1b4d2c1..0714fd26c 100644
--- a/stdlib/source/lux/tool/compiler/phase/generation/python/extension/common.lux
+++ b/stdlib/source/lux/tool/compiler/phase/generation/python/extension/common.lux
@@ -54,8 +54,8 @@
(bundle.install "char" (unary _.chr/1)))))
(import: #long java/lang/Double
- (#static MIN_VALUE Double)
- (#static MAX_VALUE Double))
+ (#static MIN_VALUE double)
+ (#static MAX_VALUE double))
(template [<name> <const>]
[(def: (<name> _)
diff --git a/stdlib/source/lux/tool/compiler/phase/generation/ruby.lux b/stdlib/source/lux/tool/compiler/phase/generation/ruby.lux
index 155d3e13c..a83ac89e1 100644
--- a/stdlib/source/lux/tool/compiler/phase/generation/ruby.lux
+++ b/stdlib/source/lux/tool/compiler/phase/generation/ruby.lux
@@ -13,6 +13,7 @@
["." ///
["." extension]
[//
+ [analysis (#+)]
["." synthesis]]]])
(def: #export (generate synthesis)
diff --git a/stdlib/source/lux/tool/compiler/phase/generation/ruby/case.lux b/stdlib/source/lux/tool/compiler/phase/generation/ruby/case.lux
index 614925cd6..25d6ff91a 100644
--- a/stdlib/source/lux/tool/compiler/phase/generation/ruby/case.lux
+++ b/stdlib/source/lux/tool/compiler/phase/generation/ruby/case.lux
@@ -99,8 +99,6 @@
(def: fail! _.break)
-(exception: #export unrecognized-path)
-
(def: (multi-pop! pops)
(-> Nat (Statement Any))
(_.statement (_.do "slice!" (list (_.int (i/* -1 (.int pops)))
@@ -197,10 +195,7 @@
post! (pattern-matching' generate postP)]
(wrap (<combinator> pre! post!))))
([/////synthesis.path/seq _.then]
- [/////synthesis.path/alt ..alternation])
-
- _
- (////.throw unrecognized-path [])))
+ [/////synthesis.path/alt ..alternation])))
(def: (pattern-matching generate pathP)
(-> Phase Path (Operation (Statement Any)))
diff --git a/stdlib/source/lux/tool/compiler/phase/generation/ruby/extension/common.lux b/stdlib/source/lux/tool/compiler/phase/generation/ruby/extension/common.lux
index cb72ecca0..80dbb312c 100644
--- a/stdlib/source/lux/tool/compiler/phase/generation/ruby/extension/common.lux
+++ b/stdlib/source/lux/tool/compiler/phase/generation/ruby/extension/common.lux
@@ -50,8 +50,8 @@
)))
(import: #long java/lang/Double
- (#static MIN_VALUE Double)
- (#static MAX_VALUE Double))
+ (#static MIN_VALUE double)
+ (#static MAX_VALUE double))
(template [<name> <const>]
[(def: (<name> _)
diff --git a/stdlib/source/lux/tool/compiler/phase/generation/scheme.lux b/stdlib/source/lux/tool/compiler/phase/generation/scheme.lux
index 2ccf4f45a..0152ffbcd 100644
--- a/stdlib/source/lux/tool/compiler/phase/generation/scheme.lux
+++ b/stdlib/source/lux/tool/compiler/phase/generation/scheme.lux
@@ -13,6 +13,7 @@
["." ///
["." extension]
[//
+ [analysis (#+)]
["." synthesis]]]])
(def: #export (generate synthesis)
diff --git a/stdlib/source/lux/tool/compiler/phase/generation/scheme/case.lux b/stdlib/source/lux/tool/compiler/phase/generation/scheme/case.lux
index 04d3bae1d..bd478f921 100644
--- a/stdlib/source/lux/tool/compiler/phase/generation/scheme/case.lux
+++ b/stdlib/source/lux/tool/compiler/phase/generation/scheme/case.lux
@@ -96,8 +96,6 @@
(def: fail-pm! (_.raise/1 pm-error))
-(exception: #export unrecognized-path)
-
(def: (pm-catch handler)
(-> Expression Computation)
(_.lambda [(list @alt-error) #.None]
@@ -154,10 +152,7 @@
rightO)))
(_.lambda [(list) #.None]
(_.begin (list save-cursor!
- leftO))))])
-
- _
- (////.throw unrecognized-path [])))
+ leftO))))])))
(def: (pattern-matching generate pathP)
(-> Phase Path (Operation Computation))
diff --git a/stdlib/source/lux/tool/compiler/phase/generation/scheme/extension/common.lux b/stdlib/source/lux/tool/compiler/phase/generation/scheme/extension/common.lux
index 6701bc078..8140c769f 100644
--- a/stdlib/source/lux/tool/compiler/phase/generation/scheme/extension/common.lux
+++ b/stdlib/source/lux/tool/compiler/phase/generation/scheme/extension/common.lux
@@ -102,8 +102,8 @@
(///runtime.i64//logical-right-shift (_.remainder/2 (_.int +64) paramO) subjectO))
(import: java/lang/Double
- (#static MIN_VALUE Double)
- (#static MAX_VALUE Double))
+ (#static MIN_VALUE double)
+ (#static MAX_VALUE double))
(template [<name> <const> <encode>]
[(def: (<name> _)
diff --git a/stdlib/source/lux/tool/compiler/phase/statement.lux b/stdlib/source/lux/tool/compiler/phase/statement.lux
index 1660fdf01..2f3c68f7b 100644
--- a/stdlib/source/lux/tool/compiler/phase/statement.lux
+++ b/stdlib/source/lux/tool/compiler/phase/statement.lux
@@ -16,6 +16,7 @@
[".P" analysis
["." type]]
["#/" // #_
+ [reference (#+)]
["#." analysis]
["/" statement (#+ Phase)]]])
diff --git a/stdlib/source/lux/tool/compiler/phase/synthesis.lux b/stdlib/source/lux/tool/compiler/phase/synthesis.lux
index 0e01c0f68..1b92abf97 100644
--- a/stdlib/source/lux/tool/compiler/phase/synthesis.lux
+++ b/stdlib/source/lux/tool/compiler/phase/synthesis.lux
@@ -16,6 +16,7 @@
["#/" // ("#;." monad)
["#." extension]
["#/" // #_
+ [reference (#+)]
["#." analysis (#+ Analysis)]
["/" synthesis (#+ Synthesis Phase)]]]])
@@ -84,7 +85,4 @@
(do //.monad
[argsS+ (monad.map @ phase args)]
(wrap (#/.Extension [name argsS+])))))))
-
- _
- (//;wrap (undefined))
))
diff --git a/stdlib/source/test/lux/control/parser.lux b/stdlib/source/test/lux/control/parser.lux
index c0bd6d92e..6e1845d15 100644
--- a/stdlib/source/test/lux/control/parser.lux
+++ b/stdlib/source/test/lux/control/parser.lux
@@ -11,7 +11,7 @@
["$." monad]]}]
[control
[parser
- ["s" code (#+ Parser)]]]
+ ["s" code]]]
[data
["." error (#+ Error)]
[number
diff --git a/stdlib/source/test/lux/control/security/policy.lux b/stdlib/source/test/lux/control/security/policy.lux
index 69c358e88..6fbcea774 100644
--- a/stdlib/source/test/lux/control/security/policy.lux
+++ b/stdlib/source/test/lux/control/security/policy.lux
@@ -2,6 +2,7 @@
[lux #*
["_" test (#+ Test)]
[abstract
+ [equivalence (#+)]
[hash (#+ Hash)]
[monad (#+ do)]
{[0 #test]
diff --git a/stdlib/source/test/lux/data/collection/sequence.lux b/stdlib/source/test/lux/data/collection/sequence.lux
index 6b4529dfc..19926ca92 100644
--- a/stdlib/source/test/lux/data/collection/sequence.lux
+++ b/stdlib/source/test/lux/data/collection/sequence.lux
@@ -4,6 +4,7 @@
["_" test (#+ Test)]
[abstract
comonad
+ [functor (#+)]
[monad (#+ do)]]
[data
["." maybe]
diff --git a/stdlib/source/test/lux/data/identity.lux b/stdlib/source/test/lux/data/identity.lux
index 38d20a7d5..3d0ae44c2 100644
--- a/stdlib/source/test/lux/data/identity.lux
+++ b/stdlib/source/test/lux/data/identity.lux
@@ -2,6 +2,8 @@
[lux #*
["_" test (#+ Test)]
[abstract
+ [equivalence (#+)]
+ [functor (#+)]
comonad
[monad (#+ do)]
{[0 #test]
diff --git a/stdlib/source/test/lux/data/number/complex.lux b/stdlib/source/test/lux/data/number/complex.lux
index 8eed3e865..644db8e27 100644
--- a/stdlib/source/test/lux/data/number/complex.lux
+++ b/stdlib/source/test/lux/data/number/complex.lux
@@ -20,7 +20,7 @@
{1
["." / (#+ Complex)]})
-(def: margin-of-error Frac +1.0e-9)
+(def: margin-of-error Frac +0.000000001)
(def: (within? margin standard value)
(-> Frac Complex Complex Bit)
diff --git a/stdlib/source/test/lux/math.lux b/stdlib/source/test/lux/math.lux
index c11380015..cee41346a 100644
--- a/stdlib/source/test/lux/math.lux
+++ b/stdlib/source/test/lux/math.lux
@@ -67,7 +67,7 @@
(do r.monad
[sample (|> r.safe-frac (:: @ map (f/* +10.0)))]
(_.test "Logarithm is the inverse of exponential."
- (|> sample /.exp /.log (within? +1.0e-15 sample)))))
+ (|> sample /.exp /.log (within? +0.000000000000001 sample)))))
(<| (_.context "Greatest-Common-Divisor and Least-Common-Multiple")
(do r.monad
[#let [gen-nat (|> r.nat (:: @ map (|>> (n/% 1000) (n/max 1))))]
diff --git a/stdlib/source/test/lux/tool/compiler/default/syntax.lux b/stdlib/source/test/lux/tool/compiler/default/syntax.lux
index a0005cc64..d6aee7e37 100644
--- a/stdlib/source/test/lux/tool/compiler/default/syntax.lux
+++ b/stdlib/source/test/lux/tool/compiler/default/syntax.lux
@@ -82,10 +82,10 @@
(case (let [source-code (%code sample)]
(/.parse "" (dictionary.new text.hash) (text.size source-code)
[default-cursor 0 source-code]))
- (#error.Failure error)
+ (#.Left error)
false
- (#error.Success [_ parsed])
+ (#.Right [_ parsed])
(:: code.equivalence = parsed sample)))
(do @
[other code^]
@@ -94,16 +94,16 @@
source-code//size (text.size source-code)]
(case (/.parse "" (dictionary.new text.hash) source-code//size
[default-cursor 0 source-code])
- (#error.Failure error)
+ (#.Left error)
false
- (#error.Success [remaining =sample])
+ (#.Right [remaining =sample])
(case (/.parse "" (dictionary.new text.hash) source-code//size
remaining)
- (#error.Failure error)
+ (#.Left error)
false
- (#error.Success [_ =other])
+ (#.Right [_ =other])
(and (:: code.equivalence = sample =sample)
(:: code.equivalence = other =other)))))))
)))
@@ -132,10 +132,10 @@
source-code//size (text.size source-code)]
(/.parse "" (dictionary.new text.hash) source-code//size
[default-cursor 0 source-code]))
- (#error.Failure error)
+ (#.Left error)
false
- (#error.Success [_ parsed])
+ (#.Right [_ parsed])
(:: code.equivalence = parsed sample)))
)))