Below you can find all available features that clojure-lsp provides with examples using Emacs lsp-mode as the client.
Also, it's possible to live rename symbols on the same buffer with linkedEditingRange
feature.
To understand what is supported and how to configure it, check the settings section.
Snippets are templates that make it easier to enter repeating code patterns, such as common functions/forms, they are available during completion. Tabstops are defined as $number
with $0
as last tabstop.
name | description | raw content |
---|---|---|
comment | Insert comment block | (comment\n ${0:body}\n ) |
comment-heading | Insert comment Header | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;\n;; ${1:Namespace summary title}\n;;\n;; ${2:Brief description}\n;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;\n\n$0 |
comment-separator | Insert comment separator | ;; ${1:Namespace summary title}\n;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;\n\n$0 |
rich-comment | Insert rich comment |
(comment
$0
#_())
|
rich-comment-rdd | Insert rich comment rdd block |
#_{:clj-kondo/ignore [:redefined-var]}\n(comment\n $0 #_()) |
rich-comment-hotload | Insert rich comment library hotload |
#_{:clj-kondo/ignore [:redefined-var]}\n(comment\n ;; Add-lib library for hot-loading\n (require '[clojure.tools.deps.alpha.repl :refer [add-libs]])\n (add-libs '{${1:domain/library-name} {:mvn/version \"${2:1.0.0}\"}$3})\n $0\n) |
condp | Insert condp | (condp ${1:pred} ${2:expr}\n $0) |
def | Insert def | (def ${1:name} $0) |
def- | Insert def private | (def ^:private ${1:name} $0) |
def-doc | Insert def with docstring | (def ${1:name}\n \"${2:docstring}\"\n $0) |
defmethod | Insert defmethod | (defmethod ${1:name} ${2:match}\n [${3:args}]\n $0) |
defmulti | Insert defmulti | (defmulti ${1:name} ${2:dispatch-fn}) |
defn | Insert public defn | (defn ${1:name} [$2]\n $0) |
defn-doc | Insert public defn with docstring | (defn ${1:name}\n \"${2:docstring}\"\n [${3:args}]\n $0) |
defn- | Insert private defn | (defn%s ${1:name} [$2]\n $0) |
defprotocol | Insert defprotocol | (defprotocol ${1:Name}\n $0) |
defrecord | Insert defrecord | (defrecord ${1:Name} [${2:fields}]\n ${3:Protocol}\n $0) |
deftype | Insert deftype | (deftype ${1:Name} [${2:fields}]\n ${3:Protocol}\n $0) |
fn | Insert fn | (fn [${1:arg-list}] $0) |
for | Insert for | (for [${1:item} ${2:coll}]\n $0) |
if | Insert if | (if ${1:test-expr}\n ${2:then-expr}\n ${3:else-expr}) |
kwargs | Insert keyword args | {:keys [${1:keys}] :or {${2:defaults}}} |
let | Insert let | (let [$0]) |
letfn | Insert letfn | (letfn [(${1:name} [${2:args}]\n $0)]) |
ns | Insert ns | (ns ${1:name}\n $0:references}) |
ns-doc | Insert ns with docstring | (ns ${1:name}\n \"${2:docstring}\"\n ${0:references}) |
require | Insert ns :require | (:require [${1:namespace}])$0 |
require-as | Insert ns require with :as alias | (:require [${1:namespace} :as ${2:alias}]$3) |
require-refer | Insert ns :require with :refer | (:require [${1:namespace} :refer [$2]]$3) |
require-rdd | Insert require for rich comment experiments | (require '[${1:namespace} :as ${2:alias}]$3)$0 |
req-as | Insert single require dep :as alias | [${1:namespace} :as ${2:alias}] |
req-refer | Insert single require dep with :refer | [${1:namespace} :refer [$2]] |
import | Insert import | (:import [${1:package}]) |
use | Insert require refer preferred over use | (:require [${1:namespace} :refer [$2]]) |
deps-alias | Insert alias with extra path & deps |
:${1:category/name}\n {:extra-paths [\"${2:path}\"]\n :extra-deps {${3:deps-maven or deps-git}}}$0 |
deps-maven | Insert maven dependency | ${1:domain/library-name} {:mvn/version \"${2:1.0.0}\"}$0 |
deps-git | Insert git dependency |
${1:domain/library-name}\n {:git/sha \"${2:git-sha-value}\"}$0 |
deps-git-tag | Insert git tag dependency |
${1:domain/library-name}\n {:git/tag \"${2:git-tag-value}\"\n :git/sha \"${3:git-sha-value}\"}$0 |
deps-git-url | Insert git URL dependency |
${1:domain/library-name}\n {:git/url \"https://github.com/$1\"\n :git/sha \"${2:git-sha-value}\"}$0 |
deps-local | Insert local dependency |
${1:domain/library-name} {:local/root \"${2:/path/to/project/root}\"}$0 |
deftest | Insert deftest clojure.test |
(deftest ${1:name}-test\n (testing \"${2:Context of the test assertions}\"\n (is (= ${3:assertion-values}))$4)) $0 |
testing | Insert testing clojure.test |
(testing \"${1:Context of the test assertions}\"\n $0) |
is | Insert is clojure.test | (is (= ${1:assertion-values})) |
User can register additional custom snippets. For more information, check the snippets config documentation.
See below for screenshots.
The LSP server is the best to say what is the semantic value of a token on the editor, semantic tokens allows server return to client all tokens of a buffer and how client show apply highlight.
Note: server return the semantic token (e.g. function
) and the client/editor apply the color that matches the user's theme.
Show the incoming or outgoing call hierarchy of a function/variable as a lazy tree
Show functions that call the current one recursively
Show functions that the current one call, recursively
Show the tests tree hierarchy of a file
Show the project tree ns and external dependencies.
All linters besides the ones below come from clj-kondo that clojure-lsp calls under the hood to lint the code and retrieve the analysis to make most of features work.
Every linter configuration should be done on clj-kondo side, so anything related to unresolved symbols or unknown macros are probably related to wrong clj-kondo for the project. For more information on how to configure clj-kondo check here.
Below you can find the custom linters implemented on clojure-lsp side that uses the :custom-lint-fn
from clj-kondo:
For more information on how to configure it, check the diagnostics settings section.
Clojure-lsp has a optional integration with clj-depend, making it easier to configure namespaces relationship.
For more information on how to configure it, check the diagnostics settings section.
It's possible to configure clojure-lsp to generate and analyze stubs for specific namespaces available on your project classpath, this is useful for closed source dependencies like datomic.api
, with that clojure-lsp will be able to make most features work with those dependencies.
For more information check the stubs settings section.
Commands that client can request. Most code actions use these commands as actions.
Note: Most of these are available via code actions and clients or users may choose to use the code action menu to execute them instead of mapping.
All functions in clojure-lsp have a two-letter mnemonic shortcut. E.g. tf
for thread-first-all
. We strongly suggest that client authors and users use these shortcuts keys when choosing to map these commands to key chords or menus; this allows for users to maintain muscle memory and familiarity as they switch between clients and editors. Thank you to clj-refactor for this system and other tools that adhere to it.
LSP clients will allow you to bind these commands to shortcuts or menu items using LSP's workspace/executeCommand
and passing a map with "command"
and "arguments"
keys.
Arguments:
file-uri
: Absolute file uri. e.x. file:///home/user/project/src/main.clj
row
: line-number of the cursor, 0 based.col
: col-number of the cursor, 0 based.name
: Used when introducing a name, usually a string for a valid clojure symbol.filename
: Filename path. e.x. src/utils.clj
Return basic information about the server.
Return debug information about the element at point.
Can you improve this documentation? These fine people already did:
Eric Dallo, Jacob Maine & Case NelsonEdit on GitHub
cljdoc is a website building & hosting documentation for Clojure/Script libraries
× close