diff options
Diffstat (limited to 'stdlib/source')
-rw-r--r-- | stdlib/source/lux/control/pipe.lux | 59 |
1 files changed, 26 insertions, 33 deletions
diff --git a/stdlib/source/lux/control/pipe.lux b/stdlib/source/lux/control/pipe.lux index 937935684..6f7721cf6 100644 --- a/stdlib/source/lux/control/pipe.lux +++ b/stdlib/source/lux/control/pipe.lux @@ -1,4 +1,4 @@ -(;module: {#;doc "Composable extensions to the piping macro |> that enhance it with various abilities."} +(;module: {#;doc "Composable extensions to the piping macros (|> and <|) that enhance them with various abilities."} lux (lux (control ["M" monad #+ do Monad] ["p" parser]) @@ -13,12 +13,12 @@ (Syntax (List Code)) (s;tuple (p;many s;any))) -(syntax: #export (_> [tokens (p;at-least +2 s;any)]) +(syntax: #export (new> [tokens (p;at-least +2 s;any)]) {#;doc (doc "Ignores the piped argument, and begins a new pipe." (|> 20 (i.* 3) (i.+ 4) - (_> 0 i.inc)))} + (new> 0 i.inc)))} (case (list;reverse tokens) (^ (list& _ r-body)) (wrap (list (` (|> (~@ (list;reverse r-body)))))) @@ -26,33 +26,26 @@ _ (undefined))) -(syntax: #export (@> [name (p;default "@" s;local-symbol)] - [body body^] - prev) +(syntax: #export (let> lhs [body body^] prev) {#;doc (doc "Gives a name to the piped-argument, within the given expression." - "If given no name, defaults to '@'." (|> 5 - (@> X [(i.+ X X)])) - - (|> 5 - (@> [(i.+ @ @)])))} + (let> X [(i.+ X X)])))} (wrap (list (L/fold (function [next prev] - (` (with-expansions - [(~ (code;symbol ["" name])) (~ prev)] + (` (let [(~ lhs) (~ prev)] (~ next)))) prev body)))) -(syntax: #export (?> [branches (p;many (p;seq body^ body^))] - [?else (p;maybe body^)] - prev) +(syntax: #export (cond> [branches (p;many (p;seq body^ body^))] + [?else (p;maybe body^)] + prev) {#;doc (doc "Branching for pipes." "Both the tests and the bodies are piped-code, and must be given inside a tuple." "If a last else-pipe is not given, the piped-argument will be used instead." (|> 5 - (?> [i.even?] [(i.* 2)] - [i.odd?] [(i.* 3)] - [(_> -1)])))} + (cond> [i.even?] [(i.* 2)] + [i.odd?] [(i.* 3)] + [(new> -1)])))} (with-gensyms [g!temp] (wrap (list (` (with-expansions [(~ g!temp) (~ prev)] @@ -67,26 +60,26 @@ _ g!temp))))))))) -(syntax: #export (!> [test body^] [then body^] prev) +(syntax: #export (loop> [test body^] [then body^] prev) {#;doc (doc "Loops for pipes." "Both the testing and calculating steps are pipes and must be given inside tuples." (|> 1 - (!> [(i.< 10)] - [i.inc])))} + (loop> [(i.< 10)] + [i.inc])))} (with-gensyms [g!temp] (wrap (list (` (loop [(~ g!temp) (~ prev)] (if (|> (~ g!temp) (~@ test)) ((~' recur) (|> (~ g!temp) (~@ then))) (~ g!temp)))))))) -(syntax: #export (%> monad [steps (p;some body^)] prev) +(syntax: #export (do> monad [steps (p;some body^)] prev) {#;doc (doc "Monadic pipes." "Each steps in the monadic computation is a pipe and must be given inside a tuple." (|> 5 - (%> Id/Monad - [(i.* 3)] - [(i.+ 4)] - [i.inc])))} + (do> Monad<Identity> + [(i.* 3)] + [(i.+ 4)] + [i.inc])))} (with-gensyms [g!temp] (case (list;reverse steps) (^ (list& last-step prev-steps)) @@ -101,11 +94,11 @@ _ (wrap (list prev))))) -(syntax: #export (~> [body body^] prev) +(syntax: #export (exec> [body body^] prev) {#;doc (doc "Non-updating pipes." "Will generate piped computations, but their results will not be used in the larger scope." (|> 5 - (~> [int-to-nat %n log!]) + (exec> [int-to-nat %n log!]) (i.* 10)))} (do @ [g!temp (meta;gensym "")] @@ -113,13 +106,13 @@ (exec (|> (~ g!temp) (~@ body)) (~ g!temp)))))))) -(syntax: #export (&> [paths (p;many body^)] prev) +(syntax: #export (tuple> [paths (p;many body^)] prev) {#;doc (doc "Parallel branching for pipes." "Allows to run multiple pipelines for a value and gives you a tuple of the outputs." (|> 5 - (&> [(i.* 10)] - [i.dec (i./ 2)] - [Int/encode])) + (tuple> [(i.* 10)] + [i.dec (i./ 2)] + [Int/encode])) "Will become: [50 2 \"5\"]")} (do @ [g!temp (meta;gensym "")] |