mirror of
https://github.com/janet-lang/janet
synced 2024-11-05 08:16:16 +00:00
add catseq
This commit is contained in:
parent
d9ed7a77f8
commit
ccd874fe4e
@ -611,6 +611,13 @@
|
|||||||
(def $accum (gensym))
|
(def $accum (gensym))
|
||||||
~(do (def ,$accum @[]) (loop ,head (,array/push ,$accum (do ,;body))) ,$accum))
|
~(do (def ,$accum @[]) (loop ,head (,array/push ,$accum (do ,;body))) ,$accum))
|
||||||
|
|
||||||
|
(defmacro catseq
|
||||||
|
``Similar to `loop`, but concatenates each element from the loop body into an array and returns that.
|
||||||
|
See `loop` for details.``
|
||||||
|
[head & body]
|
||||||
|
(def $accum (gensym))
|
||||||
|
~(do (def ,$accum @[]) (loop ,head (,array/concat ,$accum (do ,;body))) ,$accum))
|
||||||
|
|
||||||
(defmacro tabseq
|
(defmacro tabseq
|
||||||
``Similar to `loop`, but accumulates key value pairs into a table.
|
``Similar to `loop`, but accumulates key value pairs into a table.
|
||||||
See `loop` for details.``
|
See `loop` for details.``
|
||||||
|
@ -252,6 +252,9 @@
|
|||||||
(def xs (apply tuple (seq [x :down [8 -2] :when (even? x)] (tuple (/ x 2) x))))
|
(def xs (apply tuple (seq [x :down [8 -2] :when (even? x)] (tuple (/ x 2) x))))
|
||||||
(assert (= xs '((4 8) (3 6) (2 4) (1 2) (0 0))) "seq macro 2")
|
(assert (= xs '((4 8) (3 6) (2 4) (1 2) (0 0))) "seq macro 2")
|
||||||
|
|
||||||
|
(def xs (catseq [x :range [0 3]] [x x]))
|
||||||
|
(assert (deep= xs @[0 0 1 1 2 2]) "catseq")
|
||||||
|
|
||||||
# :range-to and :down-to
|
# :range-to and :down-to
|
||||||
(assert (deep= (seq [x :range-to [0 10]] x) (seq [x :range [0 11]] x)) "loop :range-to")
|
(assert (deep= (seq [x :range-to [0 10]] x) (seq [x :range [0 11]] x)) "loop :range-to")
|
||||||
(assert (deep= (seq [x :down-to [10 0]] x) (seq [x :down [10 -1]] x)) "loop :down-to")
|
(assert (deep= (seq [x :down-to [10 0]] x) (seq [x :down [10 -1]] x)) "loop :down-to")
|
||||||
|
Loading…
Reference in New Issue
Block a user