Implement ALL for strings (#333)
This commit is contained in:
parent
67e8680602
commit
9a615ff22c
2 changed files with 16 additions and 0 deletions
|
|
@ -95,6 +95,13 @@
|
||||||
(comp (map next-fn)
|
(comp (map next-fn)
|
||||||
(filter not-NONE?))
|
(filter not-NONE?))
|
||||||
structure))
|
structure))
|
||||||
|
|
||||||
|
#?(:clj String :cljs string)
|
||||||
|
(all-transform [structure next-fn]
|
||||||
|
(apply str (into []
|
||||||
|
(comp (map next-fn)
|
||||||
|
(filter not-NONE?))
|
||||||
|
structure)))
|
||||||
|
|
||||||
#?(:clj clojure.lang.PersistentHashSet :cljs cljs.core/PersistentHashSet)
|
#?(:clj clojure.lang.PersistentHashSet :cljs cljs.core/PersistentHashSet)
|
||||||
(all-transform [structure next-fn]
|
(all-transform [structure next-fn]
|
||||||
|
|
|
||||||
|
|
@ -1440,6 +1440,15 @@
|
||||||
(is (= "abq" (setval s/LAST "q" "abc")))
|
(is (= "abq" (setval s/LAST "q" "abc")))
|
||||||
)
|
)
|
||||||
|
|
||||||
|
(defn whitespace? [char]
|
||||||
|
(re-matches #"\s" (str char)))
|
||||||
|
|
||||||
|
(deftest string-transform-test
|
||||||
|
(is (= "123" (transform s/ALL identity "123")))
|
||||||
|
(is (= "123" (transform [s/ALL whitespace?] s/NONE "1 2 3")))
|
||||||
|
#?(:clj (is (= "123" (setval [s/ALL #(Character/isWhitespace %)] s/NONE "1 2 3"))))
|
||||||
|
#?(:clj (is (= "123" (transform [(s/filterer #(Character/isWhitespace %))] s/NONE "1 2 3")))))
|
||||||
|
|
||||||
(deftest regex-navigation-test
|
(deftest regex-navigation-test
|
||||||
;; also test regexes as implicit navs
|
;; also test regexes as implicit navs
|
||||||
(is (= (select #"t" "test") ["t" "t"]))
|
(is (= (select #"t" "test") ["t" "t"]))
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue