While Clojure's moving towards a 1.0 release, interest in the language has reached other platforms as well.
Clojure-contrib now contains two implementations of Clojure on different platforms. A large part of Clojure's written in Clojure, so the implementatations can share a lot of the code:
- ClojureCLR is a port of Clojure to .NET
Clojure users are experimenting with JVM libraries and frameworks. Clojure focuses on concurrency in one JVM and doesn't have special support for distributed work. Terracotta is a technology that allows to tie JVMs, on the same machine or distributed, together. Paul Stadig has been experimenting with getting Clojure to use Terracotta's features. (A similar project was attempted with JRuby). A recent progress report is promising:
So it looks like three of the biggest issues I had to work around in getting Clojure to work with Terracotta, will be resolved on the Terracotta side. This means that the Terracotta Integration Module that I wrote will pretty much boil down to a configuration file.
Finally, a new Clojure release is available with these changes:
Incorporates all the recent additions - fully lazy seqs, :let option for doseq/for, letfn for mutually recursive local fns, synchronous watches, multi-arg set/union/difference/intersection, counted?, per- defmulti hierarchies, #_ ignore form reader macro, future-calls, future and pcalls/pvalues, defmulti docstrings and metadata, methods/ prefers for multimethod reflection, uniform metadata handling for atoms/refs/agents/vars/namespaces, condp, release-pending-sends, AOT tweaks to support applets and Android, etc. All this in addition to many fixes and enhancements.