Fork me on GitHub
#mount
<
2018-10-24
>
ro600:10:12

Is it possible to define two states in the same namespace and have one refer to the other? Right now I'm getting an error that seems like one state isn't started when I try to use it from the other.

tolitius10:10:43

@robert.mather.rmm yes, it is possible. can you share an example? also how do you start it: (mount/start) or (mount/start .. only one state)?

ro620:10:40

I'm using (mount/start). I think I have it figured out. Part of my issue was not understanding that I needed to make that call before any state was used. I guess in my head using a state would trigger lazy init of the transitive subtree from that node, but (mount/start) is required before anything gets used. Just a misconception on my part. The other challenge is that I'm using Datomic Ions and trying to organize an init sequence that works the same way as on local, even though there's no 'main' called up there or repl to start from, it's ultimately just a callback so it's less clear how/when your app "starts" at a JVM level.

ro620:10:40

I'm using (mount/start). I think I have it figured out. Part of my issue was not understanding that I needed to make that call before any state was used. I guess in my head using a state would trigger lazy init of the transitive subtree from that node, but (mount/start) is required before anything gets used. Just a misconception on my part. The other challenge is that I'm using Datomic Ions and trying to organize an init sequence that works the same way as on local, even though there's no 'main' called up there or repl to start from, it's ultimately just a callback so it's less clear how/when your app "starts" at a JVM level.

tolitius21:10:19

&gt; in my head using a state would trigger lazy init of the transitive subtree it would if you are in :cljc mode and refer to state as @foo: https://github.com/tolitius/mount#cljc-mode &gt; trying to organize an init sequence that works the same way as on local from the mount perspective it will start in the order of: 1. component dependency 2. namespace compilation (i.e. if a and b are independent states that live in A and B namespaces, they would start in the order that compiler compiles A and B)

richiardiandrea22:10:43

there seem to be an issue in cljs when a state :start throws, I thought I got it covered but it still happens

richiardiandrea22:10:52

I have something like :start (s/assert* :event-store.db/config (read-config))

richiardiandrea22:10:21

when this throws, I see

richiardiandrea22:10:57

store.db> @config/map
store.db> 

richiardiandrea22:10:05

which is not very helpful 😄

richiardiandrea22:10:23

if this the state becomes a function call, then I see the exception