This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2019-08-06
Channels
- # aleph (1)
- # beginners (180)
- # calva (16)
- # cider (29)
- # clj-kondo (47)
- # cljsrn (5)
- # clojure (40)
- # clojure-dev (39)
- # clojure-europe (1)
- # clojure-italy (25)
- # clojure-nl (9)
- # clojure-russia (1)
- # clojure-spec (8)
- # clojure-uk (83)
- # clojurescript (54)
- # core-async (2)
- # datomic (20)
- # defnpodcast (7)
- # figwheel (6)
- # fulcro (6)
- # jobs (5)
- # joker (4)
- # kaocha (4)
- # luminus (4)
- # off-topic (8)
- # onyx (6)
- # pathom (14)
- # re-frame (28)
- # reagent (30)
- # remote-jobs (2)
- # shadow-cljs (88)
- # spacemacs (2)
- # specter (17)
- # sql (25)
- # tools-deps (78)
- # xtdb (1)
- # yada (2)
I think I'm confused.
filterer
navigates to a sequence of all "locations" in the sequence matching the predicate
with index 0 being the first location, index 1 being the second, and so on
transformations to the sequence navigated to by filterer
can only affect those locations
increasing the size of the sequence just causes indexes past the last location to be ignored
there's a special case for when you reduce the size of the sequence to set the removed locations to NONE
Hmmmm, OK. So, there is no 'obvious / out of the box' way to insert? Using a combo of index-vals
and before-index
works fine, is that the 'right way' to do this?
zipper navigators are good for this use case
com.rpl.specter.zipper
user=> (setval [z/VECTOR-ZIP (z/find-first #(= "b" %)) z/INNER-LEFT] [77] ["a" "b" "c"])
["a" 77 "b" "c"]
Presumably that is much more efficient as well?
unclear
zippers do have overhead
the com.rpl.specter.zipper
namespace is not totally fleshed out, so there are other navigators that could be added to make it more efficient
such as the zipper equivalent of before-index
instead of doing INNER-LEFT