diff options
author | Eduardo Julian | 2019-04-19 19:00:56 -0400 |
---|---|---|
committer | Eduardo Julian | 2019-04-19 19:00:56 -0400 |
commit | 8414d27d33ed37bad685ebca3bbb96a9baef6ea3 (patch) | |
tree | 66ddd2e20a5f374d0c10e6652188cbbc608f527e /stdlib | |
parent | 6d4950f84e4ec1d35dff95c9816d75f360d4a349 (diff) |
Moved the (rose) tree parser under "lux/control/parser/".
Diffstat (limited to '')
-rw-r--r-- | stdlib/source/lux/control/parser/tree.lux (renamed from stdlib/source/lux/data/collection/tree/rose/parser.lux) | 13 | ||||
-rw-r--r-- | stdlib/source/test/lux/control.lux | 3 | ||||
-rw-r--r-- | stdlib/source/test/lux/control/pipe.lux | 193 |
3 files changed, 101 insertions, 108 deletions
diff --git a/stdlib/source/lux/data/collection/tree/rose/parser.lux b/stdlib/source/lux/control/parser/tree.lux index 17cee8931..1c6e21f43 100644 --- a/stdlib/source/lux/data/collection/tree/rose/parser.lux +++ b/stdlib/source/lux/control/parser/tree.lux @@ -1,19 +1,20 @@ (.module: [lux #* [control - ["p" parser] ["ex" exception (#+ exception:)]] [data - ["." error (#+ Error)]]] - [// (#+ Tree) - ["." zipper (#+ Zipper)]]) + ["." error (#+ Error)] + [tree + [rose (#+ Tree) + ["." zipper (#+ Zipper)]]]]] + ["." //]) (type: #export (Parser t a) - (p.Parser (Zipper t) a)) + (//.Parser (Zipper t) a)) (def: #export (run-zipper zipper parser) (All [t a] (-> (Zipper t) (Parser t a) (Error a))) - (case (p.run zipper parser) + (case (//.run zipper parser) (#error.Success [zipper output]) (#error.Success output) diff --git a/stdlib/source/test/lux/control.lux b/stdlib/source/test/lux/control.lux index 61d69459f..ae2455e84 100644 --- a/stdlib/source/test/lux/control.lux +++ b/stdlib/source/test/lux/control.lux @@ -57,8 +57,7 @@ /exception.test /io.test /parser.test - (<| (_.context "/pipe") - /pipe.test) + /pipe.test /reader.test /region.test /state.test diff --git a/stdlib/source/test/lux/control/pipe.lux b/stdlib/source/test/lux/control/pipe.lux index 6f7b65a53..9b4110a39 100644 --- a/stdlib/source/test/lux/control/pipe.lux +++ b/stdlib/source/test/lux/control/pipe.lux @@ -5,111 +5,104 @@ [monad (#+ do)]] [data ["." identity] - ["." text ("#;." equivalence) + ["." name] + ["." text ("#@." equivalence) format]] [math ["r" random]]] {1 - /}) + ["." / #*]}) (def: #export test Test - (do r.monad - [sample r.nat] - ($_ _.and - (do @ - [another r.nat] - (_.test "Can dismiss previous pipeline results and begin a new one." - (n/= (inc another) - (|> sample - (n/* 3) - (n/+ 4) - (new> another [inc]))))) - - (_.test "Let-binding" - (n/= (n/+ sample sample) - (|> sample - (let> x [(n/+ x x)])))) - - (_.test "'Conditional' branching." - (text;= (cond (n/= 0 sample) "zero" - (n/even? sample) "even" + (<| (_.context (name.module (name-of /._))) + (do r.monad + [sample r.nat] + ($_ _.and + (do @ + [another r.nat] + (_.test "Can dismiss previous pipeline results and begin a new one." + (n/= (inc another) + (|> sample + (n/* 3) + (n/+ 4) + (new> another [inc]))))) + (_.test "Let-binding" + (n/= (n/+ sample sample) + (|> sample + (let> x [(n/+ x x)])))) + (_.test "'Conditional' branching." + (text@= (cond (n/= 0 sample) "zero" + (n/even? sample) "even" + "odd") + (|> sample + (cond> [(n/= 0)] [(new> "zero" [])] + [n/even?] [(new> "even" [])] + [(new> "odd" [])])))) + (_.test "'If' branching." + (text@= (if (n/even? sample) + "even" "odd") - (|> sample - (cond> [(n/= 0)] [(new> "zero" [])] - [n/even?] [(new> "even" [])] - [(new> "odd" [])])))) - - (_.test "'If' branching." - (text;= (if (n/even? sample) - "even" - "odd") - (|> sample - (if> [n/even?] - [(new> "even" [])] - [(new> "odd" [])])))) - - (_.test "'When' branching." - (n/= (if (n/even? sample) - (n/* 2 sample) - sample) - (|> sample - (when> [n/even?] - [(n/* 2)])))) - - (_.test "Can loop." - (n/= (n/* 10 sample) - (|> sample - (loop> [(n/= (n/* 10 sample)) not] - [(n/+ sample)])))) - - (_.test "Monads." - (n/= (inc (n/+ 4 (n/* 3 sample))) - (|> sample - (do> identity.monad - [(n/* 3)] - [(n/+ 4)] - [inc])))) - - (_.test "Execution." - (n/= (n/* 10 sample) - (|> sample - (exec> [%n (format "sample = ") log!]) - (n/* 10)))) - - (_.test "Tuple." - (let [[left middle right] (|> sample - (tuple> [inc] - [dec] - [%n]))] - (and (n/= (inc sample) left) - (n/= (dec sample) middle) - (text;= (%n sample) right)))) - - (_.test "Pattern-matching." - (text;= (case (n/% 10 sample) - 0 "zero" - 1 "one" - 2 "two" - 3 "three" - 4 "four" - 5 "five" - 6 "six" - 7 "seven" - 8 "eight" - 9 "nine" - _ "???") - (|> sample - (n/% 10) - (case> 0 "zero" - 1 "one" - 2 "two" - 3 "three" - 4 "four" - 5 "five" - 6 "six" - 7 "seven" - 8 "eight" - 9 "nine" - _ "???")))) - ))) + (|> sample + (if> [n/even?] + [(new> "even" [])] + [(new> "odd" [])])))) + (_.test "'When' branching." + (n/= (if (n/even? sample) + (n/* 2 sample) + sample) + (|> sample + (when> [n/even?] + [(n/* 2)])))) + (_.test "Can loop." + (n/= (n/* 10 sample) + (|> sample + (loop> [(n/= (n/* 10 sample)) not] + [(n/+ sample)])))) + (_.test "Monads." + (n/= (inc (n/+ 4 (n/* 3 sample))) + (|> sample + (do> identity.monad + [(n/* 3)] + [(n/+ 4)] + [inc])))) + (_.test "Execution." + (n/= (n/* 10 sample) + (|> sample + (exec> [%n (format "sample = ") log!]) + (n/* 10)))) + (_.test "Tuple." + (let [[left middle right] (|> sample + (tuple> [inc] + [dec] + [%n]))] + (and (n/= (inc sample) left) + (n/= (dec sample) middle) + (text@= (%n sample) right)))) + (_.test "Pattern-matching." + (text@= (case (n/% 10 sample) + 0 "zero" + 1 "one" + 2 "two" + 3 "three" + 4 "four" + 5 "five" + 6 "six" + 7 "seven" + 8 "eight" + 9 "nine" + _ "???") + (|> sample + (n/% 10) + (case> 0 "zero" + 1 "one" + 2 "two" + 3 "three" + 4 "four" + 5 "five" + 6 "six" + 7 "seven" + 8 "eight" + 9 "nine" + _ "???")))) + )))) |