diff options
author | Eduardo Julian | 2018-12-15 18:32:31 -0400 |
---|---|---|
committer | Eduardo Julian | 2018-12-15 18:32:31 -0400 |
commit | ee0c268d2e7922ce4d1b1b11291e6858977cce74 (patch) | |
tree | e8dcd01dd4b07727f79892278d146403d56a16fe /stdlib | |
parent | 5f7896ac2cfa8cc9b3ca79c922438412e440a922 (diff) |
Re-named the "Error" tag to "Failure".
Diffstat (limited to 'stdlib')
65 files changed, 681 insertions, 640 deletions
diff --git a/stdlib/source/lux/cli.lux b/stdlib/source/lux/cli.lux index 34514b5b9..b86b2a51b 100644 --- a/stdlib/source/lux/cli.lux +++ b/stdlib/source/lux/cli.lux @@ -34,10 +34,10 @@ (#error.Success output) _ - (#error.Error (format "Remaining CLI inputs: " (text.join-with " " remaining)))) + (#error.Failure (format "Remaining CLI inputs: " (text.join-with " " remaining)))) - (#error.Error error) - (#error.Error error))) + (#error.Failure error) + (#error.Failure error))) (def: #export any {#.doc "Just returns the next input without applying any logic."} @@ -48,7 +48,7 @@ (#error.Success [inputs' arg]) _ - (#error.Error "Cannot parse empty arguments.")))) + (#error.Failure "Cannot parse empty arguments.")))) (def: #export (parse parser) {#.doc "Parses the next input with a parsing function."} @@ -78,10 +78,10 @@ (#error.Success [remaining output]) (#error.Success [remaining output]) - (#error.Error error) + (#error.Failure error) (case immediate #.Nil - (#error.Error error) + (#error.Failure error) (#.Cons to-omit immediate') (do error.Monad<Error> @@ -95,7 +95,7 @@ (function (_ inputs) (case inputs #.Nil (#error.Success [inputs []]) - _ (#error.Error (format "Unknown parameters: " (text.join-with " " inputs)))))) + _ (#error.Failure (format "Unknown parameters: " (text.join-with " " inputs)))))) (def: #export (named name value) (All [a] (-> Text (CLI a) (CLI a))) @@ -171,7 +171,7 @@ (#error.Success [(~ g!_) (~ g!output)]) (~ g!output) - (#error.Error (~ g!message)) + (#error.Failure (~ g!message)) (.error! (~ g!message)) )))) ))) diff --git a/stdlib/source/lux/control/codec.lux b/stdlib/source/lux/control/codec.lux index 5e274e766..d2641fe38 100644 --- a/stdlib/source/lux/control/codec.lux +++ b/stdlib/source/lux/control/codec.lux @@ -1,14 +1,16 @@ (.module: [lux #* - [control monad] - [data ["e" error]]]) + [control + monad] + [data + ["." error (#+ Error)]]]) ## [Signatures] (signature: #export (Codec m a) {#.doc "A way to move back-and-forth between a type and an alternative representation for it."} (: (-> a m) encode) - (: (-> m (e.Error a)) + (: (-> m (Error a)) decode)) ## [Values] @@ -22,6 +24,6 @@ (:: Codec<c,b> encode))) (def: (decode cy) - (do e.Monad<Error> + (do error.Monad<Error> [by (:: Codec<c,b> decode cy)] (:: Codec<b,a> decode by)))) diff --git a/stdlib/source/lux/control/concurrency/actor.lux b/stdlib/source/lux/control/concurrency/actor.lux index 0af0d09f9..6f4ddf2ad 100644 --- a/stdlib/source/lux/control/concurrency/actor.lux +++ b/stdlib/source/lux/control/concurrency/actor.lux @@ -82,7 +82,7 @@ [[head tail] |mailbox| ?state' (handle head state self)] (case ?state' - (#e.Error error) + (#e.Failure error) (do @ [_ (end error state)] (exec (io.run (promise.resolve [error state (#.Cons head (obituary tail))] diff --git a/stdlib/source/lux/control/concurrency/task.lux b/stdlib/source/lux/control/concurrency/task.lux index c03ab7647..96bc40f0a 100644 --- a/stdlib/source/lux/control/concurrency/task.lux +++ b/stdlib/source/lux/control/concurrency/task.lux @@ -17,7 +17,7 @@ (def: #export (fail error) (All [a] (-> Text (Task a))) - (:: promise.Monad<Promise> wrap (#error.Error error))) + (:: promise.Monad<Promise> wrap (#error.Failure error))) (def: #export (throw exception message) (All [e a] (-> (Exception e) e (Task a))) @@ -37,8 +37,8 @@ (:: promise.Functor<Promise> map (function (_ fa') (case fa' - (#error.Error error) - (#error.Error error) + (#error.Failure error) + (#error.Failure error) (#error.Success a) (#error.Success (f a)))) @@ -65,8 +65,8 @@ (do promise.Monad<Promise> [mma' mma] (case mma' - (#error.Error error) - (wrap (#error.Error error)) + (#error.Failure error) + (wrap (#error.Failure error)) (#error.Success ma) ma)))) diff --git a/stdlib/source/lux/control/exception.lux b/stdlib/source/lux/control/exception.lux index ca6ab6540..c5fa9632c 100644 --- a/stdlib/source/lux/control/exception.lux +++ b/stdlib/source/lux/control/exception.lux @@ -40,14 +40,14 @@ (#//.Success output) (#//.Success output) - (#//.Error error) + (#//.Failure error) (let [reference (get@ #label exception)] (if (text.starts-with? reference error) (#//.Success (|> error (text.clip (text.size reference) (text.size error)) maybe.assume then)) - (#//.Error error))))) + (#//.Failure error))))) (def: #export (otherwise to-do try) {#.doc "If no handler could be found to catch the exception, then run a function as a last-resort measure."} @@ -57,7 +57,7 @@ (#//.Success output) output - (#//.Error error) + (#//.Failure error) (to-do error))) (def: #export (return value) @@ -73,7 +73,7 @@ (def: #export (throw exception message) {#.doc "Decorate an error message with an Exception and lift it into the error-handling context."} (All [e] (-> (Exception e) e Error)) - (#//.Error (construct exception message))) + (#//.Failure (construct exception message))) (def: #export (assert exception message test) (All [e] (-> (Exception e) e Bit (Error Any))) @@ -139,16 +139,16 @@ (def: #export (with-stack exception message computation) (All [e a] (-> (Exception e) e (Error a) (Error a))) (case computation - (#//.Error error) - (#//.Error (case error - "" - (..construct exception message) - - _ - ($_ "lux text concat" - (..construct exception message) - ..separator - error))) + (#//.Failure error) + (#//.Failure (case error + "" + (..construct exception message) + + _ + ($_ "lux text concat" + (..construct exception message) + ..separator + error))) success success)) diff --git a/stdlib/source/lux/control/parser.lux b/stdlib/source/lux/control/parser.lux index c40de3373..4b4ef0d34 100644 --- a/stdlib/source/lux/control/parser.lux +++ b/stdlib/source/lux/control/parser.lux @@ -9,22 +9,22 @@ [collection ["." list ("list/." Functor<List> Monoid<List>)]] ["." product] - ["e" error (#+ Error)]]]) + ["." error (#+ Error)]]]) (type: #export (Parser s a) {#.doc "A generic parser."} - (-> s (e.Error [s a]))) + (-> s (Error [s a]))) ## [Structures] (structure: #export Functor<Parser> (All [s] (Functor (Parser s))) (def: (map f ma) (function (_ input) (case (ma input) - (#e.Error msg) - (#e.Error msg) + (#error.Failure msg) + (#error.Failure msg) - (#e.Success [input' a]) - (#e.Success [input' (f a)]))))) + (#error.Success [input' a]) + (#error.Success [input' (f a)]))))) (structure: #export Apply<Parser> (All [s] (Apply (Parser s))) (def: functor Functor<Parser>) @@ -32,31 +32,31 @@ (def: (apply ff fa) (function (_ input) (case (ff input) - (#e.Success [input' f]) + (#error.Success [input' f]) (case (fa input') - (#e.Success [input'' a]) - (#e.Success [input'' (f a)]) + (#error.Success [input'' a]) + (#error.Success [input'' (f a)]) - (#e.Error msg) - (#e.Error msg)) + (#error.Failure msg) + (#error.Failure msg)) - (#e.Error msg) - (#e.Error msg))))) + (#error.Failure msg) + (#error.Failure msg))))) (structure: #export Monad<Parser> (All [s] (Monad (Parser s))) (def: functor Functor<Parser>) (def: (wrap x) (function (_ input) - (#e.Success [input x]))) + (#error.Success [input x]))) (def: (join mma) (function (_ input) (case (mma input) - (#e.Error msg) - (#e.Error msg) + (#error.Failure msg) + (#error.Failure msg) - (#e.Success [input' ma]) + (#error.Success [input' ma]) (ma input'))))) ## [Parsers] @@ -65,8 +65,8 @@ (All [s] (-> Text Bit (Parser s Any))) (function (_ input) (if test - (#e.Success [input []]) - (#e.Error message)))) + (#error.Success [input []]) + (#error.Failure message)))) (def: #export (maybe p) {#.doc "Optionality combinator."} @@ -74,12 +74,15 @@ (-> (Parser s a) (Parser s (Maybe a)))) (function (_ input) (case (p input) - (#e.Error _) (#e.Success [input #.None]) - (#e.Success [input' x]) (#e.Success [input' (#.Some x)])))) + (#error.Failure _) + (#error.Success [input #.None]) + + (#error.Success [input' x]) + (#error.Success [input' (#.Some x)])))) (def: #export (run input p) (All [s a] - (-> s (Parser s a) (e.Error [s a]))) + (-> s (Parser s a) (Error [s a]))) (p input)) (def: #export (some p) @@ -88,12 +91,15 @@ (-> (Parser s a) (Parser s (List a)))) (function (_ input) (case (p input) - (#e.Error _) (#e.Success [input (list)]) - (#e.Success [input' x]) (run input' - (do Monad<Parser> - [xs (some p)] - (wrap (list& x xs))) - )))) + (#error.Failure _) + (#error.Success [input (list)]) + + (#error.Success [input' x]) + (run input' + (do Monad<Parser> + [xs (some p)] + (wrap (list& x xs))) + )))) (def: #export (many p) {#.doc "1-or-more combinator."} @@ -119,11 +125,14 @@ (-> (Parser s a) (Parser s b) (Parser s (| a b)))) (function (_ tokens) (case (p1 tokens) - (#e.Success [tokens' x1]) (#e.Success [tokens' (0 x1)]) - (#e.Error _) (run tokens - (do Monad<Parser> - [x2 p2] - (wrap (1 x2)))) + (#error.Success [tokens' x1]) + (#error.Success [tokens' (0 x1)]) + + (#error.Failure _) + (run tokens + (do Monad<Parser> + [x2 p2] + (wrap (1 x2)))) ))) (def: #export (either pl pr) @@ -132,8 +141,11 @@ (-> (Parser s a) (Parser s a) (Parser s a))) (function (_ tokens) (case (pl tokens) - (#e.Error _) (pr tokens) - output output + (#error.Failure _) + (pr tokens) + + output + output ))) (def: #export (exactly n p) @@ -160,10 +172,10 @@ (if (n/> 0 n) (function (_ input) (case (p input) - (#e.Error msg) - (#e.Success [input (list)]) + (#error.Failure msg) + (#error.Success [input (list)]) - (#e.Success [input' x]) + (#error.Success [input' x]) (run input' (do Monad<Parser> [xs (at-most (dec n) p)] @@ -198,42 +210,42 @@ (All [s a] (-> (Parser s a) (Parser s Any))) (function (_ input) (case (p input) - (#e.Error msg) - (#e.Success [input []]) + (#error.Failure msg) + (#error.Success [input []]) _ - (#e.Error "Expected to fail; yet succeeded.")))) + (#error.Failure "Expected to fail; yet succeeded.")))) (def: #export (fail message) (All [s a] (-> Text (Parser s a))) (function (_ input) - (#e.Error message))) + (#error.Failure message))) (def: #export (lift operation) (All [s a] (-> (Error a) (Parser s a))) (function (_ input) (case operation - (#e.Success output) - (#e.Success [input output]) + (#error.Success output) + (#error.Success [input output]) - (#e.Error error) - (#e.Error error)))) + (#error.Failure error) + (#error.Failure error)))) (def: #export (default value parser) {#.doc "If the given parser fails, returns the default value."} (All [s a] (-> a (Parser s a) (Parser s a))) (function (_ input) (case (parser input) - (#e.Error error) - (#e.Success [input value]) + (#error.Failure error) + (#error.Success [input value]) - (#e.Success [input' output]) - (#e.Success [input' output])))) + (#error.Success [input' output]) + (#error.Success [input' output])))) (def: #export remaining (All [s] (Parser s s)) (function (_ inputs) - (#e.Success [inputs inputs]))) + (#error.Success [inputs inputs]))) (def: #export (rec parser) {#.doc "Combinator for recursive parser."} @@ -265,13 +277,13 @@ (All [s a z] (-> (Codec a z) (Parser s a) (Parser s z))) (function (_ input) (case (parser input) - (#e.Error error) - (#e.Error error) + (#error.Failure error) + (#error.Failure error) - (#e.Success [input' to-decode]) + (#error.Success [input' to-decode]) (case (:: Codec<a,z> decode to-decode) - (#e.Error error) - (#e.Error error) + (#error.Failure error) + (#error.Failure error) - (#e.Success value) - (#e.Success [input' value]))))) + (#error.Success value) + (#error.Success [input' value]))))) diff --git a/stdlib/source/lux/control/region.lux b/stdlib/source/lux/control/region.lux index cfd074f6b..e014777dd 100644 --- a/stdlib/source/lux/control/region.lux +++ b/stdlib/source/lux/control/region.lux @@ -6,7 +6,7 @@ ["." monad (#+ Monad do)] ["ex" exception (#+ Exception exception:)]] [data - ["e" error (#+ Error)] + ["." error (#+ Error)] ["." text format] [collection @@ -32,20 +32,20 @@ {output (Error a)}) (format error (case output - (#e.Success _) + (#error.Success _) "" - (#e.Error error|output) + (#error.Failure error|output) (format separator error|output)))) (def: (combine-outcomes clean-up output) (All [a] (-> (Error Any) (Error a) (Error a))) (case clean-up - (#e.Success _) + (#error.Success _) output - (#e.Error error|clean-up) + (#error.Failure error|clean-up) (ex.throw clean-up-error [error|clean-up output]))) (def: #export (run Monad<m> computation) @@ -64,7 +64,7 @@ (function (_ [region cleaners]) (:: Monad<m> wrap [(#.Cons (function (_ region) (cleaner value)) cleaners) - (#e.Success value)]))) + (#error.Success value)]))) (structure: #export (Functor<Region> Functor<m>) (All [m] @@ -77,11 +77,11 @@ (:: Functor<m> map (function (_ [cleaners' temp]) [cleaners' (case temp - (#e.Success value) - (#e.Success (f value)) + (#error.Success value) + (#error.Success (f value)) - (#e.Error error) - (#e.Error error))]) + (#error.Failure error) + (#error.Failure error))]) (fa region+cleaners)))))) (structure: #export (Apply<Region> Monad<m>) @@ -98,12 +98,12 @@ [[cleaners ef] (ff [region cleaners]) [cleaners ea] (fa [region cleaners])] (case [ef ea] - [(#e.Success f) (#e.Success a)] - (wrap [cleaners (#e.Success (f a))]) + [(#error.Success f) (#error.Success a)] + (wrap [cleaners (#error.Success (f a))]) - (^or [(#e.Error error) _] - [_ (#e.Error error)]) - (wrap [cleaners (#e.Error error)])))))) + (^or [(#error.Failure error) _] + [_ (#error.Failure error)]) + (wrap [cleaners (#error.Failure error)])))))) (structure: #export (Monad<Region> Monad<m>) (All [m] @@ -115,25 +115,25 @@ (def: (wrap value) (function (_ [region cleaners]) - (:: Monad<m> wrap [cleaners (#e.Success value)]))) + (:: Monad<m> wrap [cleaners (#error.Success value)]))) (def: (join ffa) (function (_ [region cleaners]) (do Monad<m> [[cleaners efa] (ffa [region cleaners])] (case efa - (#e.Success fa) + (#error.Success fa) (fa [region cleaners]) - (#e.Error error) - (wrap [cleaners (#e.Error error)])))))) + (#error.Failure error) + (wrap [cleaners (#error.Failure error)])))))) (def: #export (fail Monad<m> error) (All [m a] (-> (Monad m) Text (All [r] (Region r m a)))) (function (_ [region cleaners]) - (:: Monad<m> wrap [cleaners (#e.Error error)]))) + (:: Monad<m> wrap [cleaners (#error.Failure error)]))) (def: #export (throw Monad<m> exception message) (All [m e a] @@ -149,4 +149,4 @@ (function (_ [region cleaners]) (do Monad<m> [output operation] - (wrap [cleaners (#e.Success output)])))) + (wrap [cleaners (#error.Success output)])))) diff --git a/stdlib/source/lux/data/collection/tree/rose/parser.lux b/stdlib/source/lux/data/collection/tree/rose/parser.lux index 5364be8c5..ba24cd908 100644 --- a/stdlib/source/lux/data/collection/tree/rose/parser.lux +++ b/stdlib/source/lux/data/collection/tree/rose/parser.lux @@ -4,7 +4,7 @@ ["p" parser] ["ex" exception (#+ exception:)]] [data - ["E" error]]] + ["." error (#+ Error)]]] [// (#+ Tree) ["." zipper (#+ Zipper)]]) @@ -12,22 +12,22 @@ (p.Parser (Zipper t) a)) (def: #export (run-zipper zipper parser) - (All [t a] (-> (Zipper t) (Parser t a) (E.Error a))) + (All [t a] (-> (Zipper t) (Parser t a) (Error a))) (case (p.run zipper parser) - (#E.Success [zipper output]) - (#E.Success output) + (#error.Success [zipper output]) + (#error.Success output) - (#E.Error error) - (#E.Error error))) + (#error.Failure error) + (#error.Failure error))) (def: #export (run tree parser) - (All [t a] (-> (Tree t) (Parser t a) (E.Error a))) + (All [t a] (-> (Tree t) (Parser t a) (Error a))) (run-zipper (zipper.zip tree) parser)) (def: #export value (All [t] (Parser t t)) (function (_ zipper) - (#E.Success [zipper (zipper.value zipper)]))) + (#error.Success [zipper (zipper.value zipper)]))) (exception: #export cannot-move-further) @@ -38,7 +38,7 @@ (let [next (<direction> zipper)] (if (is? zipper next) (ex.throw cannot-move-further []) - (#E.Success [next []])))))] + (#error.Success [next []])))))] [up zipper.up] [down zipper.down] diff --git a/stdlib/source/lux/data/error.lux b/stdlib/source/lux/data/error.lux index 17d88a5a0..fc30718af 100644 --- a/stdlib/source/lux/data/error.lux +++ b/stdlib/source/lux/data/error.lux @@ -7,15 +7,18 @@ ## [Types] (type: #export (Error a) - (#Error Text) + (#Failure Text) (#Success a)) ## [Structures] (structure: #export _ (F.Functor Error) (def: (map f ma) (case ma - (#Error msg) (#Error msg) - (#Success datum) (#Success (f datum))))) + (#Failure msg) + (#Failure msg) + + (#Success datum) + (#Success (f datum))))) (structure: #export _ (A.Apply Error) (def: functor Functor<Error>) @@ -27,11 +30,11 @@ (#Success a) (#Success (f a)) - (#Error msg) - (#Error msg)) + (#Failure msg) + (#Failure msg)) - (#Error msg) - (#Error msg)) + (#Failure msg) + (#Failure msg)) )) (structure: #export _ (Monad Error) @@ -42,8 +45,11 @@ (def: (join mma) (case mma - (#Error msg) (#Error msg) - (#Success ma) ma))) + (#Failure msg) + (#Failure msg) + + (#Success ma) + ma))) (structure: #export (ErrorT Monad<M>) (All [M] (-> (Monad M) (Monad (All [a] (M (Error a)))))) @@ -56,8 +62,8 @@ (do Monad<M> [eMea MeMea] (case eMea - (#Error error) - (wrap (#Error error)) + (#Failure error) + (wrap (#Failure error)) (#Success Mea) Mea)))) @@ -72,7 +78,7 @@ (def: #export (fail message) (All [a] (-> Text (Error a))) - (#Error message)) + (#Failure message)) (def: #export (assume error) (All [a] (-> (Error a) a)) @@ -80,24 +86,24 @@ (#Success value) value - (#Error message) + (#Failure message) (error! message))) (macro: #export (default tokens compiler) {#.doc (doc "Allows you to provide a default value that will be used" - "if a (Error x) value turns out to be #Error." + "if a (Error x) value turns out to be #Failure." (is? +10 (default +20 (#Success +10))) (is? +20 - (default +20 (#Error "KABOOM!"))))} + (default +20 (#Failure "KABOOM!"))))} (case tokens (^ (list else error)) (#Success [compiler (list (` (case (~ error) (#..Success (~' g!temp)) (~' g!temp) - (#..Error (~ [dummy-cursor (#.Identifier ["" ""])])) + (#..Failure (~ [dummy-cursor (#.Identifier ["" ""])])) (~ else))))]) _ - (#Error "Wrong syntax for default"))) + (#Failure "Wrong syntax for default"))) diff --git a/stdlib/source/lux/data/format/binary.lux b/stdlib/source/lux/data/format/binary.lux index 4657b48d5..b21887854 100644 --- a/stdlib/source/lux/data/format/binary.lux +++ b/stdlib/source/lux/data/format/binary.lux @@ -47,8 +47,8 @@ (def: #export (read format input) (All [a] (-> (Format a) Binary (Error a))) (case ((get@ #read format) [0 input]) - (#error.Error msg) - (#error.Error msg) + (#error.Failure msg) + (#error.Failure msg) (#error.Success [[end _] output]) (let [length (binary.size input)] @@ -70,8 +70,8 @@ (#error.Success data) (#error.Success [(n/+ <size> offset) binary] data) - (#error.Error error) - (#error.Error error))) + (#error.Failure error) + (#error.Failure error))) #write (function (_ value) [<size> (function (_ offset binary) @@ -163,8 +163,8 @@ _ (ex.throw invalid-tag [2 data])) - (#error.Error error) - (#error.Error error))) + (#error.Failure error) + (#error.Failure error))) #write (function (_ value) [1 (function (_ offset binary) diff --git a/stdlib/source/lux/data/format/context.lux b/stdlib/source/lux/data/format/context.lux index b5d86139a..749185f85 100644 --- a/stdlib/source/lux/data/format/context.lux +++ b/stdlib/source/lux/data/format/context.lux @@ -36,5 +36,5 @@ (#error.Success [_ output]) (#error.Success output) - (#error.Error error) - (#error.Error error))) + (#error.Failure error) + (#error.Failure error))) diff --git a/stdlib/source/lux/data/format/json.lux b/stdlib/source/lux/data/format/json.lux index 63075804e..7d2e90270 100644 --- a/stdlib/source/lux/data/format/json.lux +++ b/stdlib/source/lux/data/format/json.lux @@ -102,7 +102,7 @@ (#error.Success (dictionary.keys obj)) _ - (#error.Error ($_ text/compose "Cannot get the fields of a non-object.")))) + (#error.Failure ($_ text/compose "Cannot get the fields of a non-object.")))) (def: #export (get key json) {#.doc "A JSON object field getter."} @@ -114,10 +114,10 @@ (#error.Success value) #.None - (#error.Error ($_ text/compose "Missing field '" key "' on object."))) + (#error.Failure ($_ text/compose "Missing field '" key "' on object."))) _ - (#error.Error ($_ text/compose "Cannot get field '" key "' of a non-object.")))) + (#error.Failure ($_ text/compose "Cannot get field '" key "' of a non-object.")))) (def: #export (set key value json) {#.doc "A JSON object field setter."} @@ -127,7 +127,7 @@ (#error.Success (#Object (dictionary.put key value obj))) _ - (#error.Error ($_ text/compose "Cannot set field '" key "' of a non-object.")))) + (#error.Failure ($_ text/compose "Cannot set field '" key "' of a non-object.")))) (do-template [<name> <tag> <type> <desc>] [(def: #export (<name> key json) @@ -138,10 +138,10 @@ (#error.Success value) (#error.Success _) - (#error.Error ($_ text/compose "Wrong value type at key: " key)) + (#error.Failure ($_ text/compose "Wrong value type at key: " key)) - (#error.Error error) - (#error.Error error)))] + (#error.Failure error) + (#error.Failure error)))] [get-boolean #Boolean Boolean "booleans"] [get-number #Number Number "numbers"] @@ -258,13 +258,13 @@ _ (ex.throw unconsumed-input remainder)) - (#error.Error error) - (#error.Error error))) + (#error.Failure error) + (#error.Failure error))) (def: #export (fail error) (All [a] (-> Text (Reader a))) (function (_ inputs) - (#error.Error error))) + (#error.Failure error))) (def: #export any {#.doc "Just returns the JSON input without applying any logic."} @@ -342,7 +342,7 @@ (case head (#Array values) (case (p.run (row.to-list values) parser) - (#error.Error error) + (#error.Failure error) (fail error) (#error.Success [remainder output]) @@ -369,7 +369,7 @@ (list (#String key) value))) list.concat) parser) - (#error.Error error) + (#error.Failure error) (fail error) (#error.Success [remainder output]) @@ -397,8 +397,8 @@ (#error.Success [inputs'' _]) (ex.throw unconsumed-input inputs'') - (#error.Error error) - (#error.Error error)) + (#error.Failure error) + (#error.Failure error)) (do error.Monad<Error> [[inputs'' output] (recur inputs')] (wrap [(list& (#String key) value inputs'') @@ -459,7 +459,7 @@ offset (l.many l.decimal)] (wrap ($_ text/compose mark (if signed?' "-" "") offset))))] (case (frac/decode ($_ text/compose (if signed? "-" "") digits "." decimals exp)) - (#error.Error message) + (#error.Failure message) (p.fail message) (#error.Success value) diff --git a/stdlib/source/lux/data/format/xml.lux b/stdlib/source/lux/data/format/xml.lux index 0ed744b46..e1cbda0db 100644 --- a/stdlib/source/lux/data/format/xml.lux +++ b/stdlib/source/lux/data/format/xml.lux @@ -8,7 +8,7 @@ ["ex" exception (#+ exception:)]] [data ["." number] - ["E" error] + ["." error (#+ Error)] ["." product] ["." name ("name/." Equivalence<Name> Codec<Text,Name>)] ["." text ("text/." Equivalence<Text> Monoid<Text>) @@ -171,7 +171,7 @@ (p.after (p.maybe xml-header^)))) (def: #export (read input) - (-> Text (E.Error XML)) + (-> Text (Error XML)) (l.run input xml^)) (def: (sanitize-value input) @@ -271,7 +271,7 @@ (#.Cons head tail) (case head (#Text value) - (#E.Success [tail value]) + (#error.Success [tail value]) (#Node _) (ex.throw unexpected-input []))))) @@ -294,18 +294,18 @@ (ex.throw unknown-attribute []) (#.Some value) - (#E.Success [docs value])))))) + (#error.Success [docs value])))))) (def: (run' docs reader) - (All [a] (-> (List XML) (Reader a) (E.Error a))) + (All [a] (-> (List XML) (Reader a) (Error a))) (case (p.run docs reader) - (#E.Success [remaining output]) + (#error.Success [remaining output]) (if (list.empty? remaining) - (#E.Success output) + (#error.Success output) (ex.throw unconsumed-inputs remaining)) - (#E.Error error) - (#E.Error error))) + (#error.Failure error) + (#error.Failure error))) (def: #export (node tag) (-> Name (Reader Any)) @@ -321,7 +321,7 @@ (#Node _tag _attrs _children) (if (name/= tag _tag) - (#E.Success [docs []]) + (#error.Success [docs []]) (ex.throw wrong-tag tag)))))) (def: #export (children reader) @@ -337,7 +337,7 @@ (ex.throw unexpected-input []) (#Node _tag _attrs _children) - (do E.Monad<Error> + (do error.Monad<Error> [output (run' _children reader)] (wrap [tail output])))))) @@ -349,8 +349,8 @@ (ex.throw empty-input []) (#.Cons head tail) - (#E.Success [tail []])))) + (#error.Success [tail []])))) (def: #export (run document reader) - (All [a] (-> XML (Reader a) (E.Error a))) + (All [a] (-> XML (Reader a) (Error a))) (run' (list document) reader)) diff --git a/stdlib/source/lux/data/number.lux b/stdlib/source/lux/data/number.lux index efd965d1b..b133e905f 100644 --- a/stdlib/source/lux/data/number.lux +++ b/stdlib/source/lux/data/number.lux @@ -172,7 +172,7 @@ (#error.Success value) #.None - (#error.Error <error>))))] + (#error.Failure <error>))))] [Frac "lux frac encode" "lux frac decode" "Could not decode Frac"] ) @@ -316,13 +316,13 @@ (if (n/< input-size idx) (case (<to-value> (get-char! repr idx)) #.None - (#error.Error ("lux text concat" <error> repr)) + (#error.Failure ("lux text concat" <error> repr)) (#.Some digit-value) (recur (inc idx) (|> output (n/* <base>) (n/+ digit-value)))) (#error.Success output))) - (#error.Error ("lux text concat" <error> repr))))))] + (#error.Failure ("lux text concat" <error> repr))))))] [Binary@Codec<Text,Nat> 2 binary-character binary-value "Invalid binary syntax for Nat: "] [Octal@Codec<Text,Nat> 8 octal-character octal-value "Invalid octal syntax for Nat: "] @@ -355,7 +355,7 @@ (if (n/< input-size idx) (case (<to-value> (get-char! repr idx)) #.None - (#error.Error <error>) + (#error.Failure <error>) (#.Some digit-value) (recur (inc idx) @@ -385,8 +385,8 @@ (int-decode-loop input-size repr sign <base> <to-value> <error>) #.None - (#error.Error <error>)) - (#error.Error <error>)))))] + (#error.Failure <error>)) + (#error.Failure <error>)))))] [Binary@Codec<Text,Int> +2 binary-character binary-value "Invalid binary syntax for Int: "] [Octal@Codec<Text,Int> +8 octal-character octal-value "Invalid octal syntax for Int: "] @@ -399,7 +399,7 @@ ("lux text clip" input 1 ("lux text size" input))) (do-template [<struct> <nat> <char-bit-size> <error>] - [(with-expansions [<error-output> (as-is (#error.Error ("lux text concat" <error> repr)))] + [(with-expansions [<error-output> (as-is (#error.Failure ("lux text concat" <error> repr)))] (structure: #export <struct> (Codec Text Rev) (def: (encode value) (let [raw-output (de-prefix (:: <nat> encode (:coerce Nat value))) @@ -476,16 +476,16 @@ (#error.Success dec-rev) dec-rev - (#error.Error error) + (#error.Failure error) (error! error))] (#error.Success (f/+ (int-to-frac whole) (f/* sign adjusted-decimal)))) _ - (#error.Error ("lux text concat" <error> repr)))) + (#error.Failure ("lux text concat" <error> repr)))) _ - (#error.Error ("lux text concat" <error> repr)))))] + (#error.Failure ("lux text concat" <error> repr)))))] [Binary@Codec<Text,Frac> Binary@Codec<Text,Int> +2.0 "01" "Invalid binary syntax: "] ) @@ -656,14 +656,14 @@ ("lux text concat" (<to> whole-part)) ("lux text concat" (if (f/= -1.0 sign) "-" "+")))] (case (:: Binary@Codec<Text,Frac> decode as-binary) - (#error.Error _) - (#error.Error ("lux text concat" <error> repr)) + (#error.Failure _) + (#error.Failure ("lux text concat" <error> repr)) output output)) _ - (#error.Error ("lux text concat" <error> repr))))))] + (#error.Failure ("lux text concat" <error> repr))))))] [Octal@Codec<Text,Frac> "Invalid octaladecimal syntax: " binary-to-octal octal-to-binary] [Hex@Codec<Text,Frac> "Invalid hexadecimal syntax: " binary-to-hex hex-to-binary] @@ -683,7 +683,7 @@ (~ example-2))))])) _ - (#error.Error "Wrong syntax for 'encoding-doc'."))) + (#error.Failure "Wrong syntax for 'encoding-doc'."))) (def: (underscore-prefixed? number) (-> Text Bit) @@ -704,29 +704,29 @@ (case tokens (#.Cons [meta (#.Text repr')] #.Nil) (if (underscore-prefixed? repr') - (#error.Error <error>) + (#error.Failure <error>) (let [repr (clean-underscores repr')] (case (:: <nat> decode repr) (#error.Success value) (#error.Success [state (list [meta (#.Nat value)])]) - (^multi (#error.Error _) + (^multi (#error.Failure _) [(:: <int> decode repr) (#error.Success value)]) (#error.Success [state (list [meta (#.Int value)])]) - (^multi (#error.Error _) + (^multi (#error.Failure _) [(:: <rev> decode repr) (#error.Success value)]) (#error.Success [state (list [meta (#.Rev value)])]) - (^multi (#error.Error _) + (^multi (#error.Failure _) [(:: <frac> decode repr) (#error.Success value)]) (#error.Success [state (list [meta (#.Frac value)])]) _ - (#error.Error <error>)))) + (#error.Failure <error>)))) _ - (#error.Error <error>)))] + (#error.Failure <error>)))] [bin Binary@Codec<Text,Nat> Binary@Codec<Text,Int> Binary@Codec<Text,Rev> Binary@Codec<Text,Frac> "Invalid binary syntax." @@ -918,8 +918,8 @@ (#error.Success (:coerce Rev output)))) #.None - (#error.Error ("lux text concat" "Wrong syntax for Rev: " input))) - (#error.Error ("lux text concat" "Wrong syntax for Rev: " input)))) + (#error.Failure ("lux text concat" "Wrong syntax for Rev: " input))) + (#error.Failure ("lux text concat" "Wrong syntax for Rev: " input)))) )) (def: (log2 input) diff --git a/stdlib/source/lux/data/text/lexer.lux b/stdlib/source/lux/data/text/lexer.lux index 45a88bdf3..9ecbb99c7 100644 --- a/stdlib/source/lux/data/text/lexer.lux +++ b/stdlib/source/lux/data/text/lexer.lux @@ -7,7 +7,7 @@ [data ["." product] ["." maybe] - ["e" error] + ["." error (#+ Error)] [number ("nat/." Codec<Text,Nat>)] [collection ["." list ("list/." Fold<List>)]]] @@ -38,20 +38,20 @@ ["Remaining input" (remaining offset tape)])) (def: #export (run input lexer) - (All [a] (-> Text (Lexer a) (e.Error a))) + (All [a] (-> Text (Lexer a) (Error a))) (case (lexer [start-offset input]) - (#e.Error msg) - (#e.Error msg) + (#error.Failure msg) + (#error.Failure msg) - (#e.Success [[end-offset _] output]) + (#error.Success [[end-offset _] output]) (if (n/= end-offset (//.size input)) - (#e.Success output) + (#error.Success output) (ex.throw unconsumed-input [end-offset input])))) (def: #export offset (Lexer Offset) (function (_ (^@ input [offset tape])) - (#e.Success [input offset]))) + (#error.Success [input offset]))) (def: (with-slices lexer) (-> (Lexer (List Slice)) (Lexer Slice)) @@ -71,18 +71,18 @@ (function (_ [offset tape]) (case (//.nth offset tape) (#.Some output) - (#e.Success [[("lux i64 +" 1 offset) tape] (//.from-code output)]) + (#error.Success [[("lux i64 +" 1 offset) tape] (//.from-code output)]) _ - (#e.Error cannot-lex-error)))) + (#error.Failure cannot-lex-error)))) (def: #export any! {#.doc "Just returns the next character without applying any logic."} (Lexer Slice) (function (_ [offset tape]) - (#e.Success [[("lux i64 +" 1 offset) tape] - {#basis offset - #distance 1}]))) + (#error.Success [[("lux i64 +" 1 offset) tape] + {#basis offset + #distance 1}]))) (do-template [<name> <type> <any>] [(def: #export (<name> p) @@ -90,11 +90,11 @@ (All [a] (-> (Lexer a) (Lexer <type>))) (function (_ input) (case (p input) - (#e.Error msg) + (#error.Failure msg) (<any> input) _ - (#e.Error "Expected to fail; yet succeeded."))))] + (#error.Failure "Expected to fail; yet succeeded."))))] [not Text ..any] [not! Slice ..any!] @@ -107,12 +107,12 @@ (case (//.index-of' reference offset tape) (#.Some where) (if (n/= offset where) - (#e.Success [[("lux i64 +" (//.size reference) offset) tape] - []]) - (#e.Error ($_ text/compose "Could not match: " (//.encode reference) " @ " (maybe.assume (//.clip' offset tape))))) + (#error.Success [[("lux i64 +" (//.size reference) offset) tape] + []]) + (#error.Failure ($_ text/compose "Could not match: " (//.encode reference) " @ " (maybe.assume (//.clip' offset tape))))) _ - (#e.Error ($_ text/compose "Could not match: " (//.encode reference)))))) + (#error.Failure ($_ text/compose "Could not match: " (//.encode reference)))))) (def: #export (this? reference) {#.doc "Lex a text if it matches the given sample."} @@ -120,25 +120,25 @@ (function (_ (^@ input [offset tape])) (case (//.index-of' reference offset tape) (^multi (#.Some where) (n/= offset where)) - (#e.Success [[("lux i64 +" (//.size reference) offset) tape] - #1]) + (#error.Success [[("lux i64 +" (//.size reference) offset) tape] + #1]) _ - (#e.Success [input #0])))) + (#error.Success [input #0])))) (def: #export end {#.doc "Ensure the lexer's input is empty."} (Lexer Any) (function (_ (^@ input [offset tape])) (if (n/= offset (//.size tape)) - (#e.Success [input []]) + (#error.Success [input []]) (ex.throw unconsumed-input [offset tape])))) (def: #export end? {#.doc "Ask if the lexer's input is empty."} (Lexer Bit) (function (_ (^@ input [offset tape])) - (#e.Success [input (n/= offset (//.size tape))]))) + (#error.Success [input (n/= offset (//.size tape))]))) (def: #export peek {#.doc "Lex the next character (without consuming it from the input)."} @@ -146,16 +146,16 @@ (function (_ (^@ input [offset tape])) (case (//.nth offset tape) (#.Some output) - (#e.Success [input (//.from-code output)]) + (#error.Success [input (//.from-code output)]) _ - (#e.Error cannot-lex-error)))) + (#error.Failure cannot-lex-error)))) (def: #export get-input {#.doc "Get all of the remaining input (without consuming it)."} (Lexer Text) (function (_ (^@ input [offset tape])) - (#e.Success [input (remaining offset tape)]))) + (#error.Success [input (remaining offset tape)]))) (def: #export (range bottom top) {#.doc "Only lex characters within a range."} @@ -207,13 +207,13 @@ (#.Some output) (let [output (//.from-code output)] (if (<modifier> (//.contains? output options)) - (#e.Success [[("lux i64 +" 1 offset) tape] output]) - (#e.Error ($_ text/compose "Character (" output - ") is should " <description-modifier> - "be one of: " options)))) + (#error.Success [[("lux i64 +" 1 offset) tape] output]) + (#error.Failure ($_ text/compose "Character (" output + ") is should " <description-modifier> + "be one of: " options)))) _ - (#e.Error cannot-lex-error))))] + (#error.Failure cannot-lex-error))))] [one-of "" |>] [none-of " not" .not] @@ -228,15 +228,15 @@ (#.Some output) (let [output (//.from-code output)] (if (<modifier> (//.contains? output options)) - (#e.Success [[("lux i64 +" 1 offset) tape] - {#basis offset - #distance 1}]) - (#e.Error ($_ text/compose "Character (" output - ") is should " <description-modifier> - "be one of: " options)))) + (#error.Success [[("lux i64 +" 1 offset) tape] + {#basis offset + #distance 1}]) + (#error.Failure ($_ text/compose "Character (" output + ") is should " <description-modifier> + "be one of: " options)))) _ - (#e.Error cannot-lex-error))))] + (#error.Failure cannot-lex-error))))] [one-of! "" |>] [none-of! " not" .not] @@ -249,11 +249,11 @@ (case (//.nth offset tape) (#.Some output) (if (p output) - (#e.Success [[("lux i64 +" 1 offset) tape] (//.from-code output)]) - (#e.Error ($_ text/compose "Character does not satisfy predicate: " (//.from-code output)))) + (#error.Success [[("lux i64 +" 1 offset) tape] (//.from-code output)]) + (#error.Failure ($_ text/compose "Character does not satisfy predicate: " (//.from-code output)))) _ - (#e.Error cannot-lex-error)))) + (#error.Failure cannot-lex-error)))) (def: #export space {#.doc "Only lex white-space."} @@ -337,11 +337,11 @@ (All [a] (-> Text (Lexer a) (Lexer a))) (function (_ real-input) (case (run local-input lexer) - (#e.Error error) - (#e.Error error) + (#error.Failure error) + (#error.Failure error) - (#e.Success value) - (#e.Success [real-input value])))) + (#error.Success value) + (#error.Success [real-input value])))) (def: #export (slice lexer) (-> (Lexer Slice) (Lexer Text)) @@ -350,7 +350,7 @@ (function (_ (^@ input [offset tape])) (case (//.clip basis ("lux i64 +" basis distance) tape) (#.Some output) - (#e.Success [input output]) + (#error.Success [input output]) #.None - (#e.Error "Cannot slice."))))) + (#error.Failure "Cannot slice."))))) diff --git a/stdlib/source/lux/data/text/regex.lux b/stdlib/source/lux/data/text/regex.lux index ba0128b7b..22aa4c87c 100644 --- a/stdlib/source/lux/data/text/regex.lux +++ b/stdlib/source/lux/data/text/regex.lux @@ -5,7 +5,7 @@ ["p" parser ("parser/." Monad<Parser>)]] [data ["." product] - ["e" error] + ["." error] ["." maybe] ["." number (#+ hex) ("int/." Codec<Text,Int>)] [collection @@ -319,31 +319,31 @@ (All [l r] (-> (l.Lexer [Text l]) (l.Lexer [Text r]) (l.Lexer [Text (| l r)]))) (function (_ input) (case (left input) - (#e.Success [input' [lt lv]]) - (#e.Success [input' [lt (0 lv)]]) + (#error.Success [input' [lt lv]]) + (#error.Success [input' [lt (0 lv)]]) - (#e.Error _) + (#error.Failure _) (case (right input) - (#e.Success [input' [rt rv]]) - (#e.Success [input' [rt (1 rv)]]) + (#error.Success [input' [rt rv]]) + (#error.Success [input' [rt (1 rv)]]) - (#e.Error error) - (#e.Error error))))) + (#error.Failure error) + (#error.Failure error))))) (def: (|||_^ left right) (All [l r] (-> (l.Lexer [Text l]) (l.Lexer [Text r]) (l.Lexer Text))) (function (_ input) (case (left input) - (#e.Success [input' [lt lv]]) - (#e.Success [input' lt]) + (#error.Success [input' [lt lv]]) + (#error.Success [input' lt]) - (#e.Error _) + (#error.Failure _) (case (right input) - (#e.Success [input' [rt rv]]) - (#e.Success [input' rt]) + (#error.Success [input' [rt rv]]) + (#error.Success [input' rt]) - (#e.Error error) - (#e.Error error))))) + (#error.Failure error) + (#error.Failure error))))) (def: (prep-alternative [num-captures alt]) (-> [Nat Code] Code) @@ -464,11 +464,11 @@ (case (|> (regex^ current-module) (p.before l.end) (l.run pattern)) - (#e.Error error) + (#error.Failure error) (macro.fail (format "Error while parsing regular-expression:" //.new-line error)) - (#e.Success regex) + (#error.Success regex) (wrap (list regex)) ))) @@ -489,6 +489,6 @@ (with-gensyms [g!temp] (wrap (list& (` (^multi (~ g!temp) [((~! l.run) (~ g!temp) (regex (~ (code.text pattern)))) - (#e.Success (~ (maybe.default g!temp bindings)))])) + (#error.Success (~ (maybe.default g!temp bindings)))])) body branches)))) diff --git a/stdlib/source/lux/io.lux b/stdlib/source/lux/io.lux index c054c5347..92ae11066 100644 --- a/stdlib/source/lux/io.lux +++ b/stdlib/source/lux/io.lux @@ -79,8 +79,8 @@ (#error.Success ma) ma - (#error.Error error) - (io (#error.Error error))))) + (#error.Failure error) + (io (#error.Failure error))))) (def: #export from-io (All [a] (-> (IO a) (Process a))) @@ -88,7 +88,7 @@ (def: #export (fail error) (All [a] (-> Text (Process a))) - (io (#error.Error error))) + (io (#error.Failure error))) (def: #export (throw exception message) (All [e a] (-> (Exception e) e (Process a))) diff --git a/stdlib/source/lux/macro.lux b/stdlib/source/lux/macro.lux index 5d5c8f0cf..ead5b366e 100644 --- a/stdlib/source/lux/macro.lux +++ b/stdlib/source/lux/macro.lux @@ -8,7 +8,7 @@ ["." product] [name ("name/." Codec<Text,Name> Equivalence<Name>)] ["." maybe] - ["e" error] + ["." error (#+ Error)] ["." number ("nat/." Codec<Text,Nat>)] ["." text ("text/." Monoid<Text> Equivalence<Text>)] [collection @@ -17,17 +17,17 @@ ["." code]]) ## (type: (Meta a) -## (-> Lux (e.Error [Lux a]))) +## (-> Lux (Error [Lux a]))) (structure: #export _ (Functor Meta) (def: (map f fa) (function (_ compiler) (case (fa compiler) - (#e.Error msg) - (#e.Error msg) + (#error.Failure msg) + (#error.Failure msg) - (#e.Success [compiler' a]) - (#e.Success [compiler' (f a)]))))) + (#error.Success [compiler' a]) + (#error.Success [compiler' (f a)]))))) (structure: #export _ (Apply Meta) (def: functor Functor<Meta>) @@ -35,31 +35,31 @@ (def: (apply ff fa) (function (_ compiler) (case (ff compiler) - (#e.Success [compiler' f]) + (#error.Success [compiler' f]) (case (fa compiler') - (#e.Success [compiler'' a]) - (#e.Success [compiler'' (f a)]) + (#error.Success [compiler'' a]) + (#error.Success [compiler'' (f a)]) - (#e.Error msg) - (#e.Error msg)) + (#error.Failure msg) + (#error.Failure msg)) - (#e.Error msg) - (#e.Error msg))))) + (#error.Failure msg) + (#error.Failure msg))))) (structure: #export _ (Monad Meta) (def: functor Functor<Meta>) (def: (wrap x) (function (_ compiler) - (#e.Success [compiler x]))) + (#error.Success [compiler x]))) (def: (join mma) (function (_ compiler) (case (mma compiler) - (#e.Error msg) - (#e.Error msg) + (#error.Failure msg) + (#error.Failure msg) - (#e.Success [compiler' ma]) + (#error.Success [compiler' ma]) (ma compiler'))))) (def: (get k plist) @@ -75,63 +75,63 @@ (get k plist')))) (def: #export (run' compiler action) - (All [a] (-> Lux (Meta a) (e.Error [Lux a]))) + (All [a] (-> Lux (Meta a) (Error [Lux a]))) (action compiler)) (def: #export (run compiler action) - (All [a] (-> Lux (Meta a) (e.Error a))) + (All [a] (-> Lux (Meta a) (Error a))) (case (action compiler) - (#e.Error error) - (#e.Error error) + (#error.Failure error) + (#error.Failure error) - (#e.Success [_ output]) - (#e.Success output))) + (#error.Success [_ output]) + (#error.Success output))) (def: #export (either left right) {#.doc "Pick whichever computation succeeds."} (All [a] (-> (Meta a) (Meta a) (Meta a))) (function (_ compiler) (case (left compiler) - (#e.Error error) + (#error.Failure error) (right compiler) - (#e.Success [compiler' output]) - (#e.Success [compiler' output])))) + (#error.Success [compiler' output]) + (#error.Success [compiler' output])))) (def: #export (assert message test) {#.doc "Fails with the given message if the test is #0."} (-> Text Bit (Meta Any)) (function (_ compiler) (if test - (#e.Success [compiler []]) - (#e.Error message)))) + (#error.Success [compiler []]) + (#error.Failure message)))) (def: #export (fail msg) {#.doc "Fails with the given message."} (All [a] (-> Text (Meta a))) (function (_ _) - (#e.Error msg))) + (#error.Failure msg))) (def: #export (find-module name) (-> Text (Meta Module)) (function (_ compiler) (case (get name (get@ #.modules compiler)) (#.Some module) - (#e.Success [compiler module]) + (#error.Success [compiler module]) _ - (#e.Error ($_ text/compose "Unknown module: " name))))) + (#error.Failure ($_ text/compose "Unknown module: " name))))) (def: #export current-module-name (Meta Text) (function (_ compiler) (case (get@ #.current-module compiler) (#.Some current-module) - (#e.Success [compiler current-module]) + (#error.Success [compiler current-module]) _ - (#e.Error "No current module.") + (#error.Failure "No current module.") ))) (def: #export current-module @@ -283,7 +283,7 @@ this-module current-module-name] (: (Meta (Maybe Macro)) (function (_ compiler) - (#e.Success [compiler (find-macro' (get@ #.modules compiler) this-module module name)]))))) + (#error.Success [compiler (find-macro' (get@ #.modules compiler) this-module module name)]))))) (def: #export (expand-once syntax) {#.doc (doc "Given code that requires applying a macro, does it once and returns the result." @@ -360,20 +360,20 @@ (def: #export count (Meta Nat) (function (_ compiler) - (#e.Success [(update@ #.seed inc compiler) - (get@ #.seed compiler)]))) + (#error.Success [(update@ #.seed inc compiler) + (get@ #.seed compiler)]))) (def: #export (gensym prefix) {#.doc (doc "Generates a unique name as an Code node (ready to be used in code templates)." "A prefix can be given (or just be empty text) to better identify the code for debugging purposes.")} (-> Text (Meta Code)) (function (_ compiler) - (#e.Success [(update@ #.seed inc compiler) - (|> compiler - (get@ #.seed) - (:: number.Codec<Text,Nat> encode) - ($_ text/compose "__gensym__" prefix) - [""] code.identifier)]))) + (#error.Success [(update@ #.seed inc compiler) + (|> compiler + (get@ #.seed) + (:: number.Codec<Text,Nat> encode) + ($_ text/compose "__gensym__" prefix) + [""] code.identifier)]))) (def: (get-local-identifier ast) (-> Code (Meta Text)) @@ -423,12 +423,12 @@ (def: #export (module-exists? module) (-> Text (Meta Bit)) (function (_ compiler) - (#e.Success [compiler (case (get module (get@ #.modules compiler)) - (#.Some _) - #1 - - #.None - #0)]))) + (#error.Success [compiler (case (get module (get@ #.modules compiler)) + (#.Some _) + #1 + + #.None + #0)]))) (def: (try-both f x1 x2) (All [a b] @@ -457,10 +457,10 @@ (get@ [#.type-context #.var-bindings]) (find-type-var var)) (^or #.None (#.Some (#.Var _))) - (#e.Success [compiler type]) + (#error.Success [compiler type]) (#.Some type') - (#e.Success [compiler type']))) + (#error.Success [compiler type']))) _ (:: Monad<Meta> wrap type))) @@ -488,7 +488,7 @@ ((clean-type var-type) compiler) #.None - (#e.Error ($_ text/compose "Unknown variable: " name)))))) + (#error.Failure ($_ text/compose "Unknown variable: " name)))))) (def: #export (find-def name) {#.doc "Looks-up a definition's whole data in the available modules (including the current one)."} @@ -502,22 +502,22 @@ (^slots [#.definitions]) (get v-prefix (get@ #.modules compiler))] (get v-name definitions))) (#.Some definition) - (#e.Success [compiler definition]) + (#error.Success [compiler definition]) _ (let [current-module (|> compiler (get@ #.current-module) (maybe.default "???"))] - (#e.Error ($_ text/compose - "Unknown definition: " (name/encode name) text.new-line - " Current module: " current-module text.new-line - (case (get current-module (get@ #.modules compiler)) - (#.Some this-module) - ($_ text/compose - " Imports: " (|> this-module (get@ #.imports) (text.join-with ", ")) text.new-line - " Aliases: " (|> this-module (get@ #.module-aliases) (list/map (function (_ [alias real]) ($_ text/compose alias " => " real))) (text.join-with ", ")) text.new-line) - - _ - "") - " All Known modules: " (|> compiler (get@ #.modules) (list/map product.left) (text.join-with ", ")) text.new-line))))))) + (#error.Failure ($_ text/compose + "Unknown definition: " (name/encode name) text.new-line + " Current module: " current-module text.new-line + (case (get current-module (get@ #.modules compiler)) + (#.Some this-module) + ($_ text/compose + " Imports: " (|> this-module (get@ #.imports) (text.join-with ", ")) text.new-line + " Aliases: " (|> this-module (get@ #.module-aliases) (list/map (function (_ [alias real]) ($_ text/compose alias " => " real))) (text.join-with ", ")) text.new-line) + + _ + "") + " All Known modules: " (|> compiler (get@ #.modules) (list/map product.left) (text.join-with ", ")) text.new-line))))))) (def: #export (find-def-type name) {#.doc "Looks-up a definition's type in the available modules (including the current one)."} @@ -551,8 +551,8 @@ (-> Text (Meta (List [Text Definition]))) (function (_ compiler) (case (get module-name (get@ #.modules compiler)) - #.None (#e.Error ($_ text/compose "Unknown module: " module-name)) - (#.Some module) (#e.Success [compiler (get@ #.definitions module)]) + #.None (#error.Failure ($_ text/compose "Unknown module: " module-name)) + (#.Some module) (#error.Success [compiler (get@ #.definitions module)]) ))) (def: #export (exports module-name) @@ -571,7 +571,7 @@ (|> compiler (get@ #.modules) [compiler] - #e.Success))) + #error.Success))) (def: #export (tags-of type-name) {#.doc "All the tags associated with a type definition."} @@ -590,7 +590,7 @@ {#.doc "The cursor of the current expression being analyzed."} (Meta Cursor) (function (_ compiler) - (#e.Success [compiler (get@ #.cursor compiler)]))) + (#error.Success [compiler (get@ #.cursor compiler)]))) (def: #export expected-type {#.doc "The expected type of the current expression being analyzed."} @@ -598,10 +598,10 @@ (function (_ compiler) (case (get@ #.expected compiler) (#.Some type) - (#e.Success [compiler type]) + (#error.Success [compiler type]) #.None - (#e.Error "Not expecting any type.")))) + (#error.Failure "Not expecting any type.")))) (def: #export (imported-modules module-name) {#.doc "All the modules imported by a specified module."} @@ -660,14 +660,14 @@ (function (_ compiler) (case (list.inits (get@ #.scopes compiler)) #.None - (#e.Error "No local environment") + (#error.Failure "No local environment") (#.Some scopes) - (#e.Success [compiler - (list/map (|>> (get@ [#.locals #.mappings]) - (list/map (function (_ [name [type _]]) - [name type]))) - scopes)])))) + (#error.Success [compiler + (list/map (|>> (get@ [#.locals #.mappings]) + (list/map (function (_ [name [type _]]) + [name type]))) + scopes)])))) (def: #export (un-alias def-name) {#.doc "Given an aliased definition's name, returns the original definition being referenced."} @@ -685,12 +685,12 @@ {#.doc "Obtains the current state of the compiler."} (Meta Lux) (function (_ compiler) - (#e.Success [compiler compiler]))) + (#error.Success [compiler compiler]))) (def: #export type-context (Meta Type-Context) (function (_ compiler) - (#e.Success [compiler (get@ #.type-context compiler)]))) + (#error.Success [compiler (get@ #.type-context compiler)]))) (do-template [<macro> <func> <desc>] [(macro: #export (<macro> tokens) diff --git a/stdlib/source/lux/macro/poly.lux b/stdlib/source/lux/macro/poly.lux index 51f7a4885..be33751cc 100644 --- a/stdlib/source/lux/macro/poly.lux +++ b/stdlib/source/lux/macro/poly.lux @@ -11,7 +11,7 @@ ["." bit] ["." maybe] [name ("name/." Codec<Text,Name>)] - ["e" error] + ["." error (#+ Error)] ["." number (#+ hex) ("nat/." Codec<Text,Nat>)] ["." text ("text/." Monoid<Text>) format] @@ -67,67 +67,67 @@ (def: #export fresh Env (dict.new number.Hash<Nat>)) (def: (run' env types poly) - (All [a] (-> Env (List Type) (Poly a) (e.Error a))) + (All [a] (-> Env (List Type) (Poly a) (Error a))) (case (p.run [env types] poly) - (#e.Error error) - (#e.Error error) + (#error.Failure error) + (#error.Failure error) - (#e.Success [[env' remaining] output]) + (#error.Success [[env' remaining] output]) (case remaining #.Nil - (#e.Success output) + (#error.Success output) _ (ex.throw unconsumed remaining)))) (def: #export (run type poly) - (All [a] (-> Type (Poly a) (e.Error a))) + (All [a] (-> Type (Poly a) (Error a))) (run' fresh (list type) poly)) (def: #export env (Poly Env) (.function (_ [env inputs]) - (#e.Success [[env inputs] env]))) + (#error.Success [[env inputs] env]))) (def: (with-env temp poly) (All [a] (-> Env (Poly a) (Poly a))) (.function (_ [env inputs]) (case (p.run [temp inputs] poly) - (#e.Error error) - (#e.Error error) + (#error.Failure error) + (#error.Failure error) - (#e.Success [[_ remaining] output]) - (#e.Success [[env remaining] output])))) + (#error.Success [[_ remaining] output]) + (#error.Success [[env remaining] output])))) (def: #export peek (Poly Type) (.function (_ [env inputs]) (case inputs #.Nil - (#e.Error "Empty stream of types.") + (#error.Failure "Empty stream of types.") (#.Cons headT tail) - (#e.Success [[env inputs] headT])))) + (#error.Success [[env inputs] headT])))) (def: #export any (Poly Type) (.function (_ [env inputs]) (case inputs #.Nil - (#e.Error "Empty stream of types.") + (#error.Failure "Empty stream of types.") (#.Cons headT tail) - (#e.Success [[env tail] headT])))) + (#error.Success [[env tail] headT])))) (def: #export (local types poly) (All [a] (-> (List Type) (Poly a) (Poly a))) (.function (_ [env pass-through]) (case (run' env types poly) - (#e.Error error) - (#e.Error error) + (#error.Failure error) + (#error.Failure error) - (#e.Success output) - (#e.Success [[env pass-through] output])))) + (#error.Success output) + (#error.Success [[env pass-through] output])))) (def: (label idx) (-> Nat Code) @@ -141,11 +141,11 @@ (case (p.run [(dict.put current-id [type g!var] env) inputs] poly) - (#e.Error error) - (#e.Error error) + (#error.Failure error) + (#error.Failure error) - (#e.Success [[_ inputs'] output]) - (#e.Success [[env inputs'] [g!var output]]))))) + (#error.Success [[_ inputs'] output]) + (#error.Success [[env inputs'] [g!var output]]))))) (do-template [<name> <flattener> <tag> <exception>] [(def: #export (<name> poly) diff --git a/stdlib/source/lux/macro/syntax.lux b/stdlib/source/lux/macro/syntax.lux index edee25af3..02c3ad1ae 100644 --- a/stdlib/source/lux/macro/syntax.lux +++ b/stdlib/source/lux/macro/syntax.lux @@ -40,7 +40,7 @@ (Syntax Code) (function (_ tokens) (case tokens - #.Nil (#error.Error "There are no tokens to parse!") + #.Nil (#error.Failure "There are no tokens to parse!") (#.Cons [t tokens']) (#error.Success [tokens' t])))) (do-template [<get-name> <type> <tag> <eq> <desc>] @@ -53,7 +53,7 @@ (#error.Success [tokens' x]) _ - (#error.Error ($_ text/compose "Cannot parse " <desc> (remaining-inputs tokens))))))] + (#error.Failure ($_ text/compose "Cannot parse " <desc> (remaining-inputs tokens))))))] [ bit Bit #.Bit bit.Equivalence<Bit> "bit"] [ nat Nat #.Nat number.Equivalence<Nat> "nat"] @@ -88,11 +88,11 @@ (#.Cons [token tokens']) (if (code/= ast token) (#error.Success [tokens' []]) - (#error.Error ($_ text/compose "Expected a " (code.to-text ast) " but instead got " (code.to-text token) - (remaining-inputs tokens)))) + (#error.Failure ($_ text/compose "Expected a " (code.to-text ast) " but instead got " (code.to-text token) + (remaining-inputs tokens)))) _ - (#error.Error "There are no tokens to parse!")))) + (#error.Failure "There are no tokens to parse!")))) (do-template [<name> <tag> <desc>] [(def: #export <name> @@ -104,7 +104,7 @@ (#error.Success [tokens' x]) _ - (#error.Error ($_ text/compose "Cannot parse local " <desc> (remaining-inputs tokens))))))] + (#error.Failure ($_ text/compose "Cannot parse local " <desc> (remaining-inputs tokens))))))] [local-identifier #.Identifier "identifier"] [ local-tag #.Tag "tag"] @@ -120,10 +120,10 @@ (#.Cons [[_ (<tag> members)] tokens']) (case (p members) (#error.Success [#.Nil x]) (#error.Success [tokens' x]) - _ (#error.Error ($_ text/compose "Syntax was expected to fully consume " <desc> (remaining-inputs tokens)))) + _ (#error.Failure ($_ text/compose "Syntax was expected to fully consume " <desc> (remaining-inputs tokens)))) _ - (#error.Error ($_ text/compose "Cannot parse " <desc> (remaining-inputs tokens))))))] + (#error.Failure ($_ text/compose "Cannot parse " <desc> (remaining-inputs tokens))))))] [ form #.Form "form"] [tuple #.Tuple "tuple"] @@ -138,10 +138,10 @@ (#.Cons [[_ (#.Record pairs)] tokens']) (case (p (join-pairs pairs)) (#error.Success [#.Nil x]) (#error.Success [tokens' x]) - _ (#error.Error ($_ text/compose "Syntax was expected to fully consume record" (remaining-inputs tokens)))) + _ (#error.Failure ($_ text/compose "Syntax was expected to fully consume record" (remaining-inputs tokens)))) _ - (#error.Error ($_ text/compose "Cannot parse record" (remaining-inputs tokens)))))) + (#error.Failure ($_ text/compose "Cannot parse record" (remaining-inputs tokens)))))) (def: #export end! {#.doc "Ensures there are no more inputs."} @@ -149,7 +149,7 @@ (function (_ tokens) (case tokens #.Nil (#error.Success [tokens []]) - _ (#error.Error ($_ text/compose "Expected list of tokens to be empty!" (remaining-inputs tokens)))))) + _ (#error.Failure ($_ text/compose "Expected list of tokens to be empty!" (remaining-inputs tokens)))))) (def: #export end? {#.doc "Checks whether there are no more inputs."} @@ -163,8 +163,8 @@ (All [a] (-> (Error a) (Syntax a))) (function (_ input) (case outcome - (#error.Error error) - (#error.Error error) + (#error.Failure error) + (#error.Failure error) (#error.Success value) (#error.Success [input value]) @@ -173,8 +173,8 @@ (def: #export (run inputs syntax) (All [a] (-> (List Code) (Syntax a) (Error a))) (case (syntax inputs) - (#error.Error error) - (#error.Error error) + (#error.Failure error) + (#error.Failure error) (#error.Success [unconsumed value]) (case unconsumed @@ -182,9 +182,9 @@ (#error.Success value) _ - (#error.Error (text/compose "Unconsumed inputs: " - (|> (list/map code.to-text unconsumed) - (text.join-with ", "))))))) + (#error.Failure (text/compose "Unconsumed inputs: " + (|> (list/map code.to-text unconsumed) + (text.join-with ", "))))))) (def: #export (local inputs syntax) {#.doc "Run a syntax parser with the given list of inputs, instead of the real ones."} @@ -264,8 +264,8 @@ ({(#error.Success (~ g!body)) ((~ g!body) (~ g!state)) - (#error.Error (~ g!error)) - (#error.Error ((~! text.join-with) ": " (list (~ error-msg) (~ g!error))))} + (#error.Failure (~ g!error)) + (#error.Failure ((~! text.join-with) ": " (list (~ error-msg) (~ g!error))))} ((~! ..run) (~ g!tokens) (: ((~! ..Syntax) (Meta (List Code))) ((~! do) (~! p.Monad<Parser>) diff --git a/stdlib/source/lux/math/modular.lux b/stdlib/source/lux/math/modular.lux index ac141a3c9..6222ed87b 100644 --- a/stdlib/source/lux/math/modular.lux +++ b/stdlib/source/lux/math/modular.lux @@ -6,7 +6,7 @@ [codec (#+ Codec)] [monad (#+ do)]] [data - ["e" error (#+ Error)] + ["." error (#+ Error)] ["." number ("int/." Codec<Text,Int>)] [text ("text/." Monoid<Text>) ["l" lexer (#+ Lexer)]]] @@ -28,7 +28,7 @@ (Ex [m] (-> Int (Error (Modulus m)))) (if (i/= +0 value) (ex.throw zero-cannot-be-a-modulus []) - (#e.Success (:abstraction value)))) + (#error.Success (:abstraction value)))) (def: #export (to-int modulus) (All [m] (-> (Modulus m) Int)) @@ -54,10 +54,10 @@ (syntax: #export (modulus {modulus s.int}) (case (from-int modulus) - (#e.Success _) - (wrap (list (` (e.assume (..from-int (~ (code.int modulus))))))) + (#error.Success _) + (wrap (list (` (error.assume (..from-int (~ (code.int modulus))))))) - (#e.Error error) + (#error.Failure error) (p.fail error))) (def: intL @@ -108,8 +108,8 @@ [sample sample-modulus] (:representation sample)] (if (i/= (to-int reference-modulus) (to-int sample-modulus)) - (#e.Success (:abstraction {#remainder sample - #modulus reference-modulus})) + (#error.Success (:abstraction {#remainder sample + #modulus reference-modulus})) (ex.throw cannot-equalize-moduli [reference-modulus sample-modulus])))) (do-template [<name> <op>] diff --git a/stdlib/source/lux/platform/compiler/default/init.lux b/stdlib/source/lux/platform/compiler/default/init.lux index 699ddfb54..012ab3ea9 100644 --- a/stdlib/source/lux/platform/compiler/default/init.lux +++ b/stdlib/source/lux/platform/compiler/default/init.lux @@ -98,8 +98,8 @@ (-> Reader (analysis.Operation Code)) (function (_ [bundle compiler]) (case (reader (get@ #.source compiler)) - (#error.Error error) - (#error.Error error) + (#error.Failure error) + (#error.Failure error) (#error.Success [source' output]) (let [[cursor _] output] @@ -144,10 +144,10 @@ (#error.Success [state' output]) (recur state') - (#error.Error error) + (#error.Failure error) (if (ex.match? syntax.end-of-file error) (#error.Success [state []]) - (ex.with-stack ///.cannot-compile module (#error.Error error)))))))) + (ex.with-stack ///.cannot-compile module (#error.Failure error)))))))) (def: (compile hash input) (-> Nat ///.Input <Operation>) diff --git a/stdlib/source/lux/platform/compiler/default/platform.lux b/stdlib/source/lux/platform/compiler/default/platform.lux index 9a169fb15..10dfd6ebb 100644 --- a/stdlib/source/lux/platform/compiler/default/platform.lux +++ b/stdlib/source/lux/platform/compiler/default/platform.lux @@ -73,7 +73,7 @@ ## (wrap (|> state ## (set@ [#.info #.mode] #.Build)))) - ## (#error.Error error) + ## (#error.Failure error) ## (io.fail error)) ) @@ -88,8 +88,8 @@ ## _ (write-module target-dir file-name (get@ #cli.module configuration) module outputs) ] ## (case (compiler input) - ## (#error.Error error) - ## (:: (get@ #file-system platform) lift (#error.Error error)) + ## (#error.Failure error) + ## (:: (get@ #file-system platform) lift (#error.Failure error)) ## (#error.Success)) (let [compiler (init.compiler syntax.prelude state) @@ -99,11 +99,11 @@ (#error.Success more|done) (case more|done (#.Left more) - (:: (get@ #file-system platform) lift (#error.Error "NOT DONE!")) + (:: (get@ #file-system platform) lift (#error.Failure "NOT DONE!")) (#.Right done) (wrap [])) - (#error.Error error) - (:: (get@ #file-system platform) lift (#error.Error error)))))) + (#error.Failure error) + (:: (get@ #file-system platform) lift (#error.Failure error)))))) ) diff --git a/stdlib/source/lux/platform/compiler/default/syntax.lux b/stdlib/source/lux/platform/compiler/default/syntax.lux index 5e1990393..a1bb9f3ea 100644 --- a/stdlib/source/lux/platform/compiler/default/syntax.lux +++ b/stdlib/source/lux/platform/compiler/default/syntax.lux @@ -187,15 +187,15 @@ (#error.Success [source' top]) (recur source' (#.Cons top stack)) - (#error.Error error) + (#error.Failure error) (let [[where offset _] source] (case (read-close (char <close>) source-code//size source-code offset) (#error.Success offset') (#error.Success [[(update@ #.column inc where) offset' source-code] [where (<tag> (list.reverse stack))]]) - (#error.Error error) - (#error.Error error)))))))] + (#error.Failure error) + (#error.Failure error)))))))] ## Form and tuple syntax is mostly the same, differing only in the ## delimiters involved. @@ -216,19 +216,19 @@ (#error.Success [sourceFV value]) (recur sourceFV (#.Cons [field value] stack)) - (#error.Error error) - (#error.Error error)) + (#error.Failure error) + (#error.Failure error)) - (#error.Error error) + (#error.Failure error) (let [[where offset _] source] - (<| (!with-char+ source-code//size source-code offset closing-char (#error.Error error)) + (<| (!with-char+ source-code//size source-code offset closing-char (#error.Failure error)) (case (read-close (`` (char (~~ (static ..close-record)))) source-code//size source-code offset) (#error.Success offset') (#error.Success [[(update@ #.column inc where) offset' source-code] [where (#.Record (list.reverse stack))]]) - (#error.Error error) - (#error.Error error)))))))) + (#error.Failure error) + (#error.Failure error)))))))) (template: (!guarantee-no-new-lines content body) (case ("lux text index" content (static text.new-line) 0) @@ -297,8 +297,8 @@ source-code] [where (<tag> output)]]) - (#error.Error error) - (#error.Error error))) + (#error.Failure error) + (#error.Failure error))) (def: no-exponent Offset 0) @@ -382,7 +382,7 @@ (with-expansions [<end-of-file> (ex.throw end-of-file current-module) <failure> (ex.throw unrecognized-input [where "General" source-code offset/0]) - <close!> (#error.Error close-signal) + <close!> (#error.Failure close-signal) <consume-1> (as-is [where (!inc offset/0) source-code]) <consume-2> (as-is [where (!inc/2 offset/0) source-code])] @@ -392,8 +392,8 @@ (#error.Success [source' name]) (#error.Success [source' [@module name]]) - (#error.Error error) - (#error.Error error)) + (#error.Failure error) + (#error.Failure error)) ## else <failure>)) @@ -412,8 +412,8 @@ (#error.Success [source' name]) (#error.Success [source' [@where (@tag name)]]) - (#error.Error error) - (#error.Error error))) + (#error.Failure error) + (#error.Failure error))) (with-expansions [<simple> (as-is (#error.Success [source' ["" simple]]))] (`` (def: (parse-full-name start source) @@ -428,20 +428,20 @@ (#error.Success [source'' complex]) (#error.Success [source'' [simple complex]]) - (#error.Error error) - (#error.Error error))) + (#error.Failure error) + (#error.Failure error))) <simple>))) - (#error.Error error) - (#error.Error error))))) + (#error.Failure error) + (#error.Failure error))))) (template: (!parse-full-name @offset @source @where @tag) (case (..parse-full-name @offset @source) (#error.Success [source' full-name]) (#error.Success [source' [@where (@tag full-name)]]) - (#error.Error error) - (#error.Error error))) + (#error.Failure error) + (#error.Failure error))) (`` (template: (<<closers>>) [(~~ (static ..close-form)) diff --git a/stdlib/source/lux/platform/compiler/meta/cache.lux b/stdlib/source/lux/platform/compiler/meta/cache.lux index bcb7c98f0..ceed96164 100644 --- a/stdlib/source/lux/platform/compiler/meta/cache.lux +++ b/stdlib/source/lux/platform/compiler/meta/cache.lux @@ -137,7 +137,7 @@ (#error.Success [dependency document]) (wrap (#.Some [dependency document])) - (#error.Error error) + (#error.Failure error) (do @ [_ (un-install System<m> root module)] (wrap #.None))))) diff --git a/stdlib/source/lux/platform/compiler/meta/io/archive.lux b/stdlib/source/lux/platform/compiler/meta/io/archive.lux index 1f0714b25..354f84460 100644 --- a/stdlib/source/lux/platform/compiler/meta/io/archive.lux +++ b/stdlib/source/lux/platform/compiler/meta/io/archive.lux @@ -54,7 +54,7 @@ (#error.Success output) (wrap output) - (#error.Error _) + (#error.Failure _) (:: System<m> throw cannot-prepare [archive module])))))) (def: #export (write System<m> root content name) diff --git a/stdlib/source/lux/platform/compiler/meta/io/context.lux b/stdlib/source/lux/platform/compiler/meta/io/context.lux index 32e05c219..be72e4ccc 100644 --- a/stdlib/source/lux/platform/compiler/meta/io/context.lux +++ b/stdlib/source/lux/platform/compiler/meta/io/context.lux @@ -103,5 +103,5 @@ #////.file file #////.code code}) - (#error.Error _) + (#error.Failure _) (:: System<m> throw ..cannot-read-module [module]))))) diff --git a/stdlib/source/lux/platform/compiler/phase/analysis.lux b/stdlib/source/lux/platform/compiler/phase/analysis.lux index c69ff8eb2..c5256436f 100644 --- a/stdlib/source/lux/platform/compiler/phase/analysis.lux +++ b/stdlib/source/lux/platform/compiler/phase/analysis.lux @@ -253,8 +253,8 @@ (#error.Success [[bundle' (set@ #.source old-source state')] output]) - (#error.Error error) - (#error.Error error))))) + (#error.Failure error) + (#error.Failure error))))) (def: fresh-bindings (All [k v] (Bindings k v)) @@ -279,10 +279,10 @@ [head output]]) #.Nil - (#error.Error "Impossible error: Drained scopes!")) + (#error.Failure "Impossible error: Drained scopes!")) - (#error.Error error) - (#error.Error error)))) + (#error.Failure error) + (#error.Failure error)))) (def: #export (with-current-module name) (All [a] (-> Text (Operation a) (Operation a))) @@ -301,9 +301,9 @@ (#error.Success [[bundle' (set@ #.cursor old-cursor state')] output]) - (#error.Error error) - (#error.Error (format "@ " (%cursor cursor) text.new-line - error))))))) + (#error.Failure error) + (#error.Failure (format "@ " (%cursor cursor) text.new-line + error))))))) (do-template [<name> <type> <field> <value>] [(def: #export (<name> value) diff --git a/stdlib/source/lux/platform/compiler/phase/analysis/case.lux b/stdlib/source/lux/platform/compiler/phase/analysis/case.lux index 5044aed92..d7b020932 100644 --- a/stdlib/source/lux/platform/compiler/phase/analysis/case.lux +++ b/stdlib/source/lux/platform/compiler/phase/analysis/case.lux @@ -292,7 +292,7 @@ (///.assert non-exhaustive-pattern-matching [inputC branches coverage] (coverage.exhaustive? coverage)) - (#error.Error error) + (#error.Failure error) (///.fail error))] (wrap (#//.Case inputA [outputH outputT]))) diff --git a/stdlib/source/lux/platform/compiler/phase/analysis/case/coverage.lux b/stdlib/source/lux/platform/compiler/phase/analysis/case/coverage.lux index aff981e09..bdf524f73 100644 --- a/stdlib/source/lux/platform/compiler/phase/analysis/case/coverage.lux +++ b/stdlib/source/lux/platform/compiler/phase/analysis/case/coverage.lux @@ -336,7 +336,7 @@ _ (wrap [(#.Some altMSF) altsSF'])) - (#error.Error error) + (#error.Failure error) (error.fail error)) ))))] [successA possibilitiesSF] (fuse-once addition (flatten-alt so-far))] diff --git a/stdlib/source/lux/platform/compiler/phase/analysis/macro.lux b/stdlib/source/lux/platform/compiler/phase/analysis/macro.lux index af12c747d..64dabaf43 100644 --- a/stdlib/source/lux/platform/compiler/phase/analysis/macro.lux +++ b/stdlib/source/lux/platform/compiler/phase/analysis/macro.lux @@ -64,7 +64,7 @@ (#error.Success output) (#error.Success output) - (#error.Error error) + (#error.Failure error) ((///.throw expansion-failed [name inputs error]) state))))) (def: #export (expand-one name macro inputs) diff --git a/stdlib/source/lux/platform/compiler/phase/analysis/scope.lux b/stdlib/source/lux/platform/compiler/phase/analysis/scope.lux index 2849e059d..8cd55e198 100644 --- a/stdlib/source/lux/platform/compiler/phase/analysis/scope.lux +++ b/stdlib/source/lux/platform/compiler/phase/analysis/scope.lux @@ -130,8 +130,8 @@ _ (ex.throw invalid-scope-alteration [])) - (#e.Error error) - (#e.Error error))) + (#e.Failure error) + (#e.Failure error))) _ (ex.throw cannot-create-local-binding-without-a-scope [])) @@ -172,8 +172,8 @@ state')] output]) - (#e.Error error) - (#e.Error error))) + (#e.Failure error) + (#e.Failure error))) )) (exception: #export (cannot-get-next-reference-when-there-is-no-scope) diff --git a/stdlib/source/lux/platform/compiler/phase/analysis/type.lux b/stdlib/source/lux/platform/compiler/phase/analysis/type.lux index 36fee29f8..c3219f5ac 100644 --- a/stdlib/source/lux/platform/compiler/phase/analysis/type.lux +++ b/stdlib/source/lux/platform/compiler/phase/analysis/type.lux @@ -25,7 +25,7 @@ (#error.Success [[bundle (set@ #.type-context context' state)] output]) - (#error.Error error) + (#error.Failure error) ((///.fail error) stateE)))) (def: #export with-fresh-env diff --git a/stdlib/source/lux/platform/compiler/phase/extension.lux b/stdlib/source/lux/platform/compiler/phase/extension.lux index 75814ad24..ec7323b1e 100644 --- a/stdlib/source/lux/platform/compiler/phase/extension.lux +++ b/stdlib/source/lux/platform/compiler/phase/extension.lux @@ -94,8 +94,8 @@ (#error.Success [[bundle' state'] output]) (#error.Success [[bundle' (set old state')] output]) - (#error.Error error) - (#error.Error error)))))) + (#error.Failure error) + (#error.Failure error)))))) (def: #export (temporary transform) (All [s i o v] @@ -107,8 +107,8 @@ (#error.Success [[bundle' state'] output]) (#error.Success [[bundle' state] output]) - (#error.Error error) - (#error.Error error))))) + (#error.Failure error) + (#error.Failure error))))) (def: #export (with-state state) (All [s i o v] @@ -136,5 +136,5 @@ (#error.Success [state' output]) (#error.Success [[bundle state'] output]) - (#error.Error error) - (#error.Error error)))) + (#error.Failure error) + (#error.Failure error)))) diff --git a/stdlib/source/lux/platform/compiler/phase/extension/analysis/host.jvm.lux b/stdlib/source/lux/platform/compiler/phase/extension/analysis/host.jvm.lux index a494b0e44..2981dc89b 100644 --- a/stdlib/source/lux/platform/compiler/phase/extension/analysis/host.jvm.lux +++ b/stdlib/source/lux/platform/compiler/phase/extension/analysis/host.jvm.lux @@ -6,7 +6,7 @@ ["ex" exception (#+ exception:)] pipe] [data - ["e" error] + ["." error (#+ Error)] ["." maybe] ["." product] ["." text ("text/." Equivalence<Text>) @@ -485,10 +485,10 @@ (do ////.Monad<Operation> [] (case (Class::forName name) - (#e.Success [class]) + (#error.Success [class]) (wrap class) - (#e.Error error) + (#error.Failure error) (////.throw unknown-class name)))) (def: (sub-class? super sub) @@ -759,7 +759,7 @@ (do ////.Monad<Operation> [class (load-class class-name)] (case (Class::getDeclaredField field-name class) - (#e.Success field) + (#error.Success field) (let [owner (Field::getDeclaringClass field)] (if (is? owner class) (wrap [class field]) @@ -768,7 +768,7 @@ " Owner Class: " (Class::getName owner) text.new-line "Target Class: " class-name text.new-line)))) - (#e.Error _) + (#error.Failure _) (////.throw unknown-field (format class-name "#" field-name))))) (def: (static-field class-name field-name) @@ -1143,9 +1143,9 @@ (def: invoke::static Handler (function (_ extension-name analyse args) - (case (: (e.Error [Text Text (List [Text Code])]) + (case (: (Error [Text Text (List [Text Code])]) (s.run args ($_ p.and s.text s.text (p.some (s.tuple (p.and s.text s.any)))))) - (#e.Success [class method argsTC]) + (#error.Success [class method argsTC]) (do ////.Monad<Operation> [#let [argsT (list/map product.left argsTC)] [methodT exceptionsT] (method-candidate class method #Static argsT) @@ -1160,9 +1160,9 @@ (def: invoke::virtual Handler (function (_ extension-name analyse args) - (case (: (e.Error [Text Text Code (List [Text Code])]) + (case (: (Error [Text Text Code (List [Text Code])]) (s.run args ($_ p.and s.text s.text s.any (p.some (s.tuple (p.and s.text s.any)))))) - (#e.Success [class method objectC argsTC]) + (#error.Success [class method objectC argsTC]) (do ////.Monad<Operation> [#let [argsT (list/map product.left argsTC)] [methodT exceptionsT] (method-candidate class method #Virtual argsT) @@ -1183,9 +1183,9 @@ (def: invoke::special Handler (function (_ extension-name analyse args) - (case (: (e.Error [(List Code) [Text Text Code (List [Text Code]) Any]]) + (case (: (Error [(List Code) [Text Text Code (List [Text Code]) Any]]) (p.run args ($_ p.and s.text s.text s.any (p.some (s.tuple (p.and s.text s.any))) s.end!))) - (#e.Success [_ [class method objectC argsTC _]]) + (#error.Success [_ [class method objectC argsTC _]]) (do ////.Monad<Operation> [#let [argsT (list/map product.left argsTC)] [methodT exceptionsT] (method-candidate class method #Special argsT) @@ -1200,9 +1200,9 @@ (def: invoke::interface Handler (function (_ extension-name analyse args) - (case (: (e.Error [Text Text Code (List [Text Code])]) + (case (: (Error [Text Text Code (List [Text Code])]) (s.run args ($_ p.and s.text s.text s.any (p.some (s.tuple (p.and s.text s.any)))))) - (#e.Success [class-name method objectC argsTC]) + (#error.Success [class-name method objectC argsTC]) (do ////.Monad<Operation> [#let [argsT (list/map product.left argsTC)] class (load-class class-name) @@ -1221,9 +1221,9 @@ (def: invoke::constructor Handler (function (_ extension-name analyse args) - (case (: (e.Error [Text (List [Text Code])]) + (case (: (Error [Text (List [Text Code])]) (s.run args ($_ p.and s.text (p.some (s.tuple (p.and s.text s.any)))))) - (#e.Success [class argsTC]) + (#error.Success [class argsTC]) (do ////.Monad<Operation> [#let [argsT (list/map product.left argsTC)] [methodT exceptionsT] (constructor-candidate class argsT) diff --git a/stdlib/source/lux/platform/compiler/phase/synthesis/expression.lux b/stdlib/source/lux/platform/compiler/phase/synthesis/expression.lux index 0d15ae463..672bc9e87 100644 --- a/stdlib/source/lux/platform/compiler/phase/synthesis/expression.lux +++ b/stdlib/source/lux/platform/compiler/phase/synthesis/expression.lux @@ -78,7 +78,7 @@ (case> (#error.Success output) (#error.Success output) - (#error.Error error) + (#error.Failure error) (<| (///.run' state) (do ///.Monad<Operation> [argsS+ (monad.map @ phase args)] diff --git a/stdlib/source/lux/platform/compiler/phase/translation.lux b/stdlib/source/lux/platform/compiler/phase/translation.lux index fb40f4652..c7fb60c08 100644 --- a/stdlib/source/lux/platform/compiler/phase/translation.lux +++ b/stdlib/source/lux/platform/compiler/phase/translation.lux @@ -108,8 +108,8 @@ (#error.Success [[bundle' (set@ #context [old-scope (inc old-inner)] state')] [new-scope output]]) - (#error.Error error) - (#error.Error error))))) + (#error.Failure error) + (#error.Failure error))))) (def: #export context (All [anchor expression statement] @@ -129,8 +129,8 @@ (#error.Success [[bundle' (set@ <tag> (get@ <tag> state) state')] output]) - (#error.Error error) - (#error.Error error))))) + (#error.Failure error) + (#error.Failure error))))) (def: #export <get> (All [anchor expression statement] @@ -180,7 +180,7 @@ (#error.Success output) (#error.Success [state+ output]) - (#error.Error error) + (#error.Failure error) (ex.throw cannot-interpret error))))] [evaluate! expression] @@ -195,7 +195,7 @@ (#error.Success output) (#error.Success [stateE output]) - (#error.Error error) + (#error.Failure error) (ex.throw cannot-interpret error)))) (def: #export (save! name code) diff --git a/stdlib/source/lux/platform/interpreter.lux b/stdlib/source/lux/platform/interpreter.lux index b73f72bc6..a75cbc01e 100644 --- a/stdlib/source/lux/platform/interpreter.lux +++ b/stdlib/source/lux/platform/interpreter.lux @@ -132,7 +132,7 @@ (#error.Success [state' output]) (#error.Success [state' output]) - (#error.Error error) + (#error.Failure error) (if (ex.match? total.not-a-statement error) (<| (phase.run' state) (:share [anchor expression statement] @@ -140,7 +140,7 @@ state} {<Interpretation> (interpret-expression code)})) - (#error.Error error))))) + (#error.Failure error))))) ) (def: (execute configuration code) @@ -213,7 +213,7 @@ [_ (:: Console<!> write representation)] (recur context' #0)) - (#error.Error error) + (#error.Failure error) (if (ex.match? syntax.end-of-file error) (recur context #1) (exec (log! (ex.construct ..error error)) diff --git a/stdlib/source/lux/platform/interpreter/type.lux b/stdlib/source/lux/platform/interpreter/type.lux index 7d3ac0d9c..698238e1c 100644 --- a/stdlib/source/lux/platform/interpreter/type.lux +++ b/stdlib/source/lux/platform/interpreter/type.lux @@ -144,7 +144,7 @@ #.None representation) - (#error.Error error) + (#error.Failure error) (p.fail error)))) (def: (tuple-representation representation) @@ -199,5 +199,5 @@ (ex.report ["Type" (%type type)] ["Value" (representation value)]) - (#error.Error error) + (#error.Failure error) (ex.construct cannot-represent-value [type]))) diff --git a/stdlib/source/lux/time/date.lux b/stdlib/source/lux/time/date.lux index 0e8f5468a..71dd1003d 100644 --- a/stdlib/source/lux/time/date.lux +++ b/stdlib/source/lux/time/date.lux @@ -8,7 +8,7 @@ ["p" parser] [monad (#+ do)]] [data - ["e" error] + ["." error (#+ Error)] ["." maybe] ["." number ("int/." Codec<Text,Int>)] [text ("text/." Monoid<Text>) @@ -314,7 +314,7 @@ #day (.nat utc-day)}))) (def: (decode input) - (-> Text (e.Error Date)) + (-> Text (Error Date)) (l.run input lex-date)) (structure: #export _ diff --git a/stdlib/source/lux/time/instant.lux b/stdlib/source/lux/time/instant.lux index 08029405a..8c61abe5c 100644 --- a/stdlib/source/lux/time/instant.lux +++ b/stdlib/source/lux/time/instant.lux @@ -9,7 +9,7 @@ [monad (#+ do Monad)] ["p" parser]] [data - ["e" error] + ["." error (#+ Error)] ["." maybe] ["." number ("int/." Codec<Text,Int>)] [text ("text/." Monoid<Text>) @@ -300,7 +300,7 @@ ## (shift (duration.scale-up utc-millis duration.milli)))))) ## (def: (decode input) -## (-> Text (e.Error Instant)) +## (-> Text (Error Instant)) ## (l.run input lex-instant)) ## (structure: #export _ diff --git a/stdlib/source/lux/type/check.lux b/stdlib/source/lux/type/check.lux index 7d2e55982..fa6067ab6 100644 --- a/stdlib/source/lux/type/check.lux +++ b/stdlib/source/lux/type/check.lux @@ -58,8 +58,8 @@ (#error.Success [context' output]) (#error.Success [context' (f output)]) - (#error.Error error) - (#error.Error error))))) + (#error.Failure error) + (#error.Failure error))))) (structure: #export _ (Apply Check) (def: functor Functor<Check>) @@ -72,11 +72,11 @@ (#error.Success [context'' a]) (#error.Success [context'' (f a)]) - (#error.Error error) - (#error.Error error)) + (#error.Failure error) + (#error.Failure error)) - (#error.Error error) - (#error.Error error) + (#error.Failure error) + (#error.Failure error) ))) ) @@ -95,11 +95,11 @@ (#error.Success [context'' a]) (#error.Success [context'' a]) - (#error.Error error) - (#error.Error error)) + (#error.Failure error) + (#error.Failure error)) - (#error.Error error) - (#error.Error error) + (#error.Failure error) + (#error.Failure error) ))) ) @@ -155,8 +155,8 @@ (#error.Success [context' output]) (#error.Success output) - (#error.Error error) - (#error.Error error))) + (#error.Failure error) + (#error.Failure error))) (def: #export (throw exception message) (All [e a] (-> (ex.Exception e) e (Check a))) @@ -299,20 +299,20 @@ (#error.Success [context' output]) (#error.Success [context' (#.Some output)]) - (#error.Error _) + (#error.Failure _) (#error.Success [context #.None])))) (def: #export (fail message) (All [a] (-> Text (Check a))) (function (_ context) - (#error.Error message))) + (#error.Failure message))) (def: #export (assert message test) (-> Text Bit (Check Any)) (function (_ context) (if test (#error.Success [context []]) - (#error.Error message)))) + (#error.Failure message)))) (def: (either left right) (All [a] (-> (Check a) (Check a) (Check a))) @@ -321,7 +321,7 @@ (#error.Success [context' output]) (#error.Success [context' output]) - (#error.Error _) + (#error.Failure _) (right context)))) (def: (assumed? [e a] assumptions) @@ -441,18 +441,18 @@ (All [a] (-> (-> Any Text) (Check a) (Check a))) (function (_ context) (case (check context) - (#error.Error error) - (#error.Error (case error - "" - (on-error []) - - _ - ($_ text/compose - (on-error []) - text.new-line text.new-line - "-----------------------------------------" - text.new-line text.new-line - error))) + (#error.Failure error) + (#error.Failure (case error + "" + (on-error []) + + _ + ($_ text/compose + (on-error []) + text.new-line text.new-line + "-----------------------------------------" + text.new-line text.new-line + error))) output output))) @@ -628,7 +628,7 @@ {#.doc "A simple type-checking function that just returns a yes/no answer."} (-> Type Type Bit) (case (run fresh-context (check' (list) expected actual)) - (#error.Error _) + (#error.Failure _) #0 (#error.Success _) diff --git a/stdlib/source/lux/type/quotient.lux b/stdlib/source/lux/type/quotient.lux index 17780e622..994383744 100644 --- a/stdlib/source/lux/type/quotient.lux +++ b/stdlib/source/lux/type/quotient.lux @@ -4,7 +4,7 @@ [monad (#+ do)] ["p" parser]] [data - ["e" error (#+ Error)]] + ["." error (#+ Error)]] ["." type abstract] ["." macro @@ -62,9 +62,9 @@ (do @ [constructorT (macro.find-type quotient) quotientT (case (quotient-type constructorT) - (#e.Success quotientT) + (#error.Success quotientT) (wrap quotientT) - (#e.Error error) + (#error.Failure error) (p.fail error))] (wrap (list (type.to-code quotientT))))) diff --git a/stdlib/source/lux/type/refinement.lux b/stdlib/source/lux/type/refinement.lux index 1013cf283..4ccfd02be 100644 --- a/stdlib/source/lux/type/refinement.lux +++ b/stdlib/source/lux/type/refinement.lux @@ -5,7 +5,7 @@ [monad (#+ do)] ["p" parser]] [data - ["e" error (#+ Error)]] + ["." error (#+ Error)]] ["." type ("type/." Equivalence<Type>) abstract] ["." macro @@ -96,9 +96,9 @@ (do @ [constructorT (macro.find-type refinement) refinementT (case (refinement-type constructorT) - (#e.Success refinementT) + (#error.Success refinementT) (wrap refinementT) - (#e.Error error) + (#error.Failure error) (p.fail error))] (wrap (list (type.to-code refinementT))))) diff --git a/stdlib/source/lux/world/file.lux b/stdlib/source/lux/world/file.lux index ac033fd89..343d2f7aa 100644 --- a/stdlib/source/lux/world/file.lux +++ b/stdlib/source/lux/world/file.lux @@ -347,12 +347,12 @@ (#error.Success file) (wrap true) - (#error.Error _) + (#error.Failure _) (do Monad<!> [?directory (:: System<!> directory path)] (case ?directory (#error.Success directory) (wrap true) - (#error.Error _) + (#error.Failure _) (wrap false)))))) diff --git a/stdlib/source/lux/world/net/tcp.jvm.lux b/stdlib/source/lux/world/net/tcp.jvm.lux index f9bde2e2c..cd8543f3a 100644 --- a/stdlib/source/lux/world/net/tcp.jvm.lux +++ b/stdlib/source/lux/world/net/tcp.jvm.lux @@ -113,7 +113,7 @@ [socket (ServerSocket::accept server)] (io.io (tcp socket)))] (case ?client - (#error.Error error) + (#error.Failure error) (wrap []) (#error.Success client) diff --git a/stdlib/test/test/lux/cli.lux b/stdlib/test/test/lux/cli.lux index 501c62df4..12e0b7361 100644 --- a/stdlib/test/test/lux/cli.lux +++ b/stdlib/test/test/lux/cli.lux @@ -5,7 +5,7 @@ pipe ["p" parser]] [data - ["E" error] + ["." error] ["." number] [text ("text/." Equivalence<Text>) format] @@ -30,32 +30,44 @@ ($_ seq (test "Can read any argument." (|> (/.run (list yes) /.any) - (case> (#E.Error _) + (case> (#error.Failure _) #0 - (#E.Success arg) + (#error.Success arg) (text/= arg yes)))) (test "Can test tokens." (and (|> (/.run (list yes) (/.this yes)) - (case> (#E.Error _) #0 (#E.Success _) #1)) + (case> (#error.Failure _) + #0 + + (#error.Success _) + #1)) (|> (/.run (list no) (/.this yes)) - (case> (#E.Error _) #1 (#E.Success _) #0)))) + (case> (#error.Failure _) + #1 + + (#error.Success _) + #0)))) (test "Can use custom token parsers." (|> (/.run (list yes) (/.parse Nat/decode)) - (case> (#E.Error _) + (case> (#error.Failure _) #0 - (#E.Success parsed) + (#error.Success parsed) (text/= (Nat/encode parsed) yes)))) (test "Can query if there are any more inputs." (and (|> (/.run (list) /.end) - (case> (#E.Success []) #1 _ #0)) + (case> (#error.Success []) #1 _ #0)) (|> (/.run (list yes) (p.not /.end)) - (case> (#E.Success []) #0 _ #1)))) + (case> (#error.Success []) #0 _ #1)))) (test "Can parse CLI input anywhere." (|> (/.run (list.concat (list pre-ignore (list yes) post-ignore)) (|> (/.somewhere (/.this yes)) (p.before (p.some /.any)))) - (case> (#E.Error _) #0 (#E.Success _) #1))) + (case> (#error.Failure _) + #0 + + (#error.Success _) + #1))) )))) diff --git a/stdlib/test/test/lux/compiler/default/phase/analysis/function.lux b/stdlib/test/test/lux/compiler/default/phase/analysis/function.lux index e9d1c6f8e..e46f22585 100644 --- a/stdlib/test/test/lux/compiler/default/phase/analysis/function.lux +++ b/stdlib/test/test/lux/compiler/default/phase/analysis/function.lux @@ -4,7 +4,7 @@ [monad (#+ do)] pipe] [data - ["e" error] + ["." error] ["." maybe] ["." product] [text ("text/." Equivalence<Text>) @@ -37,11 +37,11 @@ (|> analysis (typeA.with-type expectedT) (phase.run _primitive.state) - (case> (#e.Success applyA) + (case> (#error.Success applyA) (let [[funcA argsA] (analysis.application applyA)] (n/= num-args (list.size argsA))) - (#e.Error error) + (#error.Failure error) #0))) (context: "Function definition." diff --git a/stdlib/test/test/lux/compiler/default/phase/analysis/primitive.lux b/stdlib/test/test/lux/compiler/default/phase/analysis/primitive.lux index 6a64cc206..a101c5414 100644 --- a/stdlib/test/test/lux/compiler/default/phase/analysis/primitive.lux +++ b/stdlib/test/test/lux/compiler/default/phase/analysis/primitive.lux @@ -5,7 +5,7 @@ pipe ["ex" exception (#+ exception:)]] [data - ["e" error] + ["." error (#+ Error)] [text format]] [math @@ -57,23 +57,23 @@ ["Inferred" (%type inferred)])) (def: (infer-primitive expected-type analysis) - (-> Type (Operation Analysis) (e.Error Analysis)) + (-> Type (Operation Analysis) (Error Analysis)) (|> analysis typeA.with-inference (phase.run ..state) - (case> (#e.Success [inferred-type output]) + (case> (#error.Success [inferred-type output]) (if (is? expected-type inferred-type) - (#e.Success output) + (#error.Success output) (ex.throw wrong-inference [expected-type inferred-type])) - (#e.Error error) - (#e.Error error)))) + (#error.Failure error) + (#error.Failure error)))) (context: "Primitives" ($_ seq (test "Can analyse unit." (|> (infer-primitive Any (..phase (' []))) - (case> (^ (#e.Success (#analysis.Primitive (#analysis.Unit output)))) + (case> (^ (#error.Success (#analysis.Primitive (#analysis.Unit output)))) (is? [] output) _ @@ -85,7 +85,7 @@ [sample <random>] (test (format "Can analyse " <desc> ".") (|> (infer-primitive <type> (..phase (<constructor> sample))) - (case> (#e.Success (#analysis.Primitive (<tag> output))) + (case> (#error.Success (#analysis.Primitive (<tag> output))) (is? sample output) _ diff --git a/stdlib/test/test/lux/compiler/default/phase/analysis/procedure/common.lux b/stdlib/test/test/lux/compiler/default/phase/analysis/procedure/common.lux index 108b350d0..2a1a20005 100644 --- a/stdlib/test/test/lux/compiler/default/phase/analysis/procedure/common.lux +++ b/stdlib/test/test/lux/compiler/default/phase/analysis/procedure/common.lux @@ -7,7 +7,7 @@ [concurrency ["." atom]] [data - ["e" error] + ["." error] ["." product] [text format]] @@ -36,10 +36,10 @@ (typeA.with-type output-type (_primitive.phase (` ((~ (code.text procedure)) (~+ params)))))) (phase.run _primitive.state) - (case> (#e.Success _) + (case> (#error.Success _) <success> - (#e.Error error) + (#error.Failure error) <failure>)))] [check-success+ #1 #0] diff --git a/stdlib/test/test/lux/compiler/default/phase/analysis/reference.lux b/stdlib/test/test/lux/compiler/default/phase/analysis/reference.lux index 8aed9e39b..b24d74e1e 100644 --- a/stdlib/test/test/lux/compiler/default/phase/analysis/reference.lux +++ b/stdlib/test/test/lux/compiler/default/phase/analysis/reference.lux @@ -4,7 +4,7 @@ [monad (#+ do)] pipe] [data - ["e" error] + ["." error (#+ Error)] [name ("name/." Equivalence<Name>)] [text ("text/." Equivalence<Text>)]] [math @@ -28,15 +28,15 @@ [// ["_." primitive]]) -(type: Check (-> (e.Error Any) Bit)) +(type: Check (-> (Error Any) Bit)) (do-template [<name> <on-success> <on-failure>] [(def: <name> Check - (|>> (case> (#e.Success _) + (|>> (case> (#error.Success _) <on-success> - (#e.Error _) + (#error.Failure _) <on-failure>)))] [success? #1 #0] @@ -78,7 +78,7 @@ (typeA.with-inference (_primitive.phase (code.local-identifier var-name))))) (phase.run _primitive.state) - (case> (^ (#e.Success [inferredT (#analysis.Reference (reference.local var))])) + (case> (^ (#error.Success [inferredT (#analysis.Reference (reference.local var))])) (and (type/= expectedT inferredT) (n/= 0 var)) @@ -92,7 +92,7 @@ (_primitive.phase (code.identifier def-name)))) (module.with-module 0 def-module) (phase.run _primitive.state) - (case> (^ (#e.Success [_ inferredT (#analysis.Reference (reference.constant constant-name))])) + (case> (^ (#error.Success [_ inferredT (#analysis.Reference (reference.constant constant-name))])) (and (type/= expectedT inferredT) (name/= def-name constant-name)) diff --git a/stdlib/test/test/lux/compiler/default/syntax.lux b/stdlib/test/test/lux/compiler/default/syntax.lux index 165a224e5..74d927975 100644 --- a/stdlib/test/test/lux/compiler/default/syntax.lux +++ b/stdlib/test/test/lux/compiler/default/syntax.lux @@ -3,13 +3,13 @@ [control [monad (#+ do)]] [data - ["e" error] + ["." error] ["." text format ["l" lexer]] [collection ["." list] - ["dict" dictionary (#+ Dictionary)]]] + ["." dictionary (#+ Dictionary)]]] [math ["r" random ("r/." Monad<Random>)]] [macro @@ -88,28 +88,28 @@ ($_ seq (test "Can parse Lux code." (case (let [source-code (%code sample)] - (&.parse "" (dict.new text.Hash<Text>) (text.size source-code) + (&.parse "" (dictionary.new text.Hash<Text>) (text.size source-code) [default-cursor 0 source-code])) - (#e.Error error) + (#error.Failure error) #0 - (#e.Success [_ parsed]) + (#error.Success [_ parsed]) (:: code.Equivalence<Code> = parsed sample))) (test "Can parse Lux multiple code nodes." (let [source-code (format (%code sample) " " (%code other)) source-code//size (text.size source-code)] - (case (&.parse "" (dict.new text.Hash<Text>) source-code//size + (case (&.parse "" (dictionary.new text.Hash<Text>) source-code//size [default-cursor 0 source-code]) - (#e.Error error) + (#error.Failure error) #0 - (#e.Success [remaining =sample]) - (case (&.parse "" (dict.new text.Hash<Text>) source-code//size + (#error.Success [remaining =sample]) + (case (&.parse "" (dictionary.new text.Hash<Text>) source-code//size remaining) - (#e.Error error) + (#error.Failure error) #0 - (#e.Success [_ =other]) + (#error.Success [_ =other]) (and (:: code.Equivalence<Code> = sample =sample) (:: code.Equivalence<Code> = other =other)))))) )))) @@ -137,11 +137,11 @@ (test "Can handle comments." (case (let [source-code (format comment (%code sample)) source-code//size (text.size source-code)] - (&.parse "" (dict.new text.Hash<Text>) source-code//size + (&.parse "" (dictionary.new text.Hash<Text>) source-code//size [default-cursor 0 source-code])) - (#e.Error error) + (#error.Failure error) #0 - (#e.Success [_ parsed]) + (#error.Success [_ parsed]) (:: code.Equivalence<Code> = parsed sample))) )))) diff --git a/stdlib/test/test/lux/control/concurrency/actor.lux b/stdlib/test/test/lux/control/concurrency/actor.lux index 90c3d6dd4..59a0f4d76 100644 --- a/stdlib/test/test/lux/control/concurrency/actor.lux +++ b/stdlib/test/test/lux/control/concurrency/actor.lux @@ -9,7 +9,7 @@ ["T" task] ["&" actor (#+ actor: message:)]]] [data - ["e" error] + ["." error] [text format]]] lux/test) @@ -67,9 +67,9 @@ (n/= 3 output-3))))] (assert "Can send messages to actors." (case result - (#e.Success outcome) + (#error.Success outcome) outcome - (#e.Error error) + (#error.Failure error) #0)))) )) diff --git a/stdlib/test/test/lux/control/exception.lux b/stdlib/test/test/lux/control/exception.lux index 36555f490..aa6c8bf09 100644 --- a/stdlib/test/test/lux/control/exception.lux +++ b/stdlib/test/test/lux/control/exception.lux @@ -4,7 +4,7 @@ ["M" monad (#+ do Monad)] ["&" exception (#+ exception:)]] [data - ["E" error] + ["." error (#+ Error)] ["." text format]] [math @@ -39,7 +39,7 @@ another-val) otherwise-val) default-val) - actual (|> (: (E.Error Nat) + actual (|> (: (Error Nat) (if should-throw? (&.throw this-ex []) (&.return default-val))) diff --git a/stdlib/test/test/lux/control/parser.lux b/stdlib/test/test/lux/control/parser.lux index 378cbccd4..37b296357 100644 --- a/stdlib/test/test/lux/control/parser.lux +++ b/stdlib/test/test/lux/control/parser.lux @@ -17,8 +17,11 @@ (def: (should-fail input) (All [a] (-> (Error a) Bit)) (case input - (#error.Error _) #1 - _ #0)) + (#error.Failure _) + #1 + + _ + #0)) (def: (enforced? parser input) (All [s] (-> (&.Parser s Any) s Bit)) @@ -41,7 +44,7 @@ (def: (fails? input) (All [a] (-> (Error a) Bit)) (case input - (#error.Error _) + (#error.Failure _) #1 _ diff --git a/stdlib/test/test/lux/control/region.lux b/stdlib/test/test/lux/control/region.lux index 8a419bb0a..f639739b4 100644 --- a/stdlib/test/test/lux/control/region.lux +++ b/stdlib/test/test/lux/control/region.lux @@ -6,7 +6,7 @@ ["." thread (#+ Thread)] ["ex" exception (#+ exception:)]] [data - ["e" error (#+ Error)] + ["." error (#+ Error)] [collection ["." list]]] [math @@ -19,8 +19,11 @@ [(def: (<name> result) (All [a] (-> (Error a) Bit)) (case result - (#e.Success _) <success> - (#e.Error _) <error>))] + (#error.Success _) + <success> + + (#error.Failure _) + <error>))] [success? #1 #0] [error? #0 #1] @@ -39,7 +42,7 @@ count-clean-up (function (_ value) (do @ [_ (thread.update inc clean-up-counter)] - (wrap (#e.Success []))))] + (wrap (#error.Success []))))] outcome (/.run @ (do (/.Monad<Region> @) [_ (monad.map @ (/.acquire @@ count-clean-up) @@ -57,7 +60,7 @@ count-clean-up (function (_ value) (do @ [_ (thread.update inc clean-up-counter)] - (wrap (#e.Success []))))] + (wrap (#error.Success []))))] outcome (/.run @ (do (/.Monad<Region> @) [_ (monad.map @ (/.acquire @@ count-clean-up) diff --git a/stdlib/test/test/lux/control/security/taint.lux b/stdlib/test/test/lux/control/security/taint.lux index 5b33e7127..81b17d407 100644 --- a/stdlib/test/test/lux/control/security/taint.lux +++ b/stdlib/test/test/lux/control/security/taint.lux @@ -24,12 +24,12 @@ (case (@.validate (function (_ value) (if (|> value text.size (n/> 0)) (#error.Success value) - (#error.Error "Empty text is invalid."))) + (#error.Failure "Empty text is invalid."))) dirty) (#error.Success clean) (text/= raw clean) - (#error.Error error) + (#error.Failure error) false)) ))) diff --git a/stdlib/test/test/lux/data/error.lux b/stdlib/test/test/lux/data/error.lux index 30a12855d..4848443f9 100644 --- a/stdlib/test/test/lux/data/error.lux +++ b/stdlib/test/test/lux/data/error.lux @@ -5,54 +5,57 @@ [monad (#+ do Monad)] pipe] [data - ["&" error]]] + ["/" error (#+ Error)]]] lux/test) (context: "Errors" - (let [(^open "&/.") &.Apply<Error> - (^open "&/.") &.Monad<Error>] + (let [(^open "//.") /.Apply<Error> + (^open "//.") /.Monad<Error>] ($_ seq (test "Functor correctly handles both cases." - (and (|> (: (&.Error Int) (#&.Success +10)) - (&/map inc) - (case> (#&.Success +11) #1 _ #0)) + (and (|> (: (Error Int) (#/.Success +10)) + (//map inc) + (case> (#/.Success +11) #1 _ #0)) - (|> (: (&.Error Int) (#&.Error "YOLO")) - (&/map inc) - (case> (#&.Error "YOLO") #1 _ #0)) + (|> (: (Error Int) (#/.Failure "YOLO")) + (//map inc) + (case> (#/.Failure "YOLO") #1 _ #0)) )) (test "Apply correctly handles both cases." - (and (|> (&/wrap +20) - (case> (#&.Success +20) #1 _ #0)) - (|> (&/apply (&/wrap inc) (&/wrap +10)) - (case> (#&.Success +11) #1 _ #0)) - (|> (&/apply (&/wrap inc) (#&.Error "YOLO")) - (case> (#&.Error "YOLO") #1 _ #0)))) + (and (|> (//wrap +20) + (case> (#/.Success +20) #1 _ #0)) + (|> (//apply (//wrap inc) (//wrap +10)) + (case> (#/.Success +11) #1 _ #0)) + (|> (//apply (//wrap inc) (#/.Failure "YOLO")) + (case> (#/.Failure "YOLO") #1 _ #0)))) (test "Monad correctly handles both cases." - (and (|> (do &.Monad<Error> + (and (|> (do /.Monad<Error> [f (wrap i/+) a (wrap +10) b (wrap +20)] (wrap (f a b))) - (case> (#&.Success +30) #1 _ #0)) - (|> (do &.Monad<Error> + (case> (#/.Success +30) #1 _ #0)) + (|> (do /.Monad<Error> [f (wrap i/+) - a (#&.Error "YOLO") + a (#/.Failure "YOLO") b (wrap +20)] (wrap (f a b))) - (case> (#&.Error "YOLO") #1 _ #0)) + (case> (#/.Failure "YOLO") #1 _ #0)) )) ))) (context: "Monad transformer" - (let [lift (&.lift io.Monad<IO>) + (let [lift (/.lift io.Monad<IO>) (^open "io/.") io.Monad<IO>] (test "Can add error functionality to any monad." - (|> (io.run (do (&.ErrorT io.Monad<IO>) + (|> (io.run (do (/.ErrorT io.Monad<IO>) [a (lift (io/wrap +123)) b (wrap +456)] (wrap (i/+ a b)))) - (case> (#&.Success +579) #1 - _ #0))))) + (case> (#/.Success +579) + #1 + + _ + #0))))) diff --git a/stdlib/test/test/lux/data/format/json.lux b/stdlib/test/test/lux/data/format/json.lux index 0f905a844..9b6b3f9a1 100644 --- a/stdlib/test/test/lux/data/format/json.lux +++ b/stdlib/test/test/lux/data/format/json.lux @@ -7,7 +7,7 @@ pipe ["p" parser]] [data - ["e" error] + ["." error] ["." bit] ["." maybe] ["." number] @@ -176,8 +176,8 @@ (^open "@/.") Codec<JSON,Record>]] (test "Can encode/decode arbitrary types." (|> sample @/encode @/decode - (case> (#e.Success result) + (case> (#error.Success result) (@/= sample result) - (#e.Error error) + (#error.Failure error) #0)))))) diff --git a/stdlib/test/test/lux/data/text/lexer.lux b/stdlib/test/test/lux/data/text/lexer.lux index d87f91eb4..a08c49ef7 100644 --- a/stdlib/test/test/lux/data/text/lexer.lux +++ b/stdlib/test/test/lux/data/text/lexer.lux @@ -5,7 +5,7 @@ pipe ["p" parser]] [data - ["E" error] + ["." error (#+ Error)] ["." text ("text/." Equivalence<Text>) format ["&" lexer]] @@ -17,13 +17,13 @@ ## [Utils] (def: (should-fail input) - (All [a] (-> (E.Error a) Bit)) + (All [a] (-> (Error a) Bit)) (case input (#.Left _) #1 _ #0)) (def: (should-passT test input) - (-> Text (E.Error Text) Bit) + (-> Text (Error Text) Bit) (case input (#.Right output) (text/= test output) @@ -32,7 +32,7 @@ #0)) (def: (should-passL test input) - (-> (List Text) (E.Error (List Text)) Bit) + (-> (List Text) (Error (List Text)) Bit) (let [(^open "list/.") (list.Equivalence<List> text.Equivalence<Text>)] (case input (#.Right output) @@ -42,7 +42,7 @@ #0))) (def: (should-passE test input) - (-> (Either Text Text) (E.Error (Either Text Text)) Bit) + (-> (Either Text Text) (Error (Either Text Text)) Bit) (case input (#.Right output) (case [test output] diff --git a/stdlib/test/test/lux/macro/syntax.lux b/stdlib/test/test/lux/macro/syntax.lux index 0bf7b8804..5fe3a6118 100644 --- a/stdlib/test/test/lux/macro/syntax.lux +++ b/stdlib/test/test/lux/macro/syntax.lux @@ -7,7 +7,7 @@ [data ["." bit] ["." name] - ["e" error] + ["." error (#+ Error)] ["." number] ["." text format]] @@ -47,7 +47,7 @@ #0)) (def: (fails? input) - (All [a] (-> (e.Error a) Bit)) + (All [a] (-> (Error a) Bit)) (case input (#.Left _) #1 @@ -72,12 +72,12 @@ (found? (s.this? (<ctor> <value>)) (list (<ctor> <value>))) (enforced? (s.this (<ctor> <value>)) (list (<ctor> <value>)))))] - ["Can parse Bit syntax." #1 code.bit bit.Equivalence<Bit> s.bit] - ["Can parse Nat syntax." 123 code.nat number.Equivalence<Nat> s.nat] - ["Can parse Int syntax." +123 code.int number.Equivalence<Int> s.int] - ["Can parse Rev syntax." .123 code.rev number.Equivalence<Rev> s.rev] - ["Can parse Frac syntax." +123.0 code.frac number.Equivalence<Frac> s.frac] - ["Can parse Text syntax." text.new-line code.text text.Equivalence<Text> s.text] + ["Can parse Bit syntax." #1 code.bit bit.Equivalence<Bit> s.bit] + ["Can parse Nat syntax." 123 code.nat number.Equivalence<Nat> s.nat] + ["Can parse Int syntax." +123 code.int number.Equivalence<Int> s.int] + ["Can parse Rev syntax." .123 code.rev number.Equivalence<Rev> s.rev] + ["Can parse Frac syntax." +123.0 code.frac number.Equivalence<Frac> s.frac] + ["Can parse Text syntax." text.new-line code.text text.Equivalence<Text> s.text] ["Can parse Identifier syntax." ["yolo" "lol"] code.identifier name.Equivalence<Name> s.identifier] ["Can parse Tag syntax." ["yolo" "lol"] code.tag name.Equivalence<Name> s.tag] )] diff --git a/stdlib/test/test/lux/math/modular.lux b/stdlib/test/test/lux/math/modular.lux index 559928304..f2a3bdef6 100644 --- a/stdlib/test/test/lux/math/modular.lux +++ b/stdlib/test/test/lux/math/modular.lux @@ -5,7 +5,7 @@ [data ["." product] [bit ("bit/." Equivalence<Bit>)] - ["e" error] + ["." error] [text format]] [math @@ -64,11 +64,11 @@ (do @ [_normalM modulusR _alternativeM (|> modulusR (r.filter (|>> (i/= _normalM) not))) - #let [normalM (|> _normalM /.from-int e.assume) - alternativeM (|> _alternativeM /.from-int e.assume)] + #let [normalM (|> _normalM /.from-int error.assume) + alternativeM (|> _alternativeM /.from-int error.assume)] [_param param] (modR normalM) [_subject subject] (modR normalM) - #let [copyM (|> normalM /.to-int /.from-int e.assume)]] + #let [copyM (|> normalM /.to-int /.from-int error.assume)]] ($_ seq (test "Every modulus has a unique type, even if the numeric value is the same as another." (and (type/= (:of normalM) @@ -117,28 +117,28 @@ (test "Can encode/decode to text." (let [(^open "mod/.") (/.Codec<Text,Mod> normalM)] (case (|> subject mod/encode mod/decode) - (#e.Success output) + (#error.Success output) (/.m/= subject output) - (#e.Error error) + (#error.Failure error) #0))) (test "Can equalize 2 moduli if they are equal." (case (/.equalize (/.mod normalM _subject) (/.mod copyM _param)) - (#e.Success paramC) + (#error.Success paramC) (/.m/= param paramC) - (#e.Error error) + (#error.Failure error) #0)) (test "Cannot equalize 2 moduli if they are the different." (case (/.equalize (/.mod normalM _subject) (/.mod alternativeM _param)) - (#e.Success paramA) + (#error.Success paramA) #0 - (#e.Error error) + (#error.Failure error) #1)) (test "All numbers are congruent to themselves." diff --git a/stdlib/test/test/lux/time/date.lux b/stdlib/test/test/lux/time/date.lux index 602ecc78f..87734f22f 100644 --- a/stdlib/test/test/lux/time/date.lux +++ b/stdlib/test/test/lux/time/date.lux @@ -143,5 +143,5 @@ (case> (#error.Success decoded) (@/= sample decoded) - (#error.Error error) + (#error.Failure error) #0)))))) diff --git a/stdlib/test/test/lux/time/instant.lux b/stdlib/test/test/lux/time/instant.lux index 734456765..975c72558 100644 --- a/stdlib/test/test/lux/time/instant.lux +++ b/stdlib/test/test/lux/time/instant.lux @@ -95,5 +95,5 @@ ## (case> (#error.Success decoded) ## (@/= sample decoded) -## (#error.Error error) +## (#error.Failure error) ## #0)))))) diff --git a/stdlib/test/test/lux/world/binary.lux b/stdlib/test/test/lux/world/binary.lux index a6a6df9d6..c2f09abd8 100644 --- a/stdlib/test/test/lux/world/binary.lux +++ b/stdlib/test/test/lux/world/binary.lux @@ -3,7 +3,7 @@ [control ["." monad (#+ do)]] [data - ["e" error] + ["." error (#+ Error)] ["." number ["." i64]] [collection @@ -19,12 +19,12 @@ ["_eq" equivalence]]]]) (def: (succeed result) - (-> (e.Error Bit) Bit) + (-> (Error Bit) Bit) (case result - (#e.Error _) + (#error.Failure _) #0 - (#e.Success output) + (#error.Success output) output)) (def: #export (binary size) @@ -34,17 +34,17 @@ (if (n/< size idx) (do r.Monad<Random> [byte r.nat] - (exec (e.assume (/.write/8 idx byte output)) + (exec (error.assume (/.write/8 idx byte output)) (recur (inc idx)))) (:: r.Monad<Random> wrap output))))) (def: (bits-io bytes read write value) - (-> Nat (-> Nat /.Binary (e.Error Nat)) (-> Nat Nat /.Binary (e.Error Any)) Nat Bit) + (-> Nat (-> Nat /.Binary (Error Nat)) (-> Nat Nat /.Binary (Error Any)) Nat Bit) (let [binary (/.create 8) bits (n/* 8 bytes) capped-value (|> 1 (i64.left-shift bits) dec (i64.and value))] (succeed - (do e.Monad<Error> + (do error.Monad<Error> [_ (write 0 value binary) output (read 0 binary)] (wrap (n/= capped-value output)))))) @@ -74,13 +74,13 @@ (bits-io 8 /.read/64 /.write/64 value)) (test "Can slice binaries." (let [slice-size (|> to (n/- from) inc) - random-slice (e.assume (/.slice from to random-binary)) + random-slice (error.assume (/.slice from to random-binary)) idxs (list.n/range 0 (dec slice-size)) reader (function (_ binary idx) (/.read/8 idx binary))] (and (n/= slice-size (/.size random-slice)) - (case [(monad.map e.Monad<Error> (reader random-slice) idxs) - (monad.map e.Monad<Error> (|>> (n/+ from) (reader random-binary)) idxs)] - [(#e.Success slice-vals) (#e.Success binary-vals)] + (case [(monad.map error.Monad<Error> (reader random-slice) idxs) + (monad.map error.Monad<Error> (|>> (n/+ from) (reader random-binary)) idxs)] + [(#error.Success slice-vals) (#error.Success binary-vals)] (:: (list.Equivalence<List> number.Equivalence<Nat>) = slice-vals binary-vals) _ |