aboutsummaryrefslogtreecommitdiff
path: root/stdlib
diff options
context:
space:
mode:
authorEduardo Julian2017-09-19 21:52:42 -0400
committerEduardo Julian2017-09-19 21:52:42 -0400
commit70534ffd9c346ac23f9d5574b9c7820dccebc350 (patch)
treee2370a43a8bb2bdcb349d5bbbe477312859365f3 /stdlib
parente717f33e192a5969760c033c47f9c4709485dd76 (diff)
- Some refactoring.
- Moved "assume" and "default" to lux/data/maybe.
Diffstat (limited to 'stdlib')
-rw-r--r--stdlib/source/lux.lux8
-rw-r--r--stdlib/source/lux/cli.lux8
-rw-r--r--stdlib/source/lux/concurrency/frp.lux8
-rw-r--r--stdlib/source/lux/concurrency/promise.lux8
-rw-r--r--stdlib/source/lux/concurrency/stm.lux8
-rw-r--r--stdlib/source/lux/concurrency/task.lux8
-rw-r--r--stdlib/source/lux/control/applicative.lux6
-rw-r--r--stdlib/source/lux/control/concatenative.lux4
-rw-r--r--stdlib/source/lux/control/cont.lux8
-rw-r--r--stdlib/source/lux/control/exception.lux3
-rw-r--r--stdlib/source/lux/control/functor.lux2
-rw-r--r--stdlib/source/lux/control/parser.lux10
-rw-r--r--stdlib/source/lux/control/reader.lux10
-rw-r--r--stdlib/source/lux/control/state.lux12
-rw-r--r--stdlib/source/lux/control/writer.lux10
-rw-r--r--stdlib/source/lux/data/coll/array.lux6
-rw-r--r--stdlib/source/lux/data/coll/list.lux10
-rw-r--r--stdlib/source/lux/data/coll/ordered/dict.lux12
-rw-r--r--stdlib/source/lux/data/coll/priority-queue.lux3
-rw-r--r--stdlib/source/lux/data/coll/queue.lux4
-rw-r--r--stdlib/source/lux/data/coll/seq.lux122
-rw-r--r--stdlib/source/lux/data/coll/set.lux5
-rw-r--r--stdlib/source/lux/data/coll/tree/zipper.lux2
-rw-r--r--stdlib/source/lux/data/coll/vector.lux63
-rw-r--r--stdlib/source/lux/data/env.lux4
-rw-r--r--stdlib/source/lux/data/format/json.lux10
-rw-r--r--stdlib/source/lux/data/identity.lux8
-rw-r--r--stdlib/source/lux/data/lazy.lux16
-rw-r--r--stdlib/source/lux/data/maybe.lux42
-rw-r--r--stdlib/source/lux/data/number.lux43
-rw-r--r--stdlib/source/lux/data/number/complex.lux2
-rw-r--r--stdlib/source/lux/data/number/ratio.lux7
-rw-r--r--stdlib/source/lux/data/result.lux12
-rw-r--r--stdlib/source/lux/data/store.lux6
-rw-r--r--stdlib/source/lux/data/text.lux9
-rw-r--r--stdlib/source/lux/data/text/lexer.lux8
-rw-r--r--stdlib/source/lux/data/text/regex.lux7
-rw-r--r--stdlib/source/lux/data/trace.lux4
-rw-r--r--stdlib/source/lux/host.jvm.lux24
-rw-r--r--stdlib/source/lux/io.lux8
-rw-r--r--stdlib/source/lux/macro.lux20
-rw-r--r--stdlib/source/lux/macro/poly.lux4
-rw-r--r--stdlib/source/lux/macro/poly/json.lux4
-rw-r--r--stdlib/source/lux/macro/syntax.lux7
-rw-r--r--stdlib/source/lux/macro/syntax/common/reader.lux5
-rw-r--r--stdlib/source/lux/math/random.lux17
-rw-r--r--stdlib/source/lux/test.lux11
-rw-r--r--stdlib/source/lux/time/date.lux3
-rw-r--r--stdlib/source/lux/time/instant.lux3
-rw-r--r--stdlib/source/lux/type.lux4
-rw-r--r--stdlib/source/lux/type/auto.lux9
-rw-r--r--stdlib/source/lux/type/check.lux8
-rw-r--r--stdlib/source/lux/type/object.lux4
-rw-r--r--stdlib/source/lux/world/net/udp.jvm.lux3
-rw-r--r--stdlib/test/test/lux.lux7
-rw-r--r--stdlib/test/test/lux/concurrency/stm.lux5
-rw-r--r--stdlib/test/test/lux/data/coll/array.lux6
-rw-r--r--stdlib/test/test/lux/data/coll/dict.lux11
-rw-r--r--stdlib/test/test/lux/data/coll/list.lux18
-rw-r--r--stdlib/test/test/lux/data/coll/priority-queue.lux7
-rw-r--r--stdlib/test/test/lux/data/coll/stack.lux5
-rw-r--r--stdlib/test/test/lux/data/coll/stream.lux11
-rw-r--r--stdlib/test/test/lux/data/coll/tree/zipper.lux7
-rw-r--r--stdlib/test/test/lux/data/coll/vector.lux7
-rw-r--r--stdlib/test/test/lux/data/format/xml.lux3
-rw-r--r--stdlib/test/test/lux/type.lux6
66 files changed, 379 insertions, 366 deletions
diff --git a/stdlib/source/lux.lux b/stdlib/source/lux.lux
index 6b29d7c42..58f8d342a 100644
--- a/stdlib/source/lux.lux
+++ b/stdlib/source/lux.lux
@@ -3269,7 +3269,7 @@
(-> Text Bottom)
(_lux_proc ["io" "error"] [message]))
-(macro: #export (default tokens state)
+(macro: (default tokens state)
{#;doc "## Allows you to provide a default value that will be used
## if a (Maybe x) value turns out to be #;None.
(default 20 (#;Some 10)) => 10
@@ -5743,10 +5743,6 @@
)))))
))
-(def: #export assume
- (All [a] (-> (Maybe a) a))
- (|>. (default (undefined))))
-
(macro: #export (as-is tokens compiler)
(#;Right [compiler tokens]))
@@ -5755,7 +5751,7 @@
(^multi (^ (list [_ (#Text input)]))
(n.= +1 (_lux_proc ["text" "size"] [input])))
(|> (_lux_proc ["text" "char"] [input +0])
- assume
+ (default (undefined))
nat$ list
[compiler] #;Right)
diff --git a/stdlib/source/lux/cli.lux b/stdlib/source/lux/cli.lux
index 4fa625dfd..0756f058a 100644
--- a/stdlib/source/lux/cli.lux
+++ b/stdlib/source/lux/cli.lux
@@ -1,8 +1,6 @@
(;module:
lux
- (lux (control functor
- applicative
- monad
+ (lux (control monad
["p" parser])
(data (coll [list "L/" Monoid<List> Monad<List>])
[text "T/" Monoid<Text>]
@@ -15,9 +13,9 @@
["s" syntax #+ syntax: Syntax])))
## [Types]
-(type: #export CLI
+(type: #export (CLI a)
{#;doc "A command-line interface parser."}
- (p;Parser (List Text)))
+ (p;Parser (List Text) a))
## [Combinators]
(def: #export (run inputs parser)
diff --git a/stdlib/source/lux/concurrency/frp.lux b/stdlib/source/lux/concurrency/frp.lux
index aa56aadeb..ed0560b84 100644
--- a/stdlib/source/lux/concurrency/frp.lux
+++ b/stdlib/source/lux/concurrency/frp.lux
@@ -1,7 +1,7 @@
(;module:
lux
- (lux (control functor
- applicative
+ (lux (control ["F" functor]
+ ["A" applicative]
["M" monad #+ do Monad]
[eq #+ Eq]
["p" parser])
@@ -276,7 +276,7 @@
(wrap (#;Some [value (sample time next-inputs)]))))))
## [Structures]
-(struct: #export _ (Functor Channel)
+(struct: #export _ (F;Functor Channel)
(def: (map f xs)
(:: &;Functor<Promise> map
(function [?x+xs]
@@ -285,7 +285,7 @@
(#;Some [x xs']) (#;Some [(f x) (map f xs')])))
xs)))
-(struct: #export _ (Applicative Channel)
+(struct: #export _ (A;Applicative Channel)
(def: functor Functor<Channel>)
(def: (wrap a)
diff --git a/stdlib/source/lux/concurrency/promise.lux b/stdlib/source/lux/concurrency/promise.lux
index cb15c95c9..1e6bb72e9 100644
--- a/stdlib/source/lux/concurrency/promise.lux
+++ b/stdlib/source/lux/concurrency/promise.lux
@@ -5,8 +5,8 @@
text/format)
[io #- run]
function
- (control functor
- applicative
+ (control ["F" functor]
+ ["A" applicative]
["M" monad #+ do Monad]
["p" parser])
[macro]
@@ -87,7 +87,7 @@
[]
(await f promise))))))
-(struct: #export _ (Functor Promise)
+(struct: #export _ (F;Functor Promise)
(def: (map f fa)
(let [fb (promise ($ +1))]
(exec (await (function [a] (do Monad<IO>
@@ -96,7 +96,7 @@
fa)
fb))))
-(struct: #export _ (Applicative Promise)
+(struct: #export _ (A;Applicative Promise)
(def: functor Functor<Promise>)
(def: (wrap a)
diff --git a/stdlib/source/lux/concurrency/stm.lux b/stdlib/source/lux/concurrency/stm.lux
index 27dca629c..7886dda36 100644
--- a/stdlib/source/lux/concurrency/stm.lux
+++ b/stdlib/source/lux/concurrency/stm.lux
@@ -1,7 +1,7 @@
(;module:
lux
- (lux (control functor
- applicative
+ (lux (control ["F" functor]
+ ["A" applicative]
["M" monad #+ do Monad])
[io #- run]
(data (coll [list "L/" Functor<List> Fold<List>]
@@ -156,13 +156,13 @@
target)]
(wrap head))))
-(struct: #export _ (Functor STM)
+(struct: #export _ (F;Functor STM)
(def: (map f fa)
(function [tx]
(let [[tx' a] (fa tx)]
[tx' (f a)]))))
-(struct: #export _ (Applicative STM)
+(struct: #export _ (A;Applicative STM)
(def: functor Functor<STM>)
(def: (wrap a)
diff --git a/stdlib/source/lux/concurrency/task.lux b/stdlib/source/lux/concurrency/task.lux
index 9fc35ee5f..4be7ead9d 100644
--- a/stdlib/source/lux/concurrency/task.lux
+++ b/stdlib/source/lux/concurrency/task.lux
@@ -1,8 +1,8 @@
(;module:
lux
(lux (data ["R" result])
- (control functor
- applicative
+ (control ["F" functor]
+ ["A" applicative]
monad
["ex" exception #+ Exception])
(concurrency ["P" promise])
@@ -29,7 +29,7 @@
(All [a] (-> (Task a) (Task (R;Result a))))
(:: P;Functor<Promise> map (|>. #R;Success) computation))
-(struct: #export _ (Functor Task)
+(struct: #export _ (F;Functor Task)
(def: (map f fa)
(:: P;Functor<Promise> map
(function [fa']
@@ -41,7 +41,7 @@
(#R;Success (f a))))
fa)))
-(struct: #export _ (Applicative Task)
+(struct: #export _ (A;Applicative Task)
(def: functor Functor<Task>)
(def: wrap return)
diff --git a/stdlib/source/lux/control/applicative.lux b/stdlib/source/lux/control/applicative.lux
index c904535a9..187950aa9 100644
--- a/stdlib/source/lux/control/applicative.lux
+++ b/stdlib/source/lux/control/applicative.lux
@@ -13,11 +13,11 @@
(-> (f (-> a b)) (f a) (f b)))
apply))
-(struct: #export (compA Applicative<F> Applicative<G>)
+(struct: #export (compose Applicative<F> Applicative<G>)
{#;doc "Applicative functor composition."}
(All [F G] (-> (Applicative F) (Applicative G) (Applicative (All [a] (F (G a))))))
- (def: functor (F;compF (get@ #functor Applicative<F>)
- (get@ #functor Applicative<G>)))
+ (def: functor (F;compose (get@ #functor Applicative<F>)
+ (get@ #functor Applicative<G>)))
(def: wrap
(|>. (:: Applicative<G> wrap) (:: Applicative<F> wrap)))
(def: (apply fgf fgx)
diff --git a/stdlib/source/lux/control/concatenative.lux b/stdlib/source/lux/control/concatenative.lux
index cdb9cc457..e96677b64 100644
--- a/stdlib/source/lux/control/concatenative.lux
+++ b/stdlib/source/lux/control/concatenative.lux
@@ -80,8 +80,8 @@
[?bottomI ?bottomO]
(with-gensyms [g!stack]
(monad;do @
- [inputC (singleton (macro;expand-all (stack-fold (get@ #top inputs) (default g!stack ?bottomI))))
- outputC (singleton (macro;expand-all (stack-fold (get@ #top outputs) (default g!stack ?bottomO))))]
+ [inputC (singleton (macro;expand-all (stack-fold (get@ #top inputs) (maybe;default g!stack ?bottomI))))
+ outputC (singleton (macro;expand-all (stack-fold (get@ #top outputs) (maybe;default g!stack ?bottomO))))]
(wrap (list (` (All [(~ g!stack)]
(-> (~ (de-alias inputC))
(~ (de-alias outputC))))))))))))
diff --git a/stdlib/source/lux/control/cont.lux b/stdlib/source/lux/control/cont.lux
index cbedc5df0..81f62eccb 100644
--- a/stdlib/source/lux/control/cont.lux
+++ b/stdlib/source/lux/control/cont.lux
@@ -1,7 +1,7 @@
(;module:
lux
- (lux (control functor
- applicative
+ (lux (control ["F" functor]
+ ["A" applicative]
monad)
function
[macro #+ with-gensyms]
@@ -22,11 +22,11 @@
(All [a] (-> (Cont a a) a))
(cont id))
-(struct: #export Functor<Cont> (All [o] (Functor (All [i] (Cont i o))))
+(struct: #export Functor<Cont> (All [o] (F;Functor (All [i] (Cont i o))))
(def: (map f fv)
(function [k] (fv (. k f)))))
-(struct: #export Applicative<Cont> (All [o] (Applicative (All [i] (Cont i o))))
+(struct: #export Applicative<Cont> (All [o] (A;Applicative (All [i] (Cont i o))))
(def: functor Functor<Cont>)
(def: (wrap value)
diff --git a/stdlib/source/lux/control/exception.lux b/stdlib/source/lux/control/exception.lux
index 560928bf2..b36c97268 100644
--- a/stdlib/source/lux/control/exception.lux
+++ b/stdlib/source/lux/control/exception.lux
@@ -2,6 +2,7 @@
lux
(lux (control monad)
(data ["R" result]
+ [maybe]
[text "text/" Monoid<Text>])
[macro]
(macro [code]
@@ -40,7 +41,7 @@
(if (text;starts-with? reference error)
(#R;Success (|> error
(text;clip (text;size reference) (text;size error))
- assume
+ maybe;assume
then))
(#R;Error error)))))
diff --git a/stdlib/source/lux/control/functor.lux b/stdlib/source/lux/control/functor.lux
index 416223cd7..3c1f33eb8 100644
--- a/stdlib/source/lux/control/functor.lux
+++ b/stdlib/source/lux/control/functor.lux
@@ -17,7 +17,7 @@
(type: #export (<.> f g)
(All [a] (f (g a))))
-(struct: #export (compF Functor<F> Functor<G>)
+(struct: #export (compose Functor<F> Functor<G>)
{#;doc "Functor composition."}
(All [F G] (-> (Functor F) (Functor G) (Functor (All [a] (F (G a))))))
(def: (map f fga)
diff --git a/stdlib/source/lux/control/parser.lux b/stdlib/source/lux/control/parser.lux
index 0c1b2cf32..174040805 100644
--- a/stdlib/source/lux/control/parser.lux
+++ b/stdlib/source/lux/control/parser.lux
@@ -1,7 +1,7 @@
(;module:
- [lux #- not default]
- (lux (control functor
- applicative
+ [lux #- not]
+ (lux (control ["F" functor]
+ ["A" applicative]
["M" monad #+ do Monad]
[codec])
(data (coll [list "L/" Functor<List> Monoid<List>])
@@ -13,7 +13,7 @@
(-> s (R;Result [s a])))
## [Structures]
-(struct: #export Functor<Parser> (All [s] (Functor (Parser s)))
+(struct: #export Functor<Parser> (All [s] (F;Functor (Parser s)))
(def: (map f ma)
(function [input]
(case (ma input)
@@ -23,7 +23,7 @@
(#R;Success [input' a])
(#R;Success [input' (f a)])))))
-(struct: #export Applicative<Parser> (All [s] (Applicative (Parser s)))
+(struct: #export Applicative<Parser> (All [s] (A;Applicative (Parser s)))
(def: functor Functor<Parser>)
(def: (wrap x)
diff --git a/stdlib/source/lux/control/reader.lux b/stdlib/source/lux/control/reader.lux
index bbc368a0c..b080d75ec 100644
--- a/stdlib/source/lux/control/reader.lux
+++ b/stdlib/source/lux/control/reader.lux
@@ -1,7 +1,7 @@
(;module:
lux
- (lux (control functor
- applicative
+ (lux (control ["F" functor]
+ ["A" applicative]
[monad #+ do Monad])))
## [Types]
@@ -10,12 +10,12 @@
(-> r a))
## [Structures]
-(struct: #export Functor<Reader> (All [r] (Functor (Reader r)))
+(struct: #export Functor<Reader> (All [r] (F;Functor (Reader r)))
(def: (map f fa)
(function [env]
(f (fa env)))))
-(struct: #export Applicative<Reader> (All [r] (Applicative (Reader r)))
+(struct: #export Applicative<Reader> (All [r] (A;Applicative (Reader r)))
(def: functor Functor<Reader>)
(def: (wrap x)
@@ -50,7 +50,7 @@
(struct: #export (ReaderT Monad<M>)
{#;doc "Monad transformer for Reader."}
(All [M] (-> (Monad M) (All [e] (Monad (All [a] (Reader e (M a)))))))
- (def: applicative (compA Applicative<Reader> (get@ #monad;applicative Monad<M>)))
+ (def: applicative (A;compose Applicative<Reader> (get@ #monad;applicative Monad<M>)))
(def: (join eMeMa)
(function [env]
(do Monad<M>
diff --git a/stdlib/source/lux/control/state.lux b/stdlib/source/lux/control/state.lux
index 3400ed07b..e791542d5 100644
--- a/stdlib/source/lux/control/state.lux
+++ b/stdlib/source/lux/control/state.lux
@@ -1,7 +1,7 @@
(;module:
lux
- (lux (control functor
- ["A" applicative #*]
+ (lux (control ["F" functor]
+ ["A" applicative]
[monad #+ do Monad])))
## [Types]
@@ -10,13 +10,13 @@
(-> s [s a]))
## [Structures]
-(struct: #export Functor<State> (All [s] (Functor (State s)))
+(struct: #export Functor<State> (All [s] (F;Functor (State s)))
(def: (map f ma)
(function [state]
(let [[state' a] (ma state)]
[state' (f a)]))))
-(struct: #export Applicative<State> (All [s] (Applicative (State s)))
+(struct: #export Applicative<State> (All [s] (A;Applicative (State s)))
(def: functor Functor<State>)
(def: (wrap a)
@@ -75,14 +75,14 @@
(action state))
(struct: (Functor<StateT> Functor<M>)
- (All [M s] (-> (Functor M) (Functor (All [a] (-> s (M [s a]))))))
+ (All [M s] (-> (F;Functor M) (F;Functor (All [a] (-> s (M [s a]))))))
(def: (map f sfa)
(function [state]
(:: Functor<M> map (function [[s a]] [s (f a)])
(sfa state)))))
(struct: (Applicative<StateT> Monad<M>)
- (All [M s] (-> (Monad M) (Applicative (All [a] (-> s (M [s a]))))))
+ (All [M s] (-> (Monad M) (A;Applicative (All [a] (-> s (M [s a]))))))
(def: functor (Functor<StateT> (:: Monad<M> functor)))
(def: (wrap a)
diff --git a/stdlib/source/lux/control/writer.lux b/stdlib/source/lux/control/writer.lux
index 6a82df77c..10da747c9 100644
--- a/stdlib/source/lux/control/writer.lux
+++ b/stdlib/source/lux/control/writer.lux
@@ -1,8 +1,8 @@
(;module:
lux
(lux/control monoid
- ["A" applicative #*]
- functor
+ ["F" functor]
+ ["A" applicative]
[monad #+ do Monad]))
(type: #export (Writer l a)
@@ -11,13 +11,13 @@
#value a})
(struct: #export Functor<Writer> (All [l]
- (Functor (Writer l)))
+ (F;Functor (Writer l)))
(def: (map f fa)
(let [[log datum] fa]
[log (f datum)])))
(struct: #export (Applicative<Writer> mon) (All [l]
- (-> (Monoid l) (Applicative (Writer l))))
+ (-> (Monoid l) (A;Applicative (Writer l))))
(def: functor Functor<Writer>)
(def: (wrap x)
@@ -43,7 +43,7 @@
(struct: #export (WriterT Monoid<l> Monad<M>)
(All [l M] (-> (Monoid l) (Monad M) (Monad (All [a] (M (Writer l a))))))
- (def: applicative (A;compA (get@ #monad;applicative Monad<M>) (Applicative<Writer> Monoid<l>)))
+ (def: applicative (A;compose (get@ #monad;applicative Monad<M>) (Applicative<Writer> Monoid<l>)))
(def: (join MlMla)
(do Monad<M>
[[l1 Mla] (: (($ +1) (Writer ($ +0) (($ +1) (Writer ($ +0) ($ +2)))))
diff --git a/stdlib/source/lux/data/coll/array.lux b/stdlib/source/lux/data/coll/array.lux
index 4ab94fae8..507092de1 100644
--- a/stdlib/source/lux/data/coll/array.lux
+++ b/stdlib/source/lux/data/coll/array.lux
@@ -1,9 +1,7 @@
(;module:
lux
(lux (control monoid
- functor
- applicative
- monad
+ ["F" functor]
[eq #+ Eq]
fold)
(data (coll [list "List/" Fold<List>])
@@ -188,7 +186,7 @@
(copy sxs +0 xs +0)
(copy sxy +0 ys sxs)))))
-(struct: #export _ (Functor Array)
+(struct: #export _ (F;Functor Array)
(def: (map f ma)
(let [arr-size (size ma)]
(if (n.= +0 arr-size)
diff --git a/stdlib/source/lux/data/coll/list.lux b/stdlib/source/lux/data/coll/list.lux
index 0098b3b90..c2186fd8d 100644
--- a/stdlib/source/lux/data/coll/list.lux
+++ b/stdlib/source/lux/data/coll/list.lux
@@ -1,8 +1,8 @@
(;module:
lux
(lux (control monoid
- functor
- applicative
+ ["F" functor]
+ ["A" applicative]
["M" monad #+ do Monad]
[eq #+ Eq]
[fold])
@@ -260,7 +260,7 @@
(open Monoid<List>)
-(struct: #export _ (Functor List)
+(struct: #export _ (F;Functor List)
(def: (map f ma)
(case ma
#;Nil #;Nil
@@ -268,7 +268,7 @@
(open Functor<List>)
-(struct: #export _ (Applicative List)
+(struct: #export _ (A;Applicative List)
(def: functor Functor<List>)
(def: (wrap a)
@@ -478,7 +478,7 @@
(struct: #export (ListT Monad<M>)
(All [M] (-> (Monad M) (Monad (All [a] (M (List a))))))
- (def: applicative (compA (get@ #M;applicative Monad<M>) Applicative<List>))
+ (def: applicative (A;compose (get@ #M;applicative Monad<M>) Applicative<List>))
(def: (join MlMla)
(do Monad<M>
[lMla MlMla
diff --git a/stdlib/source/lux/data/coll/ordered/dict.lux b/stdlib/source/lux/data/coll/ordered/dict.lux
index d0d1e20cc..e51e23b70 100644
--- a/stdlib/source/lux/data/coll/ordered/dict.lux
+++ b/stdlib/source/lux/data/coll/ordered/dict.lux
@@ -5,7 +5,7 @@
[order #+ Order])
(data (coll [list "L/" Monad<List> Monoid<List> Fold<List>])
["p" product]
- ["M" maybe #+ Functor<Maybe>])
+ [maybe])
[macro]
(macro [code]
["s" syntax #+ syntax: Syntax])))
@@ -258,7 +258,7 @@
outcome (recur side-root)]
(if (is side-root outcome)
?root
- (#;Some (<add> (default (undefined) outcome)
+ (#;Some (<add> (maybe;assume outcome)
root))))]
[T/< #left add-left]
@@ -351,7 +351,7 @@
(#;Some (right-balance (get@ #key right)
(get@ #value right)
(get@ #right right.left)
- (:: Functor<Maybe> map redden (get@ #right right)))))
+ (:: maybe;Functor<Maybe> map redden (get@ #right right)))))
_
(error! error-message))
@@ -378,7 +378,7 @@
(get@ #value left.right)
(#;Some (left-balance (get@ #key left)
(get@ #value left)
- (:: Functor<Maybe> map redden (get@ #left left))
+ (:: maybe;Functor<Maybe> map redden (get@ #left left))
(get@ #left left.right)))
(#;Some (black key value (get@ #right left.right) ?right)))
@@ -398,7 +398,7 @@
[(#;Some left) (#;Some right)]
(case [(get@ #color left) (get@ #color right)]
[#Red #Red]
- (do M;Monad<Maybe>
+ (do maybe;Monad<Maybe>
[fused (prepend (get@ #right left) (get@ #right right))]
(case (get@ #color fused)
#Red
@@ -437,7 +437,7 @@
(get@ #right right)))
[#Black #Black]
- (do M;Monad<Maybe>
+ (do maybe;Monad<Maybe>
[fused (prepend (get@ #right left) (get@ #left right))]
(case (get@ #color fused)
#Red
diff --git a/stdlib/source/lux/data/coll/priority-queue.lux b/stdlib/source/lux/data/coll/priority-queue.lux
index b85b184fc..5a79ccd0a 100644
--- a/stdlib/source/lux/data/coll/priority-queue.lux
+++ b/stdlib/source/lux/data/coll/priority-queue.lux
@@ -22,8 +22,7 @@
(All [a] (-> (Queue a) (Maybe a)))
(do maybe;Monad<Maybe>
[fingers queue]
- (wrap (default (undefined)
- (F;search (n.= (F;tag fingers)) fingers)))))
+ (wrap (maybe;assume (F;search (n.= (F;tag fingers)) fingers)))))
(def: #export (size queue)
(All [a] (-> (Queue a) Nat))
diff --git a/stdlib/source/lux/data/coll/queue.lux b/stdlib/source/lux/data/coll/queue.lux
index e5622f178..db514cbaa 100644
--- a/stdlib/source/lux/data/coll/queue.lux
+++ b/stdlib/source/lux/data/coll/queue.lux
@@ -1,7 +1,7 @@
(;module:
lux
(lux (control [eq #+ Eq]
- functor)
+ ["F" functor])
(data (coll [list "L/" Monoid<List> Functor<List>]))))
(type: #export (Queue a)
@@ -72,7 +72,7 @@
(def: (= qx qy)
(:: (list;Eq<List> Eq<a>) = (to-list qx) (to-list qy))))
-(struct: #export _ (Functor Queue)
+(struct: #export _ (F;Functor Queue)
(def: (map f fa)
{#front (|> fa (get@ #front) (L/map f))
#rear (|> fa (get@ #rear) (L/map f))}))
diff --git a/stdlib/source/lux/data/coll/seq.lux b/stdlib/source/lux/data/coll/seq.lux
index e61845ac0..0e861e15a 100644
--- a/stdlib/source/lux/data/coll/seq.lux
+++ b/stdlib/source/lux/data/coll/seq.lux
@@ -1,13 +1,13 @@
(;module:
lux
- (lux (control functor
- applicative
+ (lux (control ["F" functor]
+ ["A" applicative]
[monad #+ do Monad]
[eq #+ Eq]
fold
["p" parser])
(data (coll ["L" list "L/" Monoid<List> Fold<List>]
- (tree ["F" finger]))
+ (tree ["f" finger]))
[number]
[maybe])
[macro]
@@ -15,26 +15,26 @@
["s" syntax #+ syntax: Syntax])))
(type: #export (Seq a)
- (Maybe (F;Fingers Nat a)))
+ (Maybe (f;Fingers Nat a)))
(def: default-size Nat +1)
(def: (new value)
- (All [a] (-> a (F;Fingers Nat a)))
- {#F;monoid number;Add@Monoid<Nat>
- #F;tree (#F;Leaf default-size value)})
+ (All [a] (-> a (f;Fingers Nat a)))
+ {#f;monoid number;Add@Monoid<Nat>
+ #f;tree (#f;Leaf default-size value)})
(do-template [<name> <side>]
[(def: #export (<name> seq)
(All [a] (-> (Seq a) (Maybe a)))
(do maybe;Monad<Maybe>
[fingers seq]
- (wrap (loop [node (get@ #F;tree fingers)]
+ (wrap (loop [node (get@ #f;tree fingers)]
(case node
- (#F;Leaf tag value)
+ (#f;Leaf tag value)
value
- (#F;Branch tag left right)
+ (#f;Branch tag left right)
(recur <side>))))))]
[first left]
@@ -48,7 +48,7 @@
(#;Some (new prefix))
(#;Some fingers)
- (#;Some (F;branch (new prefix) fingers))))
+ (#;Some (f;branch (new prefix) fingers))))
(def: #export (append suffix subject)
(All [a] (-> a (Seq a) (Seq a)))
@@ -57,7 +57,7 @@
(#;Some (new suffix))
(#;Some fingers)
- (#;Some (F;branch fingers (new suffix)))))
+ (#;Some (f;branch fingers (new suffix)))))
(def: #export (concat left right)
(All [a] (-> (Seq a) (Seq a) (Seq a)))
@@ -69,13 +69,13 @@
right
[(#;Some left') (#;Some right')]
- (#;Some (F;branch left' right'))))
+ (#;Some (f;branch left' right'))))
(def: #export (nth idx seq)
(All [a] (-> Nat (Seq a) (Maybe a)))
(do maybe;Monad<Maybe>
[fingers seq]
- (F;search (n.> idx) fingers)))
+ (f;search (n.> idx) fingers)))
(def: #export (size seq)
(All [a] (-> (Seq a) Nat))
@@ -84,8 +84,8 @@
+0
(#;Some fingers)
- (case (get@ #F;tree fingers)
- (^or (#F;Leaf tag value) (#F;Branch tag left right))
+ (case (get@ #f;tree fingers)
+ (^or (#f;Leaf tag value) (#f;Branch tag left right))
tag)))
(def: #export (to-list seq)
@@ -95,12 +95,12 @@
(list)
(#;Some fingers)
- (loop [node (get@ #F;tree fingers)]
+ (loop [node (get@ #f;tree fingers)]
(case node
- (#F;Leaf tag value)
+ (#f;Leaf tag value)
(list value)
- (#F;Branch tag left right)
+ (#f;Branch tag left right)
(L/append (recur left) (recur right))))))
(def: #export (from-list xs)
@@ -114,32 +114,32 @@
(#;Cons x #;Nil)
(wrap [default-size
- (#F;Leaf default-size x)])
+ (#f;Leaf default-size x)])
(#;Cons x xs')
(do @
[[sub-size right] (recur xs')
#let [branch-size (n.+ default-size sub-size)]]
(wrap [branch-size
- (#F;Branch branch-size
- (#F;Leaf default-size x)
+ (#f;Branch branch-size
+ (#f;Leaf default-size x)
right)]))
))]
- (wrap {#F;monoid number;Add@Monoid<Nat>
- #F;tree tree}))))
+ (wrap {#f;monoid number;Add@Monoid<Nat>
+ #f;tree tree}))))
(def: #export (reverse seq)
(All [a] (-> (Seq a) (Seq a)))
(do maybe;Monad<Maybe>
[fingers seq
- #let [node' (loop [node (get@ #F;tree fingers)]
+ #let [node' (loop [node (get@ #f;tree fingers)]
(case node
- (#F;Leaf tag value)
+ (#f;Leaf tag value)
node
- (#F;Branch tag left right)
- (#F;Branch tag (recur right) (recur left))))]]
- (wrap (set@ #F;tree node' fingers))))
+ (#f;Branch tag left right)
+ (#f;Branch tag (recur right) (recur left))))]]
+ (wrap (set@ #f;tree node' fingers))))
(def: #export (member? Eq<a> xs x)
(All [a] (-> (Eq a) (Seq a) a Bool))
@@ -148,12 +148,12 @@
false
(#;Some fingers)
- (loop [xs (get@ #F;tree fingers)]
+ (loop [xs (get@ #f;tree fingers)]
(case xs
- (#F;Leaf tag reference)
+ (#f;Leaf tag reference)
(:: Eq<a> = reference x)
- (#F;Branch tag left right)
+ (#f;Branch tag left right)
(or (recur left)
(recur right))))))
@@ -165,12 +165,12 @@
<default>
(#;Some fingers)
- (loop [seq (get@ #F;tree fingers)]
+ (loop [seq (get@ #f;tree fingers)]
(case seq
- (#F;Leaf tag reference)
+ (#f;Leaf tag reference)
(pred reference)
- (#F;Branch tag left right)
+ (#f;Branch tag left right)
(<op> (recur left)
(recur right))))))]
@@ -188,14 +188,14 @@
(-> (-> a Bool) (Seq a) (Maybe a)))
(do maybe;Monad<Maybe>
[fingers seq]
- (loop [seq (get@ #F;tree fingers)]
+ (loop [seq (get@ #f;tree fingers)]
(case seq
- (#F;Leaf tag value)
+ (#f;Leaf tag value)
(if (pred value)
(#;Some value)
#;None)
- (#F;Branch tag left right)
+ (#f;Branch tag left right)
(case (recur left)
#;None
@@ -212,12 +212,12 @@
(#;Some fingers)
(loop [init init
- node (get@ #F;tree fingers)]
+ node (get@ #f;tree fingers)]
(case node
- (#F;Leaf tag value)
+ (#f;Leaf tag value)
(f value init)
- (#F;Branch tag left right)
+ (#f;Branch tag left right)
(recur (recur init left)
right)
)))))
@@ -229,20 +229,20 @@
(to-list xs)
(to-list ys))))
-(struct: #export _ (Functor Seq)
+(struct: #export _ (F;Functor Seq)
(def: (map f ma)
(do maybe;Monad<Maybe>
[fingers ma]
- (wrap {#F;monoid number;Add@Monoid<Nat>
- #F;tree (loop [tree (get@ #F;tree fingers)]
+ (wrap {#f;monoid number;Add@Monoid<Nat>
+ #f;tree (loop [tree (get@ #f;tree fingers)]
(case tree
- (#F;Leaf tag value)
- (#F;Leaf tag (f value))
+ (#f;Leaf tag value)
+ (#f;Leaf tag (f value))
- (#F;Branch tag left right)
- (#F;Branch tag (recur left) (recur right))))}))))
+ (#f;Branch tag left right)
+ (#f;Branch tag (recur left) (recur right))))}))))
-(struct: #export _ (Applicative Seq)
+(struct: #export _ (A;Applicative Seq)
(def: functor Functor<Seq>)
(def: wrap (|>. new #;Some))
@@ -250,15 +250,15 @@
(def: (apply ff fa)
(do maybe;Monad<Maybe>
[ff' ff]
- (case (get@ #F;tree ff')
- (#F;Leaf tag f)
+ (case (get@ #f;tree ff')
+ (#f;Leaf tag f)
(:: Functor<Seq> map f fa)
- (#F;Branch tag lfs rfs)
+ (#f;Branch tag lfs rfs)
(do @
- [lefts (apply (#;Some (set@ #F;tree lfs ff')) fa)
- rights (apply (#;Some (set@ #F;tree rfs ff')) fa)]
- (wrap (F;branch lefts rights)))))))
+ [lefts (apply (#;Some (set@ #f;tree lfs ff')) fa)
+ rights (apply (#;Some (set@ #f;tree rfs ff')) fa)]
+ (wrap (f;branch lefts rights)))))))
(struct: #export _ (Monad Seq)
(def: applicative Applicative<Seq>)
@@ -266,15 +266,15 @@
(def: (join ffa)
(do maybe;Monad<Maybe>
[ffa' ffa]
- (case (get@ #F;tree ffa')
- (#F;Leaf tag fa)
+ (case (get@ #f;tree ffa')
+ (#f;Leaf tag fa)
fa
- (#F;Branch tag left right)
+ (#f;Branch tag left right)
(do @
- [left' (join (#;Some (set@ #F;tree left ffa')))
- right' (join (#;Some (set@ #F;tree right ffa')))]
- (wrap (F;branch left' right')))))))
+ [left' (join (#;Some (set@ #f;tree left ffa')))
+ right' (join (#;Some (set@ #f;tree right ffa')))]
+ (wrap (f;branch left' right')))))))
(syntax: #export (seq [elems (p;some s;any)])
(wrap (list (` (;;from-list (list (~@ elems)))))))
diff --git a/stdlib/source/lux/data/coll/set.lux b/stdlib/source/lux/data/coll/set.lux
index 06953ef23..328524a06 100644
--- a/stdlib/source/lux/data/coll/set.lux
+++ b/stdlib/source/lux/data/coll/set.lux
@@ -1,9 +1,6 @@
(;module:
lux
- (lux (control functor
- applicative
- monad
- [eq #+ Eq]
+ (lux (control [eq #+ Eq]
[hash #*])
(data (coll [dict]
[list "List/" Fold<List> Functor<List>]))))
diff --git a/stdlib/source/lux/data/coll/tree/zipper.lux b/stdlib/source/lux/data/coll/tree/zipper.lux
index 6b39178bc..48c91ea34 100644
--- a/stdlib/source/lux/data/coll/tree/zipper.lux
+++ b/stdlib/source/lux/data/coll/tree/zipper.lux
@@ -168,7 +168,7 @@
(#;Some next)
(#;Some (|> next
- (update@ [#node #rose;children] (|>. list;tail (default (list)))))))
+ (update@ [#node #rose;children] (|>. list;tail (maybe;default (list)))))))
(#;Cons next side)
(#;Some (|> zipper
diff --git a/stdlib/source/lux/data/coll/vector.lux b/stdlib/source/lux/data/coll/vector.lux
index 23d07068e..826de5c42 100644
--- a/stdlib/source/lux/data/coll/vector.lux
+++ b/stdlib/source/lux/data/coll/vector.lux
@@ -1,7 +1,7 @@
(;module:
lux
- (lux (control functor
- applicative
+ (lux (control ["F" functor]
+ ["A" applicative]
["M" monad #+ do Monad]
[eq #+ Eq]
monoid
@@ -295,31 +295,31 @@
(update@ #size n.dec)
(set@ #tail (|> (array;new new-tail-size)
(array;copy new-tail-size +0 old-tail +0)))))
- (default (undefined)
- (do maybe;Monad<Maybe>
- [new-tail (base-for (n.- +2 vec-size) vec)
- #let [[level' root'] (: [Level (Hierarchy ($ +0))]
- (let [init-level (get@ #level vec)]
- (loop [level init-level
- root (: (Hierarchy ($ +0))
- (default (new-hierarchy [])
- (pop-tail vec-size init-level (get@ #root vec))))]
- (if (n.> branching-exponent level)
- (case [(array;get +1 root) (array;get +0 root)]
- [#;None (#;Some (#Hierarchy sub-node))]
- (recur (level-down level) sub-node)
-
- [#;None (#;Some (#Base _))]
- (undefined)
-
- _
- [level root])
- [level root]))))]]
- (wrap (|> vec
- (update@ #size n.dec)
- (set@ #level level')
- (set@ #root root')
- (set@ #tail new-tail))))))
+ (maybe;assume
+ (do maybe;Monad<Maybe>
+ [new-tail (base-for (n.- +2 vec-size) vec)
+ #let [[level' root'] (: [Level (Hierarchy ($ +0))]
+ (let [init-level (get@ #level vec)]
+ (loop [level init-level
+ root (: (Hierarchy ($ +0))
+ (maybe;default (new-hierarchy [])
+ (pop-tail vec-size init-level (get@ #root vec))))]
+ (if (n.> branching-exponent level)
+ (case [(array;get +1 root) (array;get +0 root)]
+ [#;None (#;Some (#Hierarchy sub-node))]
+ (recur (level-down level) sub-node)
+
+ [#;None (#;Some (#Base _))]
+ (undefined)
+
+ _
+ [level root])
+ [level root]))))]]
+ (wrap (|> vec
+ (update@ #size n.dec)
+ (set@ #level level')
+ (set@ #root root')
+ (set@ #tail new-tail))))))
))
(def: #export (to-list vec)
@@ -396,7 +396,7 @@
(def: (append xs ys)
(List/fold add xs (to-list ys))))
-(struct: _ (Functor Node)
+(struct: _ (F;Functor Node)
(def: (map f xs)
(case xs
(#Base base)
@@ -406,7 +406,7 @@
(#Hierarchy (Array/map (map f) hierarchy)))
))
-(struct: #export _ (Functor Vector)
+(struct: #export _ (F;Functor Vector)
(def: (map f xs)
{#level (get@ #level xs)
#size (get@ #size xs)
@@ -414,7 +414,7 @@
#tail (|> xs (get@ #tail) (Array/map f))
}))
-(struct: #export _ (Applicative Vector)
+(struct: #export _ (A;Applicative Vector)
(def: functor Functor<Vector>)
(def: (wrap x)
@@ -439,8 +439,7 @@
)
(def: #export (reverse xs)
- (All [a]
- (-> (Vector a) (Vector a)))
+ (All [a] (-> (Vector a) (Vector a)))
(let [(^open) Fold<Vector>
(^open) Monoid<Vector>]
(fold add unit xs)))
diff --git a/stdlib/source/lux/data/env.lux b/stdlib/source/lux/data/env.lux
index 7c29f5833..b6f96be68 100644
--- a/stdlib/source/lux/data/env.lux
+++ b/stdlib/source/lux/data/env.lux
@@ -1,13 +1,13 @@
(;module:
lux
- (lux (control functor
+ (lux (control ["F" functor]
comonad)))
(type: #export (Env e a)
{#env e
#value a})
-(struct: #export Functor<Env> (All [e] (Functor (Env e)))
+(struct: #export Functor<Env> (All [e] (F;Functor (Env e)))
(def: (map f fa)
(update@ #value f fa)))
diff --git a/stdlib/source/lux/data/format/json.lux b/stdlib/source/lux/data/format/json.lux
index 097525b1d..95d689059 100644
--- a/stdlib/source/lux/data/format/json.lux
+++ b/stdlib/source/lux/data/format/json.lux
@@ -2,9 +2,7 @@
For more information, please see: http://www.json.org/"}
lux
- (lux (control functor
- applicative
- [monad #+ do Monad]
+ (lux (control [monad #+ do Monad]
[eq #+ Eq]
codec
["p" parser "p/" Monad<Parser>])
@@ -12,7 +10,7 @@
[text "text/" Eq<Text> Monoid<Text>]
(text ["l" lexer])
[number "frac/" Codec<Text,Frac> "nat/" Codec<Text,Nat>]
- maybe
+ [maybe]
["R" result]
[sum]
[product]
@@ -169,8 +167,8 @@
(and (n.= (vector;size xs) (vector;size ys))
(L/fold (function [idx prev]
(and prev
- (default false
- (do Monad<Maybe>
+ (maybe;default false
+ (do maybe;Monad<Maybe>
[x' (vector;nth idx xs)
y' (vector;nth idx ys)]
(wrap (= x' y'))))))
diff --git a/stdlib/source/lux/data/identity.lux b/stdlib/source/lux/data/identity.lux
index 4f025d4f7..d2335f121 100644
--- a/stdlib/source/lux/data/identity.lux
+++ b/stdlib/source/lux/data/identity.lux
@@ -1,7 +1,7 @@
(;module:
lux
- (lux/control (functor #as F #refer #all)
- (applicative #as A #refer #all)
+ (lux/control ["F" functor]
+ ["A" applicative]
(monad #as M #refer #all)
(comonad #as CM #refer #all)))
@@ -10,10 +10,10 @@
a)
## [Structures]
-(struct: #export _ (Functor Identity)
+(struct: #export _ (F;Functor Identity)
(def: map id))
-(struct: #export _ (Applicative Identity)
+(struct: #export _ (A;Applicative Identity)
(def: functor Functor<Identity>)
(def: wrap id)
diff --git a/stdlib/source/lux/data/lazy.lux b/stdlib/source/lux/data/lazy.lux
index 1891f0100..e344c6a0a 100644
--- a/stdlib/source/lux/data/lazy.lux
+++ b/stdlib/source/lux/data/lazy.lux
@@ -1,10 +1,10 @@
(;module:
lux
(lux [io]
- (control functor
- applicative
+ (control ["F" functor]
+ ["A" applicative]
monad)
- (concurrency ["A" atom])
+ (concurrency ["a" atom])
[macro]
(macro ["s" syntax #+ syntax:])
(type opaque)))
@@ -14,15 +14,15 @@
(def: #hidden (freeze' generator)
(All [a] (-> (-> [] a) (Lazy a)))
- (let [cache (A;atom (: (Maybe ($ +0)) #;None))]
+ (let [cache (a;atom (: (Maybe ($ +0)) #;None))]
(@opaque (function [_]
- (case (io;run (A;get cache))
+ (case (io;run (a;get cache))
(#;Some value)
value
_
(let [value (generator [])]
- (exec (io;run (A;compare-and-swap _ (#;Some value) cache))
+ (exec (io;run (a;compare-and-swap _ (#;Some value) cache))
value)))))))
(def: #export (thaw l-value)
@@ -34,11 +34,11 @@
[g!_ (macro;gensym "_")]
(wrap (list (` (freeze' (function [(~ g!_)] (~ expr))))))))
-(struct: #export _ (Functor Lazy)
+(struct: #export _ (F;Functor Lazy)
(def: (map f fa)
(freeze (f (thaw fa)))))
-(struct: #export _ (Applicative Lazy)
+(struct: #export _ (A;Applicative Lazy)
(def: functor Functor<Lazy>)
(def: (wrap a)
diff --git a/stdlib/source/lux/data/maybe.lux b/stdlib/source/lux/data/maybe.lux
index 9cf80d4a8..27d63f1fb 100644
--- a/stdlib/source/lux/data/maybe.lux
+++ b/stdlib/source/lux/data/maybe.lux
@@ -1,9 +1,9 @@
(;module:
lux
- (lux (control (monoid #as m #refer #all)
- (functor #as F #refer #all)
- (applicative #as A #refer #all)
- ["M" monad #+ do Monad]
+ (lux (control ["m" monoid]
+ ["F" functor]
+ ["A" applicative]
+ [monad #+ do Monad]
[eq #+ Eq])))
## [Types]
@@ -12,20 +12,20 @@
## (#;Some a))
## [Structures]
-(struct: #export Monoid<Maybe> (All [a] (Monoid (Maybe a)))
+(struct: #export Monoid<Maybe> (All [a] (m;Monoid (Maybe a)))
(def: unit #;None)
(def: (append xs ys)
(case xs
#;None ys
(#;Some x) (#;Some x))))
-(struct: #export _ (Functor Maybe)
+(struct: #export _ (F;Functor Maybe)
(def: (map f ma)
(case ma
#;None #;None
(#;Some a) (#;Some (f a)))))
-(struct: #export _ (Applicative Maybe)
+(struct: #export _ (A;Applicative Maybe)
(def: functor Functor<Maybe>)
(def: (wrap x)
@@ -61,7 +61,7 @@
(struct: #export (MaybeT Monad<M>)
(All [M] (-> (Monad M) (Monad (All [a] (M (Maybe a))))))
- (def: applicative (A;compA (get@ #M;applicative Monad<M>) Applicative<Maybe>))
+ (def: applicative (A;compose (get@ #monad;applicative Monad<M>) Applicative<Maybe>))
(def: (join MmMma)
(do Monad<M>
[mMma MmMma]
@@ -74,4 +74,28 @@
(def: #export (lift Monad<M>)
(All [M a] (-> (Monad M) (-> (M a) (M (Maybe a)))))
- (M;lift Monad<M> (:: Monad<Maybe> wrap)))
+ (monad;lift Monad<M> (:: Monad<Maybe> wrap)))
+
+(macro: #export (default tokens state)
+ {#;doc "## Allows you to provide a default value that will be used
+ ## if a (Maybe x) value turns out to be #;None.
+ (default 20 (#;Some 10)) => 10
+
+ (default 20 #;None) => 20"}
+ (case tokens
+ (^ (list else maybe))
+ (let [g!temp (: Code [dummy-cursor (#;Symbol ["" ""])])
+ code (` (case (~ maybe)
+ (#;Some (~ g!temp))
+ (~ g!temp)
+
+ #;None
+ (~ else)))]
+ (#;Right [state (list code)]))
+
+ _
+ (#;Left "Wrong syntax for default")))
+
+(def: #export assume
+ (All [a] (-> (Maybe a) a))
+ (|>. (default (undefined))))
diff --git a/stdlib/source/lux/data/number.lux b/stdlib/source/lux/data/number.lux
index 82f8cadbb..b48aa5f7d 100644
--- a/stdlib/source/lux/data/number.lux
+++ b/stdlib/source/lux/data/number.lux
@@ -9,6 +9,7 @@
interval
codec)
(data ["R" result]
+ [maybe]
[bit])))
## [Structures]
@@ -180,7 +181,7 @@
(def: (encode value)
(loop [input value
output ""]
- (let [digit (assume (get-char <char-set> (n.% <base> input)))
+ (let [digit (maybe;assume (get-char <char-set> (n.% <base> input)))
output' (_lux_proc ["text" "append"] [digit output])
input' (n./ <base> input)]
(if (n.= +0 input')
@@ -196,7 +197,7 @@
(loop [idx +1
output +0]
(if (n.< input-size idx)
- (let [digit (assume (get-char input idx))]
+ (let [digit (maybe;assume (get-char input idx))]
(case (_lux_proc ["text" "index"] [<char-set> digit +0])
#;None
(#R;Error (_lux_proc ["text" "append"] [<error> repr]))
@@ -227,10 +228,10 @@
(loop [input (|> value (i./ <base>) (:: Number<Int> abs))
output (|> value (i.% <base>) (:: Number<Int> abs) int-to-nat
(get-char <char-set>)
- assume)]
+ maybe;assume)]
(if (i.= 0 input)
(_lux_proc ["text" "append"] [sign output])
- (let [digit (assume (get-char <char-set> (int-to-nat (i.% <base> input))))]
+ (let [digit (maybe;assume (get-char <char-set> (int-to-nat (i.% <base> input))))]
(recur (i./ <base> input)
(_lux_proc ["text" "append"] [digit output]))))))))
@@ -247,7 +248,7 @@
(loop [idx (if (i.= -1 sign) +1 +0)
output 0]
(if (n.< input-size idx)
- (let [digit (assume (get-char input idx))]
+ (let [digit (maybe;assume (get-char input idx))]
(case (_lux_proc ["text" "index"] [<char-set> digit +0])
#;None
(#R;Error <error>)
@@ -266,7 +267,7 @@
(def: (de-prefix input)
(-> Text Text)
- (assume (_lux_proc ["text" "clip"] [input +1 (_lux_proc ["text" "size"] [input])])))
+ (maybe;assume (_lux_proc ["text" "clip"] [input +1 (_lux_proc ["text" "size"] [input])])))
(do-template [<struct> <nat> <char-bit-size> <error>]
[(struct: #export <struct> (Codec Text Deg)
@@ -315,7 +316,7 @@
(_lux_proc ["text" "append"] ["." output])
(let [shifted (f.* <base> dec-left)
digit (|> shifted (f.% <base>) frac-to-int int-to-nat
- (get-char <char-set>) assume)]
+ (get-char <char-set>) maybe;assume)]
(recur (f.% 1.0 shifted)
(_lux_proc ["text" "append"] [output digit]))))))]
(_lux_proc ["text" "append"] [whole-part decimal-part])))
@@ -323,8 +324,8 @@
(def: (decode repr)
(case (_lux_proc ["text" "index"] [repr "." +0])
(#;Some split-index)
- (let [whole-part (assume (_lux_proc ["text" "clip"] [repr +0 split-index]))
- decimal-part (assume (_lux_proc ["text" "clip"] [repr (n.inc split-index) (_lux_proc ["text" "size"] [repr])]))]
+ (let [whole-part (maybe;assume (_lux_proc ["text" "clip"] [repr +0 split-index]))
+ decimal-part (maybe;assume (_lux_proc ["text" "clip"] [repr (n.inc split-index) (_lux_proc ["text" "size"] [repr])]))]
(case [(:: <int> decode whole-part)
(:: <int> decode decimal-part)]
(^multi [(#;Some whole) (#;Some decimal)]
@@ -368,8 +369,8 @@
(if (n.<= chunk-size num-digits)
(list digits)
(let [boundary (n.- chunk-size num-digits)
- chunk (assume (_lux_proc ["text" "clip"] [digits boundary num-digits]))
- remaining (assume (_lux_proc ["text" "clip"] [digits +0 boundary]))]
+ chunk (maybe;assume (_lux_proc ["text" "clip"] [digits boundary num-digits]))
+ remaining (maybe;assume (_lux_proc ["text" "clip"] [digits +0 boundary]))]
(list& chunk (segment-digits chunk-size remaining)))))))
(def: (bin-segment-to-hex input)
@@ -497,11 +498,11 @@
(def: (encode value)
(let [sign (:: Number<Frac> signum value)
raw-bin (:: Binary@Codec<Text,Frac> encode value)
- dot-idx (assume (_lux_proc ["text" "index"] [raw-bin "." +0]))
- whole-part (assume (_lux_proc ["text" "clip"] [raw-bin
- (if (f.= -1.0 sign) +1 +0)
- dot-idx]))
- decimal-part (assume (_lux_proc ["text" "clip"] [raw-bin (n.inc dot-idx) (_lux_proc ["text" "size"] [raw-bin])]))
+ dot-idx (maybe;assume (_lux_proc ["text" "index"] [raw-bin "." +0]))
+ whole-part (maybe;assume (_lux_proc ["text" "clip"] [raw-bin
+ (if (f.= -1.0 sign) +1 +0)
+ dot-idx]))
+ decimal-part (maybe;assume (_lux_proc ["text" "clip"] [raw-bin (n.inc dot-idx) (_lux_proc ["text" "size"] [raw-bin])]))
hex-output (|> (<from> false decimal-part)
["."]
(_lux_proc ["text" "append"])
@@ -520,8 +521,8 @@
1.0)]
(case (_lux_proc ["text" "index"] [repr "." +0])
(#;Some split-index)
- (let [whole-part (assume (_lux_proc ["text" "clip"] [repr (if (f.= -1.0 sign) +1 +0) split-index]))
- decimal-part (assume (_lux_proc ["text" "clip"] [repr (n.inc split-index) (_lux_proc ["text" "size"] [repr])]))
+ (let [whole-part (maybe;assume (_lux_proc ["text" "clip"] [repr (if (f.= -1.0 sign) +1 +0) split-index]))
+ decimal-part (maybe;assume (_lux_proc ["text" "clip"] [repr (n.inc split-index) (_lux_proc ["text" "size"] [repr])]))
as-binary (|> (<to> decimal-part)
["."]
(_lux_proc ["text" "append"])
@@ -602,7 +603,7 @@
(def: (digits-get idx digits)
(-> Nat Digits Nat)
- (default +0 (_lux_proc ["array" "get"] [digits idx])))
+ (maybe;default +0 (_lux_proc ["array" "get"] [digits idx])))
(def: (digits-put idx digit digits)
(-> Nat Nat Digits Digits)
@@ -677,7 +678,7 @@
(loop [idx +0
output (make-digits [])]
(if (n.< length idx)
- (let [char (assume (get-char input idx))]
+ (let [char (maybe;assume (get-char input idx))]
(case (_lux_proc ["text" "index"] ["0123456789" char +0])
#;None
#;None
@@ -749,7 +750,7 @@
(if (and dotted?
(n.<= (n.inc bit;width) length))
(case (|> (_lux_proc ["text" "clip"] [input +1 length])
- assume
+ maybe;assume
text-to-digits)
(#;Some digits)
(loop [digits digits
diff --git a/stdlib/source/lux/data/number/complex.lux b/stdlib/source/lux/data/number/complex.lux
index 3b8fb7f00..e1cb226a0 100644
--- a/stdlib/source/lux/data/number/complex.lux
+++ b/stdlib/source/lux/data/number/complex.lux
@@ -29,7 +29,7 @@
"The imaginary part can be omitted if it's 0."
(complex real))}
(wrap (list (` {#;;real (~ real)
- #;;imaginary (~ (default (' 0.0)
+ #;;imaginary (~ (maybe;default (' 0.0)
?imaginary))}))))
(def: #export i Complex (complex 0.0 1.0))
diff --git a/stdlib/source/lux/data/number/ratio.lux b/stdlib/source/lux/data/number/ratio.lux
index 3352fd02d..83f987827 100644
--- a/stdlib/source/lux/data/number/ratio.lux
+++ b/stdlib/source/lux/data/number/ratio.lux
@@ -11,7 +11,8 @@
[text "Text/" Monoid<Text>]
text/format
["R" result]
- [product])
+ [product]
+ [maybe])
[macro]
(macro [code]
["s" syntax #+ syntax: Syntax])))
@@ -127,7 +128,7 @@
(def: part-encode
(-> Nat Text)
- (|>. n/encode (text;split +1) (default (undefined)) product;right))
+ (|>. n/encode (text;split +1) maybe;assume product;right))
(def: part-decode
(-> Text (R;Result Nat))
@@ -155,5 +156,5 @@
"The denominator can be omitted if it's 1."
(ratio numerator))}
(wrap (list (` (normalize {#;;numerator (~ numerator)
- #;;denominator (~ (default (' +1)
+ #;;denominator (~ (maybe;default (' +1)
?denominator))})))))
diff --git a/stdlib/source/lux/data/result.lux b/stdlib/source/lux/data/result.lux
index aa9de092b..df52522af 100644
--- a/stdlib/source/lux/data/result.lux
+++ b/stdlib/source/lux/data/result.lux
@@ -1,7 +1,7 @@
(;module:
- [lux #- assume default]
- (lux (control functor
- applicative
+ lux
+ (lux (control ["F" functor]
+ ["A" applicative]
["M" monad #+ do Monad])))
## [Types]
@@ -10,13 +10,13 @@
(#Success a))
## [Structures]
-(struct: #export _ (Functor Result)
+(struct: #export _ (F;Functor Result)
(def: (map f ma)
(case ma
(#Error msg) (#Error msg)
(#Success datum) (#Success (f datum)))))
-(struct: #export _ (Applicative Result)
+(struct: #export _ (A;Applicative Result)
(def: functor Functor<Result>)
(def: (wrap a)
@@ -46,7 +46,7 @@
(struct: #export (ResultT Monad<M>)
(All [M] (-> (Monad M) (Monad (All [a] (M (Result a))))))
- (def: applicative (compA (get@ #M;applicative Monad<M>) Applicative<Result>))
+ (def: applicative (A;compose (get@ #M;applicative Monad<M>) Applicative<Result>))
(def: (join MeMea)
(do Monad<M>
[eMea MeMea]
diff --git a/stdlib/source/lux/data/store.lux b/stdlib/source/lux/data/store.lux
index e60c3703c..ef92b68c4 100644
--- a/stdlib/source/lux/data/store.lux
+++ b/stdlib/source/lux/data/store.lux
@@ -1,6 +1,6 @@
(;module:
lux
- (lux (control functor
+ (lux (control ["F" functor]
comonad)
(type auto)))
@@ -13,7 +13,7 @@
{#cursor (get@ #cursor wa)
#peek (function [s] (f (set@ #cursor s wa)))})
-(struct: #export Functor<Store> (All [s] (Functor (Store s)))
+(struct: #export Functor<Store> (All [s] (F;Functor (Store s)))
(def: (map f fa)
(extend (function [store]
(f (:: store peek (:: store cursor))))
@@ -39,5 +39,5 @@
(|> store (::: split) (peeks change)))
(def: #export (experiment Functor<f> change store)
- (All [f s a] (-> (Functor f) (-> s (f s)) (Store s a) (f a)))
+ (All [f s a] (-> (F;Functor f) (-> s (f s)) (Store s a) (f a)))
(:: Functor<f> map (::: peek) (change (::: cursor))))
diff --git a/stdlib/source/lux/data/text.lux b/stdlib/source/lux/data/text.lux
index 2819e9c16..ec3d2f3c1 100644
--- a/stdlib/source/lux/data/text.lux
+++ b/stdlib/source/lux/data/text.lux
@@ -26,6 +26,7 @@
[(def: #export (<name> input)
(-> Text Text)
(_lux_proc ["text" <proc>] [input]))]
+
[lower-case "lower-case"]
[upper-case "upper-case"]
[trim "trim"]
@@ -172,11 +173,11 @@
(def: #export (replace-once pattern value template)
(-> Text Text Text Text)
- (default template
+ (maybe;default template
(do maybe;Monad<Maybe>
- [[pre post] (split-with pattern template)]
- (let [(^open) Monoid<Text>]
- (wrap ($_ append pre value post))))))
+ [[pre post] (split-with pattern template)
+ #let [(^open) Monoid<Text>]]
+ (wrap ($_ append pre value post)))))
(def: #export (enclose [left right] content)
{#;doc "Surrounds the given content text with left and right side additions."}
diff --git a/stdlib/source/lux/data/text/lexer.lux b/stdlib/source/lux/data/text/lexer.lux
index ae3c4859f..cb68fe93d 100644
--- a/stdlib/source/lux/data/text/lexer.lux
+++ b/stdlib/source/lux/data/text/lexer.lux
@@ -1,8 +1,6 @@
(;module:
[lux #- not]
- (lux (control functor
- applicative
- [monad #+ do Monad]
+ (lux (control [monad #+ do Monad]
["p" parser])
(data [text "text/" Monoid<Text>]
[product]
@@ -19,7 +17,7 @@
(def: (remaining offset tape)
(-> Offset Text Text)
- (|> tape (text;split offset) assume product;right))
+ (|> tape (text;split offset) maybe;assume product;right))
(def: cannot-lex-error Text "Cannot lex from empty text.")
@@ -121,7 +119,7 @@
(-> Nat Nat (Lexer Text))
(do p;Monad<Parser>
[char any
- #let [char' (assume (text;nth +0 char))]
+ #let [char' (maybe;assume (text;nth +0 char))]
_ (p;assert ($_ text/append "Character is not within range: " (text;from-code bottom) "-" (text;from-code top))
(and (n.>= bottom char')
(n.<= top char')))]
diff --git a/stdlib/source/lux/data/text/regex.lux b/stdlib/source/lux/data/text/regex.lux
index c42aa9ba3..6d430b756 100644
--- a/stdlib/source/lux/data/text/regex.lux
+++ b/stdlib/source/lux/data/text/regex.lux
@@ -8,6 +8,7 @@
[number "Int/" Codec<Text,Int>]
[product]
["R" result]
+ [maybe]
(coll [list "L/" Fold<List> Monad<List>]))
[macro #- run]
(macro [code]
@@ -77,9 +78,9 @@
(def: re-range^
(l;Lexer Code)
(do p;Monad<Parser>
- [from (|> regex-char^ (:: @ map (|>. (text;nth +0) assume)))
+ [from (|> regex-char^ (:: @ map (|>. (text;nth +0) maybe;assume)))
_ (l;this "-")
- to (|> regex-char^ (:: @ map (|>. (text;nth +0) assume)))]
+ to (|> regex-char^ (:: @ map (|>. (text;nth +0) maybe;assume)))]
(wrap (` (l;range (~ (code;nat from)) (~ (code;nat to)))))))
(def: re-char^
@@ -487,7 +488,7 @@
[g!temp (macro;gensym "temp")]
(wrap (list& (` (^multi (~ g!temp)
[(l;run (~ g!temp) (regex (~ (code;text pattern))))
- (#R;Success (~ (default g!temp
+ (#R;Success (~ (maybe;default g!temp
bindings)))]))
body
branches))))
diff --git a/stdlib/source/lux/data/trace.lux b/stdlib/source/lux/data/trace.lux
index 137713fa7..7f6a376a9 100644
--- a/stdlib/source/lux/data/trace.lux
+++ b/stdlib/source/lux/data/trace.lux
@@ -1,7 +1,7 @@
(;module:
lux
(lux (control ["m" monoid]
- functor
+ ["F" functor]
comonad)
[macro]))
@@ -9,7 +9,7 @@
{#monoid (m;Monoid t)
#trace (-> t a)})
-(struct: #export Functor<Trace> (All [t] (Functor (Trace t)))
+(struct: #export Functor<Trace> (All [t] (F;Functor (Trace t)))
(def: (map f fa)
(update@ #trace (. f) fa)))
diff --git a/stdlib/source/lux/host.jvm.lux b/stdlib/source/lux/host.jvm.lux
index 731e4e482..ef4844d88 100644
--- a/stdlib/source/lux/host.jvm.lux
+++ b/stdlib/source/lux/host.jvm.lux
@@ -7,7 +7,7 @@
(data (coll [list "L/" Monad<List> Fold<List> Monoid<List>]
[array #+ Array])
number
- maybe
+ [maybe]
[product]
[text "Text/" Eq<Text> Monoid<Text>]
text/format
@@ -313,7 +313,7 @@
(code;symbol ["" name])
(#;Some [pname pbounds])
- (class->type' mode type-params in-array? (default (undefined) (list;head pbounds))))
+ (class->type' mode type-params in-array? (maybe;assume (list;head pbounds))))
(#GenericClass name+params)
(generic-class->type' mode type-params in-array? name+params
@@ -357,7 +357,7 @@
(def: (get-import name imports)
(-> Text ClassImports (Maybe Text))
- (:: Functor<Maybe> map product;right
+ (:: maybe;Functor<Maybe> map product;right
(list;find (|>. product;left (Text/= name))
imports)))
@@ -481,7 +481,7 @@
(format "java.lang." name)
## else
- (default name (get-import name imports))))
+ (maybe;default name (get-import name imports))))
(def: type-var-class Text "java.lang.Object")
@@ -497,7 +497,7 @@
type-var-class
(#;Some [pname pbounds])
- (simple-class$ params (default (undefined) (list;head pbounds))))
+ (simple-class$ params (maybe;assume (list;head pbounds))))
(^or (#GenericWildcard #;None) (#GenericWildcard (#;Some [#LowerBound _])))
type-var-class
@@ -787,7 +787,7 @@
(-> ClassImports (Syntax (List Annotation)))
(do p;Monad<Parser>
[anns?? (p;opt (annotations^' imports))]
- (wrap (default (list) anns??))))
+ (wrap (maybe;default (list) anns??))))
(def: (throws-decl'^ imports type-vars)
(-> ClassImports (List TypeParam) (Syntax (List GenericType)))
@@ -799,7 +799,7 @@
(-> ClassImports (List TypeParam) (Syntax (List GenericType)))
(do p;Monad<Parser>
[exs? (p;opt (throws-decl'^ imports type-vars))]
- (wrap (default (list) exs?))))
+ (wrap (maybe;default (list) exs?))))
(def: (method-decl^ imports type-vars)
(-> ClassImports (List TypeParam) (Syntax [MemberDecl MethodDecl]))
@@ -1022,8 +1022,8 @@
?prim-mode (p;opt primitive-mode^)
args (import-member-args^ imports total-vars)
[io? try? maybe?] import-member-return-flags^]
- (wrap (#ConstructorDecl [{#import-member-mode (default #AutoPrM ?prim-mode)
- #import-member-alias (default "new" ?alias)
+ (wrap (#ConstructorDecl [{#import-member-mode (maybe;default #AutoPrM ?prim-mode)
+ #import-member-alias (maybe;default "new" ?alias)
#import-member-kind #VirtualIMK
#import-member-tvars tvars
#import-member-args args
@@ -1044,8 +1044,8 @@
args (import-member-args^ imports total-vars)
[io? try? maybe?] import-member-return-flags^
return (generic-type^ imports total-vars)]
- (wrap (#MethodDecl [{#import-member-mode (default #AutoPrM ?prim-mode)
- #import-member-alias (default name ?alias)
+ (wrap (#MethodDecl [{#import-member-mode (maybe;default #AutoPrM ?prim-mode)
+ #import-member-alias (maybe;default name ?alias)
#import-member-kind kind
#import-member-tvars tvars
#import-member-args args
@@ -1062,7 +1062,7 @@
gtype (generic-type^ imports owner-vars)
maybe? (s;this? (' #?))
setter? (s;this? (' #!))]
- (wrap (#FieldAccessDecl {#import-field-mode (default #AutoPrM ?prim-mode)
+ (wrap (#FieldAccessDecl {#import-field-mode (maybe;default #AutoPrM ?prim-mode)
#import-field-name name
#import-field-static? static?
#import-field-maybe? maybe?
diff --git a/stdlib/source/lux/io.lux b/stdlib/source/lux/io.lux
index 11b97f0a7..f7459251d 100644
--- a/stdlib/source/lux/io.lux
+++ b/stdlib/source/lux/io.lux
@@ -1,7 +1,7 @@
(;module: {#;doc "A method for abstracting I/O and effectful computations to make it safe while writing pure functional code."}
lux
- (lux (control functor
- applicative
+ (lux (control ["F" functor]
+ ["A" applicative]
["M" monad #+ do Monad])
(data (coll [list]))))
@@ -26,11 +26,11 @@
(#;Left "Wrong syntax for io")))
## [Structures]
-(struct: #export _ (Functor IO)
+(struct: #export _ (F;Functor IO)
(def: (map f ma)
(io (f (ma (:! Void []))))))
-(struct: #export _ (Applicative IO)
+(struct: #export _ (A;Applicative IO)
(def: functor Functor<IO>)
(def: (wrap x)
diff --git a/stdlib/source/lux/macro.lux b/stdlib/source/lux/macro.lux
index a7a5d22cd..4a9b8e8f7 100644
--- a/stdlib/source/lux/macro.lux
+++ b/stdlib/source/lux/macro.lux
@@ -1,21 +1,21 @@
(;module: {#;doc "Functions for extracting information from the state of the compiler."}
lux
(lux (macro [code])
- (control functor
- applicative
+ (control ["F" functor]
+ ["A" applicative]
["M" monad #+ do Monad])
(data (coll [list "L/" Monoid<List> Monad<List>])
[number]
[text "T/" Monoid<Text> Eq<Text>]
[product]
[ident "Ident/" Codec<Text,Ident>]
- maybe
+ [maybe]
["R" result])))
## (type: (Lux a)
## (-> Compiler (R;Result [Compiler a])))
-(struct: #export _ (Functor Lux)
+(struct: #export _ (F;Functor Lux)
(def: (map f fa)
(function [state]
(case (fa state)
@@ -25,7 +25,7 @@
(#R;Success [state' a])
(#R;Success [state' (f a)])))))
-(struct: #export _ (Applicative Lux)
+(struct: #export _ (A;Applicative Lux)
(def: functor Functor<Lux>)
(def: (wrap x)
@@ -222,8 +222,8 @@
[(def: #export (<name> anns)
{#;doc (#;TextA ($_ T/append "Looks up the arguments of a " <desc> "."))}
(-> Anns (List Text))
- (default (list)
- (do Monad<Maybe>
+ (maybe;default (list)
+ (do maybe;Monad<Maybe>
[_args (get-ann (ident-for <tag>) anns)
args (try-mlist _args)]
(M;map @ try-mtext args))))]
@@ -235,7 +235,7 @@
(def: (find-macro' modules this-module module name)
(-> (List [Text Module]) Text Text Text
(Maybe Macro))
- (do Monad<Maybe>
+ (do maybe;Monad<Maybe>
[$module (get module modules)
[def-type def-anns def-value] (: (Maybe Def) (|> (: Module $module) (get@ #;defs) (get name)))]
(if (and (macro? def-anns)
@@ -425,7 +425,7 @@
(function [state]
(let [test (: (-> [Text [Type Top]] Bool)
(|>. product;left (T/= name)))]
- (case (do Monad<Maybe>
+ (case (do maybe;Monad<Maybe>
[scope (list;find (function [env]
(or (list;any? test (: (List [Text [Type Top]])
(get@ [#;locals #;mappings] env)))
@@ -449,7 +449,7 @@
(-> Ident (Lux Def))
(function [state]
(case (: (Maybe Def)
- (do Monad<Maybe>
+ (do maybe;Monad<Maybe>
[#let [[v-prefix v-name] name]
(^slots [#;defs]) (get v-prefix (get@ #;modules state))]
(get v-name defs)))
diff --git a/stdlib/source/lux/macro/poly.lux b/stdlib/source/lux/macro/poly.lux
index 58afcd1a3..0cf927f00 100644
--- a/stdlib/source/lux/macro/poly.lux
+++ b/stdlib/source/lux/macro/poly.lux
@@ -416,13 +416,13 @@
(#;Bound idx)
(let [idx (adjusted-idx env idx)]
(if (n.= +0 idx)
- (|> (dict;get idx env) (default (undefined)) product;left (to-ast env))
+ (|> (dict;get idx env) maybe;assume product;left (to-ast env))
(` (;$ (~ (code;nat (n.dec idx)))))))
(#;Apply #;Void (#;Bound idx))
(let [idx (adjusted-idx env idx)]
(if (n.= +0 idx)
- (|> (dict;get idx env) (default (undefined)) product;left (to-ast env))
+ (|> (dict;get idx env) maybe;assume product;left (to-ast env))
(undefined)))
(^template [<tag>]
diff --git a/stdlib/source/lux/macro/poly/json.lux b/stdlib/source/lux/macro/poly/json.lux
index 379be9f49..321a80492 100644
--- a/stdlib/source/lux/macro/poly/json.lux
+++ b/stdlib/source/lux/macro/poly/json.lux
@@ -1,8 +1,6 @@
(;module: {#;doc "Codecs for values in the JSON format."}
lux
- (lux (control functor
- applicative
- [monad #+ do Monad]
+ (lux (control [monad #+ do Monad]
[eq #+ Eq]
codec
["p" parser "p/" Monad<Parser>])
diff --git a/stdlib/source/lux/macro/syntax.lux b/stdlib/source/lux/macro/syntax.lux
index 4a05041f6..96f1b658f 100644
--- a/stdlib/source/lux/macro/syntax.lux
+++ b/stdlib/source/lux/macro/syntax.lux
@@ -1,9 +1,7 @@
(;module:
lux
(lux [macro #+ Monad<Lux> with-gensyms]
- (control functor
- applicative
- ["M" monad #+ do Monad]
+ (control ["M" monad #+ do Monad]
[eq #+ Eq]
["p" parser])
(data [bool]
@@ -12,6 +10,7 @@
[ident]
(coll [list #* "" Functor<List> Fold<List> "List/" Monoid<List>])
[product]
+ [maybe]
["R" result]))
(.. [code "Code/" Eq<Code>]))
@@ -218,7 +217,7 @@
[constructor-args (constructor-args^ imports class-vars)]
[methods (some (overriden-method-def^ imports))])
(let [def-code ($_ Text/append "anon-class:"
- (spaced (list (super-class-decl$ (;default object-super-class super))
+ (spaced (list (super-class-decl$ (maybe;default object-super-class super))
(with-brackets (spaced (map super-class-decl$ interfaces)))
(with-brackets (spaced (map constructor-arg$ constructor-args)))
(with-brackets (spaced (map (method-def$ id) methods))))))]
diff --git a/stdlib/source/lux/macro/syntax/common/reader.lux b/stdlib/source/lux/macro/syntax/common/reader.lux
index 84d40fb03..33ca61b8b 100644
--- a/stdlib/source/lux/macro/syntax/common/reader.lux
+++ b/stdlib/source/lux/macro/syntax/common/reader.lux
@@ -4,7 +4,8 @@
["p" parser])
(data (coll [list "L/" Functor<List>])
[ident "Ident/" Eq<Ident>]
- [product])
+ [product]
+ [maybe])
[macro]
(macro ["s" syntax #+ syntax: Syntax]))
[.. #*])
@@ -87,7 +88,7 @@
(def: (find-definition-args meta-data)
(-> (List [Ident Code]) (List Text))
- (default (list)
+ (maybe;default (list)
(case (list;find (|>. product;left (Ident/= ["lux" "func-args"])) meta-data)
(^multi (#;Some [_ value])
[(p;run (list value) list-meta^)
diff --git a/stdlib/source/lux/math/random.lux b/stdlib/source/lux/math/random.lux
index f9989be40..f054ec1e4 100644
--- a/stdlib/source/lux/math/random.lux
+++ b/stdlib/source/lux/math/random.lux
@@ -1,18 +1,19 @@
(;module: {#;doc "Pseudo-random number generation (PRNG) algorithms."}
[lux #- list]
- (lux (control functor
- applicative
+ (lux (control ["F" functor]
+ ["A" applicative]
["M" monad #+ do Monad]
hash)
(data [bit]
[text "Text/" Monoid<Text>]
text/format
[product]
+ [maybe]
[number]
(number ["r" ratio]
["c" complex])
(coll [list "List/" Fold<List>]
- ["A" array]
+ ["a" array]
["D" dict]
["Q" queue]
["S" set]
@@ -28,13 +29,13 @@
{#;doc "A producer of random values based on a PRNG."}
(-> PRNG [PRNG a]))
-(struct: #export _ (Functor Random)
+(struct: #export _ (F;Functor Random)
(def: (map f fa)
(function [state]
(let [[state' a] (fa state)]
[state' (f a)]))))
-(struct: #export _ (Applicative Random)
+(struct: #export _ (A;Applicative Random)
(def: functor Functor<Random>)
(def: (wrap a)
@@ -200,7 +201,7 @@
[values (list size value-gen)]
(wrap (|> values <ctor>))))]
- [array A;Array A;from-list]
+ [array a;Array a;from-list]
[queue Q;Queue Q;from-list]
[stack ST;Stack (List/fold ST;push ST;empty)]
)
@@ -273,9 +274,7 @@
(def: (swap from to vec)
(All [a] (-> Nat Nat (V;Vector a) (V;Vector a)))
- (V;put to (default (undefined)
- (V;nth from vec))
- vec))
+ (V;put to (maybe;assume (V;nth from vec)) vec))
(def: #export (shuffle seed vector)
{#;doc "Shuffle a vector randomly based on a seed value."}
diff --git a/stdlib/source/lux/test.lux b/stdlib/source/lux/test.lux
index 5d95e2f6b..09165c0b7 100644
--- a/stdlib/source/lux/test.lux
+++ b/stdlib/source/lux/test.lux
@@ -3,13 +3,12 @@
(lux [macro #+ Monad<Lux> with-gensyms]
(macro ["s" syntax #+ syntax: Syntax]
[code])
- (control functor
- applicative
- ["M" monad #+ do Monad]
+ (control ["M" monad #+ do Monad]
["p" parser])
(concurrency [promise #+ Promise Monad<Promise>])
(data (coll [list "L/" Monad<List> Fold<List>])
[product]
+ [maybe]
[text]
text/format
["E" result])
@@ -112,7 +111,7 @@
(def: #hidden (repeat ?seed times random-test)
(-> (Maybe Nat) Nat (R;Random Test) Test)
- (repeat' (default (|> (io;run instant;now) instant;to-millis int-to-nat)
+ (repeat' (maybe;default (|> (io;run instant;now) instant;to-millis int-to-nat)
?seed)
(case ?seed
#;None times
@@ -195,10 +194,10 @@
false)))
(test "Can have defaults for Maybe values."
- (and (is "yolo" (default "yolo"
+ (and (is "yolo" (maybe;default "yolo"
#;None))
- (is "lol" (default "yolo"
+ (is "lol" (maybe;default "yolo"
(#;Some "lol")))))
))
"Also works with random generation of values for property-based testing."
diff --git a/stdlib/source/lux/time/date.lux b/stdlib/source/lux/time/date.lux
index 85c878211..4e74a3b73 100644
--- a/stdlib/source/lux/time/date.lux
+++ b/stdlib/source/lux/time/date.lux
@@ -7,6 +7,7 @@
["p" parser]
[monad #+ do])
(data ["R" result]
+ [maybe]
[number "int/" Codec<Text,Int>]
[text "text/" Monoid<Text>]
(text ["l" lexer])
@@ -286,7 +287,7 @@
normal-months)
month-days (|> months
(v;nth (int-to-nat (i.dec utc-month)))
- assume)]
+ maybe;assume)]
_ (l;this "-")
utc-day lex-section
_ (p;assert "Invalid day."
diff --git a/stdlib/source/lux/time/instant.lux b/stdlib/source/lux/time/instant.lux
index 5fb8bf4f1..c626e9ec4 100644
--- a/stdlib/source/lux/time/instant.lux
+++ b/stdlib/source/lux/time/instant.lux
@@ -11,6 +11,7 @@
(text ["l" lexer])
[number "int/" Codec<Text,Int>]
["R" result]
+ [maybe]
(coll [list "L/" Fold<List> Functor<List>]
["v" vector "v/" Functor<Vector> Fold<Vector>]))
(type opaque))
@@ -252,7 +253,7 @@
normal-months)
month-days (|> months
(v;nth (int-to-nat (i.dec utc-month)))
- assume)]
+ maybe;assume)]
_ (l;this "-")
utc-day lex-section
_ (p;assert "Invalid day."
diff --git a/stdlib/source/lux/type.lux b/stdlib/source/lux/type.lux
index 72d63483f..8fe0465ba 100644
--- a/stdlib/source/lux/type.lux
+++ b/stdlib/source/lux/type.lux
@@ -35,7 +35,7 @@
[#;ExQ])
(#;Bound idx)
- (default (error! (Text/append "Unknown type var: " (Nat/encode idx)))
+ (maybe;default (error! (Text/append "Unknown type var: " (Nat/encode idx)))
(list;nth idx env))
_
@@ -336,7 +336,7 @@
(quantified? _type)
(#;Apply A F)
- (default false
+ (maybe;default false
(do maybe;Monad<Maybe>
[applied (apply (list A) F)]
(wrap (quantified? applied))))
diff --git a/stdlib/source/lux/type/auto.lux b/stdlib/source/lux/type/auto.lux
index 08c5aa784..9bb8a5657 100644
--- a/stdlib/source/lux/type/auto.lux
+++ b/stdlib/source/lux/type/auto.lux
@@ -9,7 +9,8 @@
(coll [list "List/" Monad<List> Fold<List>]
[dict])
[bool]
- [product])
+ [product]
+ [maybe])
[macro #+ Monad<Lux>]
(macro [code]
["s" syntax #+ syntax: Syntax])
@@ -156,8 +157,7 @@
(#;UnivQ _)
(do Monad<Check>
[[id var] tc;create-var]
- (apply-function-type (default (undefined)
- (type;apply (list var) func))
+ (apply-function-type (maybe;assume (type;apply (list var) func))
arg))
(#;Function input output)
@@ -174,8 +174,7 @@
(#;UnivQ _)
(do Monad<Check>
[[id var] tc;create-var
- [ids final-output] (concrete-type (default (undefined)
- (type;apply (list var) type)))]
+ [ids final-output] (concrete-type (maybe;assume (type;apply (list var) type)))]
(wrap [(#;Cons id ids)
final-output]))
diff --git a/stdlib/source/lux/type/check.lux b/stdlib/source/lux/type/check.lux
index 7d1bd0462..11b584859 100644
--- a/stdlib/source/lux/type/check.lux
+++ b/stdlib/source/lux/type/check.lux
@@ -2,8 +2,8 @@
Very useful for writing advanced macros."}
lux
- (lux (control functor
- applicative
+ (lux (control ["F" functor]
+ ["A" applicative]
["M" monad #+ do Monad])
(data [text "text/" Monoid<Text> Eq<Text>]
[number "nat/" Codec<Text,Nat>]
@@ -22,7 +22,7 @@
(type: #export Type-Vars
(List [Nat (Maybe Type)]))
-(struct: #export _ (Functor Check)
+(struct: #export _ (F;Functor Check)
(def: (map f fa)
(function [context]
(case (fa context)
@@ -33,7 +33,7 @@
(#R;Success [context' (f output)])
))))
-(struct: #export _ (Applicative Check)
+(struct: #export _ (A;Applicative Check)
(def: functor Functor<Check>)
(def: (wrap x)
diff --git a/stdlib/source/lux/type/object.lux b/stdlib/source/lux/type/object.lux
index 961be9b03..786e7806a 100644
--- a/stdlib/source/lux/type/object.lux
+++ b/stdlib/source/lux/type/object.lux
@@ -5,7 +5,7 @@
(data [text]
text/format
[product]
- maybe
+ [maybe]
[ident #+ "Ident/" Eq<Ident>]
(coll [list "L/" Functor<List> Fold<List> Monoid<List>]
[set #+ Set]))
@@ -106,7 +106,7 @@
(list;enumerate inputs))
g!destructuring (L/fold (function [_ g!bottom] (` [(~ g!_temp) (~ g!_temp) (~ g!bottom)]))
(` [(~ g!_behavior) (~ g!_state) (~ g!_extension)])
- (default g!states (list;tail g!states)))]
+ (maybe;default g!states (list;tail g!states)))]
(` (def: (~@ (csw;export export)) ((~ g!method) (~@ g!_args) (~ g!_object))
(All [(~@ g!parameters) (~ g!ext) (~@ g!states) (~@ g!type-vars)]
(-> (~@ inputs) (~ g!self-object) (~ output)))
diff --git a/stdlib/source/lux/world/net/udp.jvm.lux b/stdlib/source/lux/world/net/udp.jvm.lux
index e76a1e009..f9bf5eec4 100644
--- a/stdlib/source/lux/world/net/udp.jvm.lux
+++ b/stdlib/source/lux/world/net/udp.jvm.lux
@@ -6,6 +6,7 @@
["T" task]
[frp])
(data ["R" result]
+ [maybe]
(coll [array]))
(type opaque)
(world [blob #+ Blob])
@@ -50,7 +51,7 @@
(: (io;IO (R;Result InetAddress))
(case (array;size addresses)
+0 (io;io (ex;throw Cannot-Resolve-Address address))
- +1 (wrap (assume (array;get +0 addresses)))
+ +1 (wrap (maybe;assume (array;get +0 addresses)))
_ (io;io (ex;throw Multiple-Candidate-Addresses address))))))
(opaque: #export UDP {}
diff --git a/stdlib/test/test/lux.lux b/stdlib/test/test/lux.lux
index 41b3bc555..546d7f14f 100644
--- a/stdlib/test/test/lux.lux
+++ b/stdlib/test/test/lux.lux
@@ -5,7 +5,8 @@
[io]
[math]
["R" math/random]
- (data [text "T/" Eq<Text>]
+ (data [maybe]
+ [text "T/" Eq<Text>]
text/format)
[macro]
(macro ["s" syntax #+ syntax:])))
@@ -161,10 +162,10 @@
false)))
(test "Can have defaults for Maybe values."
- (and (is "yolo" (default "yolo"
+ (and (is "yolo" (maybe;default "yolo"
#;None))
- (is "lol" (default "yolo"
+ (is "lol" (maybe;default "yolo"
(#;Some "lol")))))
))
diff --git a/stdlib/test/test/lux/concurrency/stm.lux b/stdlib/test/test/lux/concurrency/stm.lux
index b7403d8d5..ade1700b5 100644
--- a/stdlib/test/test/lux/concurrency/stm.lux
+++ b/stdlib/test/test/lux/concurrency/stm.lux
@@ -3,6 +3,7 @@
(lux [io]
(control ["M" monad #+ do Monad])
(data [number]
+ [maybe]
(coll [list "" Functor<List> "List/" Fold<List>])
text/format)
(concurrency ["&" stm]
@@ -25,9 +26,9 @@
_ (&;update (i.* 3) _var)]
(&;read _var)))
?c1+changes' changes
- #let [[c1 changes'] (default [-1 changes] ?c1+changes')]
+ #let [[c1 changes'] (maybe;default [-1 changes] ?c1+changes')]
?c2+changes' changes'
- #let [[c2 changes'] (default [-1 changes] ?c2+changes')]]
+ #let [[c2 changes'] (maybe;default [-1 changes] ?c2+changes')]]
($_ seq
(test "Can read STM vars."
(i.= 0 output1))
diff --git a/stdlib/test/test/lux/data/coll/array.lux b/stdlib/test/test/lux/data/coll/array.lux
index b98c20c66..3f344a1be 100644
--- a/stdlib/test/test/lux/data/coll/array.lux
+++ b/stdlib/test/test/lux/data/coll/array.lux
@@ -5,7 +5,8 @@
[io]
(data (coll ["&" array]
[list])
- [number])
+ [number]
+ [maybe])
["R" math/random])
lux/test)
@@ -51,8 +52,7 @@
idx (:: @ map (n.% size) R;nat)
array (|> (R;array size R;nat)
(R;filter (|>. &;to-list (list;any? n.odd?))))
- #let [value (default (undefined)
- (&;get idx array))]]
+ #let [value (maybe;assume (&;get idx array))]]
($_ seq
(test "Shouldn't be able to find a value in an unoccupied cell."
(case (&;get idx (&;remove idx array))
diff --git a/stdlib/test/test/lux/data/coll/dict.lux b/stdlib/test/test/lux/data/coll/dict.lux
index b317cdfa8..defea0534 100644
--- a/stdlib/test/test/lux/data/coll/dict.lux
+++ b/stdlib/test/test/lux/data/coll/dict.lux
@@ -6,6 +6,7 @@
(data [text]
text/format
[number]
+ [maybe]
(coll ["&" dict]
[list "L/" Fold<List> Functor<List>]))
["r" math/random])
@@ -59,7 +60,7 @@
(test "Shouldn't be able to put~ an existing key."
(or (n.= +0 size)
- (let [first-key (|> dict &;keys list;head (default (undefined)))]
+ (let [first-key (|> dict &;keys list;head maybe;assume)]
(case (&;get first-key (&;put~ first-key test-val dict))
(#;Some v) (not (n.= test-val v))
_ true))))
@@ -115,13 +116,11 @@
(test "Should be able to re-bind existing values to different keys."
(or (n.= +0 size)
- (let [first-key (|> dict &;keys list;head (default (undefined)))
+ (let [first-key (|> dict &;keys list;head maybe;assume)
rebound (&;re-bind first-key non-key dict)]
(and (n.= (&;size dict) (&;size rebound))
(&;contains? non-key rebound)
(not (&;contains? first-key rebound))
- (n.= (default (undefined)
- (&;get first-key dict))
- (default (undefined)
- (&;get non-key rebound)))))))
+ (n.= (maybe;assume (&;get first-key dict))
+ (maybe;assume (&;get non-key rebound)))))))
))
diff --git a/stdlib/test/test/lux/data/coll/list.lux b/stdlib/test/test/lux/data/coll/list.lux
index 08bd547f4..087c9d831 100644
--- a/stdlib/test/test/lux/data/coll/list.lux
+++ b/stdlib/test/test/lux/data/coll/list.lux
@@ -7,7 +7,8 @@
[text "Text/" Monoid<Text>]
[number]
[bool]
- [product])
+ [product]
+ [maybe])
["R" math/random])
lux/test)
@@ -56,8 +57,7 @@
(&;any? (bool;complement n.even?) sample)))
(test "Any element of the list can be considered its member."
- (let [elem (default (undefined)
- (&;nth idx sample))]
+ (let [elem (maybe;assume (&;nth idx sample))]
(&;member? number;Eq<Nat> sample elem)))
))
@@ -72,19 +72,15 @@
(^open "&/") &;Functor<List>]]
($_ seq
(test "Appending the head and the tail should yield the original list."
- (let [head (default (undefined)
- (&;head sample))
- tail (default (undefined)
- (&;tail sample))]
+ (let [head (maybe;assume (&;head sample))
+ tail (maybe;assume (&;tail sample))]
(= sample
(#;Cons head tail))))
(test "Appending the inits and the last should yield the original list."
(let [(^open) &;Monoid<List>
- inits (default (undefined)
- (&;inits sample))
- last (default (undefined)
- (&;last sample))]
+ inits (maybe;assume (&;inits sample))
+ last (maybe;assume (&;last sample))]
(= sample
(append inits (list last)))))
diff --git a/stdlib/test/test/lux/data/coll/priority-queue.lux b/stdlib/test/test/lux/data/coll/priority-queue.lux
index d2fdb9969..51b9aee5e 100644
--- a/stdlib/test/test/lux/data/coll/priority-queue.lux
+++ b/stdlib/test/test/lux/data/coll/priority-queue.lux
@@ -3,7 +3,8 @@
(lux [io]
(control [monad #+ do Monad])
(data (coll ["&" priority-queue])
- [number])
+ [number]
+ [maybe])
["R" math/random])
lux/test)
@@ -42,8 +43,8 @@
(or (n.= +0 (&;size sample))
(and (&;member? number;Eq<Nat>
sample
- (default (undefined) (&;peek sample)))
+ (maybe;assume (&;peek sample)))
(not (&;member? number;Eq<Nat>
(&;pop sample)
- (default (undefined) (&;peek sample))))))))
+ (maybe;assume (&;peek sample))))))))
))
diff --git a/stdlib/test/test/lux/data/coll/stack.lux b/stdlib/test/test/lux/data/coll/stack.lux
index 60fb1a4bd..981d73197 100644
--- a/stdlib/test/test/lux/data/coll/stack.lux
+++ b/stdlib/test/test/lux/data/coll/stack.lux
@@ -4,7 +4,8 @@
(control [monad #+ do Monad])
(data (coll ["&" stack]
[list "" Fold<List>])
- [number])
+ [number]
+ [maybe])
["R" math/random])
lux/test)
@@ -37,6 +38,6 @@
(and (is sample
(&;pop (&;push new-top sample)))
(n.= (n.inc (&;size sample)) (&;size (&;push new-top sample)))
- (|> (&;push new-top sample) &;peek (default (undefined))
+ (|> (&;push new-top sample) &;peek maybe;assume
(is new-top))))
))
diff --git a/stdlib/test/test/lux/data/coll/stream.lux b/stdlib/test/test/lux/data/coll/stream.lux
index 0dfc03ed2..053228278 100644
--- a/stdlib/test/test/lux/data/coll/stream.lux
+++ b/stdlib/test/test/lux/data/coll/stream.lux
@@ -4,7 +4,8 @@
(control [monad #+ do Monad]
comonad
[cont])
- (data [text "Text/" Monoid<Text>]
+ (data [maybe]
+ [text "Text/" Monoid<Text>]
text/format
(coll [list]
["&" stream])
@@ -91,9 +92,9 @@
(test "Can cycle over the same elements as an infinite stream."
(|> (&;cycle cycle-seed)
- (default (undefined))
+ maybe;assume
(&;nth cycle-sample-idx)
- (n.= (default (undefined)
- (list;nth (n.% size cycle-sample-idx)
- cycle-seed)))))
+ (n.= (|> cycle-seed
+ (list;nth (n.% size cycle-sample-idx))
+ maybe;assume))))
))
diff --git a/stdlib/test/test/lux/data/coll/tree/zipper.lux b/stdlib/test/test/lux/data/coll/tree/zipper.lux
index 9154459b9..a65292cf0 100644
--- a/stdlib/test/test/lux/data/coll/tree/zipper.lux
+++ b/stdlib/test/test/lux/data/coll/tree/zipper.lux
@@ -8,7 +8,8 @@
[rose]))
[text]
text/format
- [number])
+ [number]
+ [maybe])
["r" math/random])
lux/test)
@@ -76,9 +77,9 @@
zipper (|> zipper
&;down
(&;insert-left pre-val)
- (default (undefined))
+ maybe;assume
(&;insert-right post-val)
- (default (undefined))
+ maybe;assume
&;up)]
(and (|> zipper &;down &;value (is pre-val))
(|> zipper &;down &;right &;value (is mid-val))
diff --git a/stdlib/test/test/lux/data/coll/vector.lux b/stdlib/test/test/lux/data/coll/vector.lux
index f197b8f10..2d7d00576 100644
--- a/stdlib/test/test/lux/data/coll/vector.lux
+++ b/stdlib/test/test/lux/data/coll/vector.lux
@@ -6,7 +6,8 @@
[list "List/" Fold<List> Functor<List>])
[text "Text/" Monoid<Text>]
text/format
- [number])
+ [number]
+ [maybe])
["R" math/random])
lux/test)
@@ -35,13 +36,13 @@
(|> sample
(&;put idx non-member)
(&;nth idx)
- (default (undefined))
+ maybe;assume
(is non-member)))
(test "Can update elements of vectors."
(|> sample
(&;put idx non-member) (&;update idx n.inc)
- (&;nth idx) (default (undefined))
+ (&;nth idx) maybe;assume
(n.= (n.inc non-member))))
(test "Can safely transform to/from lists."
diff --git a/stdlib/test/test/lux/data/format/xml.lux b/stdlib/test/test/lux/data/format/xml.lux
index 382659ab0..b43aee394 100644
--- a/stdlib/test/test/lux/data/format/xml.lux
+++ b/stdlib/test/test/lux/data/format/xml.lux
@@ -8,6 +8,7 @@
text/format
[ident]
["R" result]
+ [maybe]
(format ["&" xml])
(coll [dict]
[list "L/" Functor<List>]))
@@ -25,7 +26,7 @@
(r;Random Nat)
(do r;Monad<Random>
[idx (|> r;nat (:: @ map (n.% (text;size char-range))))]
- (wrap (assume (text;nth idx char-range)))))
+ (wrap (maybe;assume (text;nth idx char-range)))))
(def: (size^ bottom top)
(-> Nat Nat (r;Random Nat))
diff --git a/stdlib/test/test/lux/type.lux b/stdlib/test/test/lux/type.lux
index 3e50f2035..8c149e3f4 100644
--- a/stdlib/test/test/lux/type.lux
+++ b/stdlib/test/test/lux/type.lux
@@ -6,7 +6,7 @@
(data [text "Text/" Monoid<Text>]
text/format
[number]
- maybe
+ [maybe]
(coll [list]))
["R" math/random]
["&" type])
@@ -51,8 +51,8 @@
(context: "Type application"
(test "Can apply quantified types (universal and existential quantification)."
- (and (default false
- (do Monad<Maybe>
+ (and (maybe;default false
+ (do maybe;Monad<Maybe>
[partial (&;apply (list Bool) Meta)
full (&;apply (list Int) partial)]
(wrap (:: &;Eq<Type> = full (#;Product Bool Int)))))