JuliaEditorSupport/julia-emacs@d360ad5285 -> JuliaEditorSupport/julia-emacs@2aca8cf585 ProofGeneral/PG@3a99da2755 -> ProofGeneral/PG@b30d65de80 abo-abo/org-download@19e166f0a8 -> abo-abo/org-download@c8be261178 agda/agda@4f82f9b90a -> agda/agda@819993172d ananthakumaran/tide@b38dfc3f8f -> ananthakumaran/tide@6a35fe355f babashka/neil@6728367eff -> babashka/neil@78ffab1868 beancount/beancount-mode@7b437abcf0 -> beancount/beancount-mode@452621fa1f cdominik/cdlatex@33770dec73 -> cdominik/cdlatex@fac070f016 clojure-emacs/cider@8fdb53e8be -> clojure-emacs/cider@c228dec27d davazp/graphql-mode@ef4aecaead -> davazp/graphql-mode@c3baca9280 diml/utop@384b3098c8 -> diml/utop@b490baca21 emacs-geiser/guile@5a856c2982 -> emacs-geiser/guile@a0f111f8de emacs-geiser/mit@4e90e9ae81 -> emacs-geiser/mit@ddd2ba733e emacs-jupyter/jupyter@f97f4b5d8c -> emacs-jupyter/jupyter@e966c5d3d6 emacs-lsp/lsp-dart@9ffbafb7dc -> emacs-lsp/lsp-dart@7e3d342941 emacs-lsp/lsp-haskell@ba49fa9822 -> emacs-lsp/lsp-haskell@6981f8d122 emacs-lsp/lsp-metals@0dc938be11 -> emacs-lsp/lsp-metals@b5139c9593 emacs-lsp/lsp-pyright@0c0d72aedd -> emacs-lsp/lsp-pyright@dd54b3ae7c emacs-php/composer.el@791a7104be -> emacs-php/composer.el@6c7e19256f emacs-php/php-mode@59814bd80c -> emacs-php/php-mode@31f702ee2d emacs-rustic/rustic@d765680373 -> emacs-rustic/rustic@9fdf5c76b2 emacs-straight/auctex@08881d08ce -> emacs-straight/auctex@0de9730957 emacs-typescript/typescript.el@fc3a4f3b27 -> emacs-typescript/typescript.el@dd10f702d4 emacsmirror/org-contrib@ccd4212866 -> emacsmirror/org-contrib@f22bdd6a58 emacsmirror/paredit@037b9b8acb -> emacsmirror/paredit@af075775af emacsorphanage/dart-mode@44beb628e5 -> emacsorphanage/dart-mode@02e919c1cf emacsorphanage/macrostep@4939d88779 -> emacsorphanage/macrostep@419873665f erlang/otp@c66bf53cde -> erlang/otp@094260aba7 flatwhatson/scheme-mode@51e586e5f1 -> flatwhatson/scheme-mode@a713b253d2 godotengine/emacs-gdscript-mode@32086df833 -> godotengine/emacs-gdscript-mode@bee7f99c6f greghendershott/racket-mode@dba66c4536 -> greghendershott/racket-mode@c5bee6895b hakimel/reveal.js@472535065c -> hakimel/reveal.js@0d02d8a303 haskell/haskell-mode@727f72a2a4 -> haskell/haskell-mode@1a285fc4c5 hniksic/emacs-htmlize@ed5e5b05fd -> hniksic/emacs-htmlize@8e3841c837 jimhourihan/glsl-mode@9b2e5f28e4 -> jimhourihan/glsl-mode@c5f2c2e7ed jrblevin/markdown-mode@6102ac5b73 -> jrblevin/markdown-mode@b8637bae07 jwiegley/emacs-async@43f97d7e68 -> jwiegley/emacs-async@af47d6f930 kaushalmodi/ox-hugo@c4156d9d38 -> kaushalmodi/ox-hugo@98421a1298 ledger/ledger-mode@a6be7a2d79 -> ledger/ledger-mode@356d8049ed necaris/conda.el@ce748a53f9 -> necaris/conda.el@05de0c8f0c non-Jedi/eglot-jl@1d9cab6823 -> non-Jedi/eglot-jl@7c968cc61f nonsequitur/inf-ruby@b234625c85 -> nonsequitur/inf-ruby@6399a36682 ocaml/dune@a7924e322e -> ocaml/dune@5ac095c7c0 ocaml/merlin@e016abfac6 -> ocaml/merlin@a36f42a5b1 org-noter/org-noter@6f292d7f1e -> org-noter/org-noter@691efc3ed4 org-roam/org-roam@0b9fcbc97b -> org-roam/org-roam@2a630476b3 purcell/flycheck-ledger@628e25ba66 -> purcell/flycheck-ledger@48bed9193c purcell/flycheck-package@75efa098cf -> purcell/flycheck-package@a52e4e95f3 purcell/less-css-mode@c7fa3d56d8 -> purcell/less-css-mode@c78b88ff9a purescript-emacs/purescript-mode@eacc61aaaf -> purescript-emacs/purescript-mode@d187b3d4bb rust-lang/rust-mode@c87f6f82bd -> rust-lang/rust-mode@542f1755d8 seagle0128/grip-mode@9adac9c989 -> seagle0128/grip-mode@d6c7e33e40 senny/rbenv.el@588b817d51 -> senny/rbenv.el@4afe1dc6bd swift-emacs/swift-mode@b06c97b909 -> swift-emacs/swift-mode@ab189d6e89 technomancy/fennel-mode@f4bd34e1c3 -> technomancy/fennel-mode@259470b297 tpapp/julia-repl@801d0fc3d8 -> tpapp/julia-repl@bb90cc1fce wbolster/emacs-python-pytest@dcdaec6fe2 -> wbolster/emacs-python-pytest@25d9801562 yoshiki/yaml-mode@7b5ce294fb -> yoshiki/yaml-mode@d91f878729 ziglang/zig-mode@f55e42536a -> ziglang/zig-mode@f0b4a48753
:lang clojure
Description unfold
This module adds support for the Clojure(Script) language.
- Interactive development environment (
cider
): REPL, compilation, debugging, running tests, definitions & documentation lookup, code completion, and much more - Refactoring (
clj-refactor
) - Linting (
clj-kondo
), requires doom-module::checkers syntax - LSP support (
clojure-lsp
), required doom-module:+lsp
Maintainers
Module flags
- +lsp
-
Enable LSP support for
clojure-mode
(alongside Cider). Requires doom-module::tools lsp and a langserver (supports clojure-lsp). - +tree-sitter
- Leverages tree-sitter for better syntax highlighting and structural text editing. Requires doom-module::tools tree-sitter.
Packages
- doom-package:cider
- doom-package:clj-refactor
- doom-package:flycheck-clj-kondo if doom-module::checkers syntax
Hacks
- Error messages emitted from CIDER are piped into the REPL buffer when it is first opened, to make them easier to notice.
- Disabled the help banner when opening the cider REPL.
TODO Changelog
This module does not have a changelog yet.
Installation
Enable this module in your doom!
block.
This module requires:
This module optionally requires:
- clj-kondo, for linting code (if doom-module::checkers syntax)
- clojure-lsp, for LSP support (if doom-module:+lsp)
- neil for the ability to add packages to your Clojure project from Emacs
- jet for jet integration
- cljfmt, for formatting code (if doom-module::editor format)
Usage
Below is a listing of the various keybinds provided by the module.
REPL management
For the most part, general usage should fall into:
- Open a Clojure project
- Open/connect to a REPL
As such, these bindings are most likely to be used.
Keybind | Command |
---|---|
<localleader> ' | cider-jack-in-clj |
<localleader> c | cider-connect-clj |
<localleader> C | cider-connect-cljs |
<localleader> m " | cider-jack-in-cljs |
<localleader> r R | cider-restart |
<localleader> r q | cider-quit |
<localleader> r B | +clojure/cider-switch-to-repl-buffer-and-switch-ns |
<localleader> r L | cider-load-buffer-and-switch-to-repl-buffer |
<localleader> r b | cider-switch-to-repl-buffer |
<localleader> r c | cider-find-and-clear-repl-output |
<localleader> r l | cider-load-buffer |
<localleader> r n | cider-repl-set-ns |
<localleader> r r | cider-ns-refresh |
Tests
The module also provides support for running tests through cider, including a nicely formatted output.
Keybind | Command |
---|---|
<localleader> t a | cider-test-rerun-test |
<localleader> t l | cider-test-run-loaded-tests |
<localleader> t n | cider-test-run-ns-tests |
<localleader> t p | cider-test-run-project-tests |
<localleader> t r | cider-test-rerun-failed-tests |
<localleader> t s | cider-test-run-ns-tests-with-filters |
<localleader> t t | cider-test-run-test |
Search/navigation
Some useful bindings for navigating around namespaces and symbols. When using doom-module:+lsp, the bindings in doom-module::tools lsp are supported.
Keybind | Command |
---|---|
<localleader> g b | cider-pop-back |
<localleader> g g | cider-find-var |
<localleader> g n | cider-find-ns |
<localleader> h n | cider-find-ns |
<localleader> n N | cider-browse-ns-all |
<localleader> n n | cider-browse-ns |
<localleader> h a | cider-apropos |
Evaluation
Outside of the SPC m e bindings for evaluating forms, the following are also available; including some to pretty-print the results.
Keybind | Command |
---|---|
<localleader> e D | cider-insert-defun-in-repl |
<localleader> e E | cider-insert-last-sexp-in-repl |
<localleader> e R | cider-insert-region-in-repl |
<localleader> e b | cider-eval-buffer |
<localleader> e d | cider-eval-defun-at-point |
<localleader> e e | cider-eval-last-sexp |
<localleader> e r | cider-eval-region |
<localleader> p d | cider-pprint-eval-defun-at-point |
<localleader> p D | cider-pprint-eval-defun-to-comment |
<localleader> p p | cider-pprint-eval-last-sexp |
<localleader> p P | cider-pprint-eval-last-sexp-to-comment |
<localleader> p r | cider-pprint-eval-last-sexp-to-repl |
Debugging
A number of bindings to provide useful overlays that help during debugging. cider-enlighten-mode
is a mode that will highlight the results of a function evaluation, including the locals. See a demo here.
Keybind | Command |
---|---|
<localleader> M | cider-macroexpand-all |
<localleader> R | hydra-cljr-help-menu/body |
<localleader> e u | cider-undef |
<localleader> i e | cider-enlighten-mode |
<localleader> i i | cider-inspect |
<localleader> i r | cider-inspect-last-result |
<localleader> m | cider-macroexpand-1 |
Help
Several bindings used for viewing documentation for various functions, both inside and outside of both a REPL and Emacs (K for example uses the sources and a cached version of clojuredocs)
Keybind | Command |
---|---|
<localleader> h c | cider-clojuredocs |
<localleader> h d | cider-doc |
<localleader> h j | cider-javadoc |
<localleader> h w | cider-clojuredocs-web |
K | +lookup/documentation |
Configuration
enrich-classpath
In recent versions, an option has been introduced that attempts to improve the experience of CIDER by accessing java source & javadocs, though this option is still currently considered beta.
In order to opt into this, add the following to your config.el
(setq cider-enrich-classpath t)
See the docs for more
Troubleshooting
There are no known problems with this module. Report one?
Frequently asked questions
This module has no FAQs yet. Ask one?
TODO Appendix
This module has no appendix yet. Write one?