A Leiningen plugin to use clojure-lsp features API, it automatically downloads clojure-lsp native binary and runs with the provided args.
Add the plugin to your project.clj:
:plugins [[com.github.clojure-lsp/lein-clojure-lsp "2.0.12"]]This plugin accepts the following pattern clojure-lsp <command> "<options>".
For more information on all available commands and options, Check the API documentation.
$ lein clojure-lsp clean-ns --dryYou can configure your project.clj to add custom aliases to run specific clojure-lsp tasks, below you can find a simple example with both tasks for formatting, cleaning the namespaces as aliases to just check instead of change the code (dry):
,,,
:clojure-lsp {:settings {:clean {:ns-inner-blocks-indentation :same-line}}} ;; API options
:aliases {"clean-ns" ["clojure-lsp" "clean-ns" "--dry"]          ;; check if namespaces are clean
          "format" ["clojure-lsp" "format" "--dry"]              ;; check if namespaces are formatted
          "diagnostics" ["clojure-lsp" "diagnostics"]            ;; check if project has any diagnostics (clj-kondo findings)
          "lint" ["do" ["clean-ns"] ["format"] ["diagnostics"]]  ;; check all above
          "clean-ns-fix" ["clojure-lsp" "clean-ns"]              ;; Fix namespaces not clean
          "format-fix" ["clojure-lsp" "format"]                  ;; Fix namespaces not formatted
          "lint-fix" ["do" ["clean-ns-fix"] ["format-fix"]]}     ;; Fix both
,,,