CIDER is the Clojure(Script) Interactive Development Environment that Rocks!
CIDER extends Emacs with support for interactive programming in Clojure. The
features are centered around cider-mode, an Emacs minor-mode that complements
clojure-mode supports editing Clojure source files,
cider-mode adds support for interacting with a running Clojure process for
compilation, debugging, definition and documentation lookup, running tests and
Please consider supporting financially its ongoing development.
Programmers are expected to program in a very dynamic and incremental manner, constantly re-evaluating existing Clojure definitions and adding new ones to their running applications. You never stop/start a Clojure application while using CIDER - you’re constantly interacting with it and changing it.
You can find more details about the typical CIDER workflow in the Interactive Programming section. While we’re a bit short on video tutorials, you can check out this introduction to CIDER to get a feel about what do we mean by an "Interactive Development Environment".
CIDER’s built on top of nREPL, the Clojure networked REPL server.
CIDER’s basic architecture looks something like this:
Clojure code gets executed by an nREPL server. CIDER sends requests to the server and processes its responses. The server’s functionality is augmented by additional nREPL middleware, designed specifically to address the needs of an interactive development environment like CIDER.
CIDER packs plenty of features. Here are some of them (in no particular order):
Interactive code evaluation
Definition & documentation lookup
Enhanced error reporting
And many many more… The rest of this manual will be exploring CIDER’s features in great detail.
Below you can see a typical CIDER session.
Here the user checked the documentation for
clojure.core/merge straight from the source buffer
and then jumped to a REPL buffer to try out something there.
So, what to do next? While you can peruse the documentation in whatever way you’d like, here are a few recommendations: