add partition form to core

the 2 argument version of Clojure's partition.

pre-expand ->> macro in partition

Docstring for partition.

add test-partition

Document partition.
This commit is contained in:
gilch 2015-08-05 14:59:05 -06:00
parent 79de62d2b3
commit bb00e709ee
3 changed files with 39 additions and 9 deletions

View File

@ -674,6 +674,20 @@ Returns ``True`` if *x* is odd. Raises ``TypeError`` if
.. _pos?-fn: .. _pos?-fn:
partition
---------
Usage: ``(partition n coll)``
Chunks coll into tuples of length n. The remainder, if any, is not included.
.. code-block:: hy
=> (list (partition 3 (range 10)))
[(0, 1, 2), (3, 4, 5), (6, 7, 8)]
.. _partition-fn:
pos? pos?
---- ----

View File

@ -314,6 +314,10 @@
(_numeric-check n) (_numeric-check n)
(= (% n 2) 1)) (= (% n 2) 1))
(defn partition [n coll]
"Chunks coll into tuples of length n. The remainder, if any, is not included."
(apply zip (* n (, (iter coll)))))
(defn pos? [n] (defn pos? [n]
"Return true if n is > 0" "Return true if n is > 0"
(_numeric_check n) (_numeric_check n)
@ -423,12 +427,12 @@
(hyify (. value __name__)) (hyify (. value __name__))
(catch [] (string value)))))) (catch [] (string value))))))
(def *exports* '[butlast calling-module-name coll? cons cons? cycle (def *exports*
dec distinct disassemble drop drop-last drop-while empty? even? '[butlast calling-module-name coll? cons cons? cycle dec distinct disassemble
every? first filter filterfalse flatten float? fraction gensym drop drop-last drop-while empty? even? every? first filter filterfalse
identity inc input instance? integer integer? integer-char? flatten float? fraction gensym identity inc input instance? integer integer?
interleave interpose iterable? iterate iterator? keyword integer-char? interleave interpose iterable? iterate iterator? keyword
keyword? last list* macroexpand macroexpand-1 map merge-with keyword? last list* macroexpand macroexpand-1 map merge-with name neg? nil?
name neg? nil? none? nth numeric? odd? pos? range read read-str none? nth numeric? odd? partition pos? range read read-str remove repeat
remove repeat repeatedly rest reduce second some string string? repeatedly rest reduce second some string string? symbol? take take-nth
symbol? take take-nth take-while zero? zip zip_longest zipwith]) take-while zero? zip zip_longest zipwith])

View File

@ -470,6 +470,18 @@
(try (do (odd? None) (assert False)) (try (do (odd? None) (assert False))
(catch [e [TypeError]] (assert (in "not a number" (str e)))))) (catch [e [TypeError]] (assert (in "not a number" (str e))))))
(defn test-partition []
"NATIVE: testing the partition function"
(setv ten (range 10))
(assert-equal (list (partition 3 ten))
[(, 0 1 2) (, 3 4 5) (, 6 7 8)])
(assert-equal (list (partition 2 ten))
[(, 0 1) (, 2 3) (, 4 5) (, 6 7) (, 8 9)])
(assert-equal (list (partition 1 ten))
[(, 0) (, 1) (, 2) (, 3) (, 4) (, 5) (, 6) (, 7) (, 8) (, 9)])
(assert-equal (list (partition 0 ten)) [])
(assert-equal (list (partition -1 ten)) []))
(defn test-pos [] (defn test-pos []
"NATIVE: testing the pos? function" "NATIVE: testing the pos? function"
(assert-true (pos? 2)) (assert-true (pos? 2))