doomemacs/modules/lang/clojure
Henrik Lissner c7a1e2d70c
bump: :lang
JuliaEditorSupport/julia-emacs@5c940c4ba3 -> JuliaEditorSupport/julia-emacs@aadf29523a
ProofGeneral/PG@d60382db08 -> ProofGeneral/PG@75c13f91b6
agda/agda@bb9e13d970 -> agda/agda@5cf984c3d2
ananthakumaran/exunit.el@12a1efd003 -> ananthakumaran/exunit.el@bef971bde5
ardumont/markdown-toc@29e5c0f33e -> ardumont/markdown-toc@d22633b654
babashka/neil@8d5ccdbd81 -> babashka/neil@74cc79e4b9
clojure-emacs/cider@15bd3b0265 -> clojure-emacs/cider@ae247d8845
clojure-emacs/clojure-mode@4679222109 -> clojure-emacs/clojure-mode@bddba12e96
emacs-ess/ESS@f8c464dc1b -> emacs-ess/ESS@bfe892db15
emacs-rustic/rustic@e77f62facc -> emacs-rustic/rustic@cb013cd217
emacs-straight/auctex@077874d25a -> emacs-straight/auctex@1939acb54b
erlang/otp@2b2b39797f -> erlang/otp@f80e9c1c4a
godotengine/emacs-gdscript-mode@248b73b1bd -> godotengine/emacs-gdscript-mode@dd44f1dfa5
greghendershott/racket-mode@150b057953 -> greghendershott/racket-mode@71f27c643d
hakimel/reveal.js@33bfe3b233 -> hakimel/reveal.js@5abf24c1d8
haskell/haskell-mode@383b4b7775 -> haskell/haskell-mode@2dd755a5fa
hhvm/hack-mode@86a981bd7b -> hhvm/hack-mode@0b117e7f25
hvesalai/emacs-scala-mode@661337d8aa -> hvesalai/emacs-scala-mode@50bcafa181
idris-hackers/idris-mode@85928dc4cc -> idris-hackers/idris-mode@d32b2396a8
jrblevin/markdown-mode@92802fae9e -> jrblevin/markdown-mode@9de2df5a9f
mekeor/nael@9711443449 -> mekeor/nael@3ee1cf286d
meow_king/zig-ts-mode@89b52c865c -> meow_king/zig-ts-mode@64611c6d51
minad/org-modern@9bbc44cc7e -> minad/org-modern@b4b5b1c864
nim-lang/nim-mode@625cc023bd -> nim-lang/nim-mode@4502f83fbb
nix-community/nix-ts-mode@706bbfaf7f -> nix-community/nix-ts-mode@625306cf9c
ocaml/dune@14df34d30d -> ocaml/dune@7a7d49206f
ocaml/merlin@a0b096c243 -> ocaml/merlin@1c4148af05
org-roam/org-roam@c72702cf27 -> org-roam/org-roam@b4857fd7a1
rust-lang/rust-mode@ae161dca23 -> rust-lang/rust-mode@f68ddca5c2
seagle0128/grip-mode@26bdadf604 -> seagle0128/grip-mode@b8b9e603ed
sogaiu/janet-ts-mode@0e4d04d648 -> sogaiu/janet-ts-mode@aba932a1a1
szermatt/emacs-bash-completion@762f28fefb -> szermatt/emacs-bash-completion@5b621db96e
technomancy/fennel-mode@c1bccdec9e -> technomancy/fennel-mode@9c1dac3c39
tpapp/julia-repl@681efc14a7 -> tpapp/julia-repl@0173237a43
weijiangan/flycheck-golangci-lint@f7e36e19d6 -> weijiangan/flycheck-golangci-lint@51aede797d
2026-02-13 16:31:15 -05:00
..
.doommodule feat: add .doommodule files 2024-09-14 20:47:39 -04:00
autoload.el refactor: (if|when)-let -> (if|when)-let* 2025-01-08 19:33:37 -05:00
config.el fix: file-name-concat paths instead of concat 2025-12-30 22:59:10 -05:00
doctor.el fix(clojure): void-function derived-mode-add-parents on <30 2025-12-30 22:50:31 -05:00
packages.el bump: :lang 2026-02-13 16:31:15 -05:00
README.org fix(clojure): void-function derived-mode-add-parents on <30 2025-12-30 22:50:31 -05:00

: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 and Emacs 30.1 or newer.

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?