You could simplify your fix code a small bit by using go-loop and when, like this:
(go-loop [] (let [[v ch] (alts! [dump-chan (om/get-state owner :exit-chan)])] (when (= ch dump-chan) (.log js/console "dumping state:") (.log js/console (pr-str (om/get-state owner))) (recur)))) This won't work in your code because my-form's parent owns dump-chan, but if a component owns the channel, an alternative approach is to simply close dump-chan in IWillUnmount and change your go block to something like this: (go-loop [] (when-let [v (<! dump-chan)] (.log js/console "dumping state:") (.log js/console (pr-str (om/get-state owner))) (recur))) In my own code, I've abstracted my go blocks into om-tools mixins that handle the killing of go blocks. I'm not sure why the second problem happens. As a general rule, I never create new resources in render (IMO render should be pure functional: app state and local state in -> new dom nodes out; but as the child stores the channel between calls to parents render, this breaks that "rule") and I've never had the issue. Since base isn't being re-rendered in this case, I'm not sure why this would be a problem here. On 24 July 2014 02:35, Sean Corfield <s...@corfield.org> wrote: > You'll want to read this thread: > https://groups.google.com/forum/#!topic/clojurescript/DHJvcGey8Sc > > In particular: > > "So if you have code that's like this, those components will want to clean > up after themselves in IWillUnmount." > > That should address your first problem? > > I'm not sure what to suggest right now about the second problem. > > Sean > > > On Jul 23, 2014, at 4:19 PM, Alexander Hudek <alexan...@hudek.org> wrote: > > I've encountered two subtle but serious problems using om with core.async. > > The first one is illustrated by this code: > > https://github.com/akhudek/om-async-error > > First, one obvious solution here is to move the dump-chan inside the form > state. > However, it's written this way to illustrate the error which originally > arose in a > dialog component that took both an action channel that receives button > presses > and a dialog content component. It exposed the action channel in this way > in > order to be flexible. > > I believe the cause of this error is that when you toggle the form in the > demo > to off, it unmounts the component. However, the go-block is still active > and > listening to the channel. When you toggle the form back on, a new component > is created and mounted. Now you have two components listening on the same > channel! > > The ideal solution might be to find a way to end the go block when the > component > unmounts. This is easy to do on a case by case basis, but not easy to do > in a > completely generic fashion. Here is one solution: > > > https://github.com/akhudek/om-async-error/blob/alts-fix/src/om_async_error/core.cljs > > The second problem is easy to fix, however, I don't understand why it > happens. > > https://github.com/akhudek/om-async-error/tree/chan-opts-bug > > Instead of initializing the dump channel in the base components state, we > initialize > it when creating the form component. As soon as you start typing into the > form > the channel breaks. It was suggested on irc that this might be because of > a > re-render of base would create a new channel, but the form component will > not > be re-mounted because it's already mounted. However, putting in some debug > code shows that there is no re-render of the base component occurring > between > when the channel works and when it doesn't. > > I'm posting this here mostly to warn people to be wary of these > situations. Of > course, if you have any suggestions or explanations for these I'd love to > hear them. > > Alex > > > > -- You received this message because you are subscribed to the Google Groups "Clojure" group. To post to this group, send email to clojure@googlegroups.com Note that posts from new members are moderated - please be patient with your first post. To unsubscribe from this group, send email to clojure+unsubscr...@googlegroups.com For more options, visit this group at http://groups.google.com/group/clojure?hl=en --- You received this message because you are subscribed to the Google Groups "Clojure" group. To unsubscribe from this group and stop receiving emails from it, send an email to clojure+unsubscr...@googlegroups.com. For more options, visit https://groups.google.com/d/optout.