Add a keyword? function to detect keywords.
Thanks to algernon for the function body; huge improvement.
This commit is contained in:
parent
aefea557cb
commit
3a9cf486db
@ -44,6 +44,11 @@
|
|||||||
"Check whether c can be used as a cons object"
|
"Check whether c can be used as a cons object"
|
||||||
(instance? HyCons c))
|
(instance? HyCons c))
|
||||||
|
|
||||||
|
(defn keyword? [k]
|
||||||
|
"Check whether k is a keyword"
|
||||||
|
(and (instance? (type :foo) k)
|
||||||
|
(.startswith k (get :foo 0))))
|
||||||
|
|
||||||
(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 [])
|
||||||
@ -354,7 +359,7 @@
|
|||||||
(def *exports* '[calling-module-name coll? cons cons? cycle dec distinct
|
(def *exports* '[calling-module-name coll? cons cons? cycle dec distinct
|
||||||
disassemble drop drop-while empty? even? every? first filter
|
disassemble drop drop-while empty? even? every? first filter
|
||||||
flatten float? gensym identity inc instance? integer
|
flatten float? gensym identity inc instance? integer
|
||||||
integer? integer-char? iterable? iterate iterator?
|
integer? integer-char? iterable? iterate iterator? keyword?
|
||||||
list* macroexpand macroexpand-1 neg? nil? none? nth
|
list* macroexpand macroexpand-1 neg? nil? none? nth
|
||||||
numeric? odd? pos? remove repeat repeatedly rest second
|
numeric? odd? pos? remove repeat repeatedly rest second
|
||||||
some string string? take take-nth take-while zero? zipwith])
|
some string string? take take-nth take-while zero? zipwith])
|
||||||
|
@ -478,3 +478,14 @@
|
|||||||
(assert-equal (list res) [4 4 4])
|
(assert-equal (list res) [4 4 4])
|
||||||
(setv res (zipwith operator.sub [3 7 9] [1 2 4]))
|
(setv res (zipwith operator.sub [3 7 9] [1 2 4]))
|
||||||
(assert-equal (list res) [2 5 5]))
|
(assert-equal (list res) [2 5 5]))
|
||||||
|
|
||||||
|
(defn test-is-keyword []
|
||||||
|
"NATIVE: testing the keyword? function"
|
||||||
|
(assert (keyword? ':bar))
|
||||||
|
(assert (keyword? ':baz))
|
||||||
|
(assert (keyword? :bar))
|
||||||
|
(assert (keyword? :baz))
|
||||||
|
(assert (not (keyword? "foo")))
|
||||||
|
(assert (not (keyword? ":foo")))
|
||||||
|
(assert (not (keyword? 1)))
|
||||||
|
(assert (not (keyword? nil))))
|
||||||
|
Loading…
x
Reference in New Issue
Block a user