Javascript Language Extensions for Clojurescript
- bugfix for midje forms (thanks to natedev)
- bugfix for sequence behaviour (thanks to deliminator)
- purnam has been repacked and all subprojects have been merged into a single repo (much easier to maintain)
- travis-ci tests are fixed for karma 0.12 (finally)
In your project file, add
[im.chit/purnam "0.5.2"]
or for individual libraries:
[im.chit/purnam.common "0.5.2"]
[im.chit/purnam.native "0.5.2"]
[im.chit/purnam.core "0.5.2"]
[im.chit/purnam.test "0.5.2"]
A Google Group for purnam has been setup here. Comments, Questions, Feedback, Contributions are most definitely welcome!
In its earliest incarnation, purnam
was more or less a set of scattered ideas about how to play nicely with existing javascript libraries using clojurescript. What initially started off as experimental language extensions for working with clojurescript and angularjs has matured into a synergistic set of libraries and workflows for crafting clojurescript applications (now decoupled from angularjs
)
The original purnam library was way too big. It has now been broken up into more reasonably sized pieces. The core functionality of purnam have been seperated into independent libraries so that developers can have a choice about including one or all of them inside their projects.
purnam.core
provides macros for better and more intuitive javascript interop.purnam.test
provides macros for testing with the karma test runner.purnam.native
provides utility function and clojure protocol support for native arrays and objects.
Support for angular.js was a major reason that purnam
became a popular choice for frontend development. From a functional point of view however, the language extensions could be completely decoupled from angularjs support and so purnam.angular
has been renamed to gyr.
As the purnam
style syntax could be extended to meteorjs, reactjs as well as the thousands of javascript libaries out there, decoupling the code-walking component purnam.common
from the main project took the most of the time in the redesign. Hopefully, this library will enable other developers to write their own purnam-flavored macros.
// javascript
function square(x){
return {value: x.value * x.value};
}
;; clojurescript + purnam
(def.n square [x]
(obj :value (* x.value x.value)))
;; or
(def*n square [x]
{:value (* x.value x.value)})
;; clojurescript
(defn square [x]
(let [o (js-obj)
v (aget x "value")]
(aset o "value" (* v v)))
o)
// javascript
var user = {id: 0
account: {username: "user"
password: "pass"}}
;; clojurescript + purnam
(def user (obj :id 0
:account {:username "user"
:password "pass"}))
;; or
(def* user {:id 0
:account {:username "user"
:password "pass"})})
;; clojurescript
(def user
(let [acc (js-obj)
user (js-obj)]
(aset acc "username" "user")
(aset acc "password" "pass")
(aset user "account" acc)
(aset user "id" 0)
user))
;; clojurescript using clj->js (slower)
(def user
(clj->js {:id 0
:account {:username "user"
:password "pass"})})
(seq (js* "[1, 2, 3, 4]"))
=> '(1 2 3 4)
(seq (js* "{a:1, b:2}"))
=> '(["a" 1] ["b" 2])
(fact [[{:doc "an example test description"
:globals [ka "a"
kb "b"]
:vars [o (obj :a 1 :b 2 :c 3)]}]]
"dot notation for native objects"
o.a => 1
(+ o.a o.b o.c) => 6
"support for both native and cljs comparisons"
o => (obj :a 1 :b 2 :c 3)
[1 2 3 4] => [1 2 3 4]
"support for function comparison"
2 => even?
3 => (comp not even?)
"globals"
o.|ka| => 1
(+ o.|ka| o.|kb|) => 3
"vars are allowed to be rebound"
(! o (arr [1 2 3]
[4 5 6]
[7 8 9]))
(- o.2.2 o.0.0) => 8)
Copyright © 2014 Chris Zheng
Distributed under the The MIT License.