Version 2.0 was a breaking version. This guide sums up what has changed.
Where the start
and stop
functions used to take zero to multiple "option maps", they now take one optional argument: the "up to" var.
If you were using the only
or except
options, see if you can replace them with the "up to" approach, or with the extension point, or keep using the 0.9.x version.
To use the value of a started state, you need to dereference it by using @
or deref
now.
Dereferencing a stopped state yields an exception.
Substitutes cannot be defined as a simple map anymore.
Please use the state
macro to create anonymous states.
The syntax for the state
macro has not changed though, with respect to versions before 2.0.
For example:
;; This is not supported anymore
(def sub {:start (fn [] ...)})
;; This is the only supported syntax now
(def sub (state :start ...))
States are not automatically stopped anymore on redefinition.
You need to manually stop
and start
your states, or use the tools.namespace library.
This also means that the :on-reload
and :on-cascade
options of defstate
are gone, just as the on-reload
function.
A refresh extension has been added for an easy integration with tools.namespace library.
Detecting the dependency graph for the defstates
has been removed from the core.
It has returned as an another form as the explicit-deps extension.
This means that the "up-to" behaviour may now start or stop more states than you were used to.
Because state dependency graphs have been removed for now, starting or stopping states in parallel
has been removed as well.
The bindings
feature has been removed as well.
It was rarely used, and only added complexity to the macros.
If you use the feature, it can easily be replaced by many other means.
Can you improve this documentation?Edit on GitHub
cljdoc is a website building & hosting documentation for Clojure/Script libraries
× close