Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add customizable default connection params #3359

Open
wants to merge 5 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@
- [#3784](https://github.com/clojure-emacs/cider/issues/3784): Inspector: make point less erratic when navigating between inspector screens.
- [#3790](https://github.com/clojure-emacs/cider/issues/3790): Stacktrace: show messages and data for all exception causes by default.
- [#3789](https://github.com/clojure-emacs/cider/issues/3789): Refactor and simplify exception handling.
- [#3359](https://github.com/clojure-emacs/cider/pull/3359): Add customizable default connection params

## 1.17.1 (2025-02-25)

Expand Down
88 changes: 69 additions & 19 deletions cider.el
Original file line number Diff line number Diff line change
Expand Up @@ -1540,14 +1540,54 @@ server buffer, in which case a new session for that server is created."
(plist-put :session-name ses-name)
(plist-put :repl-type 'cljs)))))

(defcustom cider-connect-default-params nil
"Default plist of params for connecting to an external nREPL server.
Recognized keys are :host, :port and :project-dir.

These are used as arguments to the commands `cider-connect-clj',
`cider-connect-cljs' and `cider-connect-clj&cljs', in order to bypass
the corresponding user prompts.

This defcustom is intended for use with .dir-locals.el on a per-project basis.
See `cider-connect-default-cljs-params' in order to specify a separate set of params
for cljs REPL connections.

Note: it is recommended to set the variable `cider-default-cljs-repl'
instead of specifying the :cljs-repl-type key."
:type '(plist :key-type
(choice (const :host)
(const :port)
(const :project-dir)))
:group 'cider)

(defcustom cider-connect-default-cljs-params nil
"Default plist of params for connecting to a ClojureScript REPL.
Recognized keys are :host, :port and :project-dir.

If non-nil, overrides `cider-connect-default-params' for the commands
`cider-connect-cljs' and (the latter half of) `cider-connect-clj&cljs'.

Note: it is recommended to set the variable `cider-default-cljs-repl'
instead of specifying the :cljs-repl-type key."
:type '(plist :key-type
(choice (const :host)
(const :port)
(const :project-dir)))
:group 'cider)

;;;###autoload
(defun cider-connect-clj (&optional params)
"Initialize a Clojure connection to an nREPL server.
PARAMS is a plist optionally containing :host, :port and :project-dir. On
prefix argument, prompt for all the parameters."
PARAMS is a plist optionally containing :host, :port and :project-dir.
If nil, use the default parameters in `cider-connect-default-params'.

With the prefix argument, prompt for all the parameters regardless of
their supplied or default values."
(interactive "P")
(cider-nrepl-connect
(thread-first params
(thread-first (or params cider-connect-default-params)
(copy-sequence) ;; Note: the following steps mutate the list
(map-delete :cljs-repl-type)
(cider--update-project-dir)
(cider--update-host-port)
(cider--check-existing-session)
Expand All @@ -1560,12 +1600,17 @@ prefix argument, prompt for all the parameters."
"Initialize a ClojureScript connection to an nREPL server.
PARAMS is a plist optionally containing :host, :port, :project-dir and
:cljs-repl-type (e.g. 'shadow, 'node, 'figwheel, etc).
If nil, use the default parameters in `cider-connect-default-params' or
`cider-connect-default-cljs-params'.

On prefix, prompt for all the
parameters regardless of their supplied or default values."
With the prefix argument, prompt for all the parameters regardless of
their supplied or default values."
(interactive "P")
(cider-nrepl-connect
(thread-first params
(thread-first (or params
cider-connect-default-cljs-params
cider-connect-default-params)
(copy-sequence)
(cider--update-project-dir)
(cider--update-host-port)
(cider--check-existing-session)
Expand All @@ -1578,22 +1623,27 @@ parameters regardless of their supplied or default values."
(defun cider-connect-clj&cljs (params &optional soft-cljs-start)
"Initialize a Clojure and ClojureScript connection to an nREPL server.
PARAMS is a plist optionally containing :host, :port, :project-dir and
:cljs-repl-type (e.g. 'shadow, 'node, 'figwheel, etc). When SOFT-CLJS-START is
non-nil, don't start if ClojureScript requirements are not met."
:cljs-repl-type (e.g. 'shadow, 'node, 'figwheel, etc).
If nil, use the default parameters in `cider-connect-default-params' and
`cider-connect-default-cljs-params'.

When SOFT-CLJS-START is non-nil, don't start if ClojureScript requirements are
not met.

With the prefix argument, prompt for all the parameters regardless of
their supplied or default values."
(interactive "P")
(let* ((params (thread-first params
(cider--update-project-dir)
(cider--update-host-port)
(cider--check-existing-session)
(cider--update-cljs-type)))
(clj-params (thread-first params
copy-sequence
(map-delete :cljs-repl-type)))
(clj-repl (cider-connect-clj clj-params)))
(let* ((clj-repl (cider-connect-clj params))
(cljs-params
(thread-first (or params cider-connect-default-cljs-params)
(copy-sequence)
(cider--update-cljs-type)
;; already asked, don't ask on sibling connect
(plist-put :do-prompt nil))))
(when (if soft-cljs-start
(cider--check-cljs (plist-get params :cljs-repl-type) 'no-error)
(cider--check-cljs (plist-get cljs-params :cljs-repl-type) 'no-error)
t)
(cider-connect-sibling-cljs params clj-repl))))
(cider-connect-sibling-cljs cljs-params clj-repl))))

(defvar cider-connection-init-commands
'(cider-jack-in-clj
Expand Down
16 changes: 16 additions & 0 deletions doc/modules/ROOT/pages/basics/up_and_running.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -358,6 +358,22 @@ reads for the host and port prompts when you invoke
("host-b" "7888")))
----

If you wish to bypass the prompts entirely, you can configure the variables
`cider-connect-default-params` and `cider-connect-default-cljs-params`
on a per-project basis using https://www.gnu.org/software/emacs/manual/html_node/emacs/Directory-Variables.html[.dir-locals.el].

The following configuration allows you to type kbd:[M-x] `cider-connect-clj&cljs` kbd:[RET] and instantly connect to both JVM and shadow-cljs REPLs without answering any prompts – useful when the project always uses the same fixed endpoints for its nREPL servers.

[source,lisp]
---
((clojure-mode
. ((cider-connect-default-params . (:host "localhost" :port 1234))
(cider-connect-default-cljs-params . (:host "localhost" :port 5678))
(cider-default-cljs-repl . shadow))))
---

Note that the universal argument kbd:[C-u] can be used before a command to override these settings and force the prompts to be displayed.

== Working with Remote Hosts

While most of the time you'd be connecting to a locally running nREPL
Expand Down
24 changes: 24 additions & 0 deletions test/integration/integration-tests.el
Original file line number Diff line number Diff line change
Expand Up @@ -616,3 +616,27 @@ If CLI-COMMAND is nil, then use the default."
;; wait for the REPL to exit
(cider-itu-poll-until (not (eq (process-status nrepl-proc) 'run)) 15)
(expect (member (process-status nrepl-proc) '(exit signal)))))))))))

(describe "cider-connect-default-params"
(it "bypasses cider-connect user prompts"
(let (host-prompt port-prompt)
(spy-on 'cider--completing-read-host
:and-call-fake (lambda (_) (setq host-prompt t)))
(spy-on 'cider--completing-read-host
:and-call-fake (lambda (_) (setq port-prompt t)))
(with-temp-buffer
(setq-local cider-connect-default-params '(:host "localhost"))
(ignore-errors (call-interactively 'cider-connect))
(expect host-prompt :to-equal nil)
(expect port-prompt :to-equal t))
(with-temp-buffer
(setq host-prompt nil port-prompt nil)
(setq-local cider-connect-default-params
'(:host "localhost" :port 65536))
(condition-case e
(call-interactively 'cider-connect)
(error
(expect e :to-equal
'(error "[nREPL] Direct connection to localhost:65536 failed"))))
(expect host-prompt :to-equal nil)
(expect port-prompt :to-equal nil)))))