why not ref and dosync?


On Thu, May 16, 2013 at 2:45 PM, Phillip Lord
<phillip.l...@newcastle.ac.uk>wrote:

> Jim <jimpil1...@gmail.com> writes:
>
> > On 16/05/13 11:33, Phillip Lord wrote:
> >> And if it is okay to use set!
> >> on*warn-on-reflection*, why is it not okay to allow me, as the library
> >> developer, to define similar properties for my library which work in a
> >> similar way.
> >
> > well, nothing stops you from providing bindings at the main entry point
> of
> > your library, much in the same way that Clojure does...then consumers
> can use
> > set! as you expect. That said, I wouldn't go down that road simply
> because it
> > gives that 'global-state' smell...
>
>
> I don't have a main entry point. And, yes, I want global-state for
> exactly the same reason that Clojure does. I have a process that
> produces logging output, and I want the user to be able to define
> where that output goes. Basically, the same as doing:
>
> (set! *out* some-sensible-value)
>
> but different because I also want to be able to choose between a
> GUI output, and text.
>
> So, I guess, my two options are:
>
>
> (def
>   ^{:dynamic true}
>   *can-we-change-it* (atom "John"))
>
> (println @*can-we-change-it*)
>
> (reset! *can-we-change-it* "Paul")
>
> (println @*can-we-change-it*)
>
> (binding [*can-we-change-it*
>           (atom "George")]
>   (println @*can-we-change-it*))
>
>
> (println @*can-we-change-it*)
>
>
>
> (def
>   ^{:dynamic true}
>   *can-we-change-this-one* "Mick")
>
> (println *can-we-change-this-one*)
>
> (alter-var-root #'*can-we-change-this-one*
>                 (fn [x] "Keith"))
>
> (println *can-we-change-this-one*)
>
> (binding [*can-we-change-this-one*
>           "Bill"]
>   (println *can-we-change-this-one*))
>
> (println *can-we-change-this-one*)
>
>
>
> Of which, I think, the former is the best option, although it's going to
> break my existing code which uses binding forms.
>
> Phil
>
> --
> --
> 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/groups/opt_out.
>
>
>

-- 
-- 
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/groups/opt_out.


Reply via email to