Merge branch 'f/is-coll' of https://github.com/theanalyst/hy into theanalyst-f/is-coll
This commit is contained in:
commit
14a791f37b
@ -6,6 +6,29 @@ Hy Core
|
|||||||
Core Functions
|
Core Functions
|
||||||
===============
|
===============
|
||||||
|
|
||||||
|
.. _is-coll-fn:
|
||||||
|
|
||||||
|
coll?
|
||||||
|
----
|
||||||
|
|
||||||
|
.. versionadded:: 0.9.13
|
||||||
|
|
||||||
|
Usage: ``(coll? x)``
|
||||||
|
|
||||||
|
Returns true if argument is iterable and not a string.
|
||||||
|
|
||||||
|
.. code-block:: clojure
|
||||||
|
|
||||||
|
=> (coll? [1 2 3 4])
|
||||||
|
True
|
||||||
|
|
||||||
|
=> (coll? {"a" 1 "b" 2})
|
||||||
|
True
|
||||||
|
|
||||||
|
=> (coll? "abc")
|
||||||
|
False
|
||||||
|
|
||||||
|
|
||||||
.. _dec-fn:
|
.. _dec-fn:
|
||||||
|
|
||||||
dec
|
dec
|
||||||
|
@ -30,6 +30,10 @@
|
|||||||
(if (not (numeric? x))
|
(if (not (numeric? x))
|
||||||
(raise (TypeError (.format "{0!r} is not a number" x)))))
|
(raise (TypeError (.format "{0!r} is not a number" x)))))
|
||||||
|
|
||||||
|
(defn coll? [coll]
|
||||||
|
"Checks whether item is a collection"
|
||||||
|
(and (iterable? coll) (not (string? coll))))
|
||||||
|
|
||||||
(defn cycle [coll]
|
(defn cycle [coll]
|
||||||
"Yield an infinite repetition of the items in coll"
|
"Yield an infinite repetition of the items in coll"
|
||||||
(setv seen [])
|
(setv seen [])
|
||||||
@ -112,7 +116,7 @@
|
|||||||
|
|
||||||
(defn flatten [coll]
|
(defn flatten [coll]
|
||||||
"Return a single flat list expanding all members of coll"
|
"Return a single flat list expanding all members of coll"
|
||||||
(if (and (iterable? coll) (not (string? coll)))
|
(if (coll? coll)
|
||||||
(_flatten coll [])
|
(_flatten coll [])
|
||||||
(raise (TypeError (.format "{0!r} is not a collection" coll)))))
|
(raise (TypeError (.format "{0!r} is not a collection" coll)))))
|
||||||
|
|
||||||
@ -298,8 +302,8 @@
|
|||||||
(_numeric_check n)
|
(_numeric_check n)
|
||||||
(= n 0))
|
(= n 0))
|
||||||
|
|
||||||
(def *exports* '[calling-module-name cycle dec distinct disassemble drop
|
(def *exports* '[calling-module-name coll? cycle dec distinct disassemble
|
||||||
drop-while empty? even? filter flatten float? gensym
|
drop drop-while empty? even? filter flatten float? gensym
|
||||||
inc instance? integer integer? iterable? iterate
|
inc instance? integer integer? iterable? iterate
|
||||||
iterator? macroexpand macroexpand-1 neg? nil? none?
|
iterator? macroexpand macroexpand-1 neg? nil? none?
|
||||||
nth numeric? odd? pos? remove repeat repeatedly second
|
nth numeric? odd? pos? remove repeat repeatedly second
|
||||||
|
@ -30,6 +30,14 @@
|
|||||||
(defn assert-equal [x y]
|
(defn assert-equal [x y]
|
||||||
(assert (= x y)))
|
(assert (= x y)))
|
||||||
|
|
||||||
|
(defn test-coll? []
|
||||||
|
"NATIVE: testing coll?"
|
||||||
|
(assert-true (coll? [1 2 3]))
|
||||||
|
(assert-true (coll? {"a" 1 "b" 2}))
|
||||||
|
(assert-true (coll? (range 10)))
|
||||||
|
(assert-false (coll? "abc"))
|
||||||
|
(assert-false (coll? 1)))
|
||||||
|
|
||||||
(defn test-cycle []
|
(defn test-cycle []
|
||||||
"NATIVE: testing cycle"
|
"NATIVE: testing cycle"
|
||||||
(assert-equal (list (cycle [])) [])
|
(assert-equal (list (cycle [])) [])
|
||||||
|
Loading…
x
Reference in New Issue
Block a user