This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2019-09-30
Channels
- # aleph (1)
- # announcements (7)
- # aws (4)
- # beginners (52)
- # calva (11)
- # cider (20)
- # clj-kondo (36)
- # clojure (53)
- # clojure-austin (1)
- # clojure-brasil (1)
- # clojure-conj (1)
- # clojure-europe (27)
- # clojure-italy (17)
- # clojure-nl (11)
- # clojure-norway (2)
- # clojure-spec (41)
- # clojure-uk (39)
- # clojuredesign-podcast (2)
- # clojurescript (22)
- # clojutre (14)
- # community-development (24)
- # cursive (6)
- # data-science (1)
- # datomic (38)
- # duct (3)
- # figwheel-main (8)
- # fulcro (34)
- # funcool (8)
- # jackdaw (3)
- # jobs (2)
- # off-topic (84)
- # pathom (3)
- # re-frame (4)
- # shadow-cljs (8)
- # tools-deps (5)
- # vim (7)
It depends. If the function can be viewed as a module and it is used in many places — you can make it just like the handler example, i.e the multimethod that takes the dependencies and returns a function that closes over these deps.
After init
the system will contain this function and you can provide it as a dependency where needed.
At least you should be able to do something similar to this.
If the function is used in one place, I think there's no need to define it as a module.
@jjttjj: No, it’s like @jahson says. You should never typically access the system directly; except calling halt to shut it down, or in a dev/debugging/testing context. The whole idea is that components are injected with precisely the dependencies they need. Those dependencies include other instantiated components. I’d avoid calling these things modules though, they’re integrant components. Modules are something very different.