aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChristophe Grand <christophe@cgrand.net>2009-02-23 09:31:35 +0000
committerChristophe Grand <christophe@cgrand.net>2009-02-23 09:31:35 +0000
commit5c68bc277d17e3dcdfef7ea6e79402ec7a190044 (patch)
tree157e4c2aa56f2f75115330dcb59aaf0e25411f70
parent631d0c88047bf4f035abb69fe00a493189ec6459 (diff)
Added agent-utils
-rw-r--r--src/clojure/contrib/agent_utils.clj30
1 files changed, 30 insertions, 0 deletions
diff --git a/src/clojure/contrib/agent_utils.clj b/src/clojure/contrib/agent_utils.clj
new file mode 100644
index 00000000..ef377d25
--- /dev/null
+++ b/src/clojure/contrib/agent_utils.clj
@@ -0,0 +1,30 @@
+; Copyright (c) Christophe Grand, November 2008. All rights reserved.
+
+; The use and distribution terms for this software are covered by the
+; Eclipse Public License 1.0 (http://opensource.org/licenses/eclipse-1.0.php)
+; which can be found in the file epl-v10.html at the root of this
+; distribution.
+; By using this software in any fashion, you are agreeing to be bound by
+; the terms of this license.
+; You must not remove this notice, or any other, from this software.
+
+;; misc agent utilities
+
+;; note to other contrib members: feel free to add to this lib
+
+(ns clojure.contrib.agent-utils)
+
+(defmacro capture-and-send
+ "Capture the current value of the specified vars and rebind
+ them on the agent thread before executing the action.
+
+ Example:
+ (capture-and-send [*out*] a f b c)"
+
+ [vars agent action & args]
+ (let [locals (map #(gensym (name %)) vars)]
+ `(let [~@(interleave locals vars)
+ action# (fn [& args#]
+ (binding [~@(interleave vars locals)]
+ (apply ~action args#)))]
+ (send ~agent action# ~@args))))