]> git.eshelyaron.com Git - emacs.git/commitdiff
Make m-x eglot's interactive spec a separate function
authorJoão Távora <joaotavora@gmail.com>
Fri, 4 May 2018 09:47:17 +0000 (10:47 +0100)
committerJoão Távora <joaotavora@gmail.com>
Fri, 4 May 2018 10:46:36 +0000 (11:46 +0100)
* eglot.el (eglot--interactive): New function.
(eglot): Rework a little.

lisp/progmodes/eglot.el

index 3d0c04483440206240affcb2ecb47ff6048e30e2..ec7f3e6653c89e5769ccb9d3eaaeb9bf38a2df50 100644 (file)
@@ -234,6 +234,39 @@ SUCCESS-FN with no args if all goes well."
 (defvar eglot--command-history nil
   "History of COMMAND arguments to `eglot'.")
 
+(defun eglot--interactive ()
+  "Helper for `eglot'."
+  (let* ((managed-major-mode
+          (cond
+           ((or current-prefix-arg
+                (not buffer-file-name))
+            (intern
+             (completing-read
+              "[eglot] Start a server to manage buffers of what major mode? "
+              (mapcar #'symbol-name
+                      (eglot--all-major-modes)) nil t
+              (symbol-name major-mode) nil
+              (symbol-name major-mode) nil)))
+           (t major-mode)))
+         (guessed-command
+          (cdr (assoc managed-major-mode eglot-executables))))
+    (list
+     managed-major-mode
+     (let ((prompt
+            (cond (current-prefix-arg
+                   "[eglot] Execute program (or connect to <host>:<port>) ")
+                  ((null guessed-command)
+                   (format "[eglot] Sorry, couldn't guess for `%s'!\n\
+Execute program (or connect to <host>:<port>) "
+                           managed-major-mode)))))
+       (if prompt
+           (split-string-and-unquote
+            (read-shell-command prompt
+                                (combine-and-quote-strings guessed-command)
+                                'eglot-command-history))
+         guessed-command))
+     t)))
+
 (defun eglot (managed-major-mode command &optional interactive)
   "Start a Language Server Protocol server.
 Server is started with COMMAND and manages buffers of
@@ -251,64 +284,33 @@ With a prefix arg, prompt for MANAGED-MAJOR-MODE and COMMAND,
 else guess them from current context and `eglot-executables'.
 
 INTERACTIVE is t if called interactively."
-  (interactive
-   (let* ((managed-major-mode
-           (cond
-            ((or current-prefix-arg
-                 (not buffer-file-name))
-             (intern
-              (completing-read
-               "[eglot] Start a server to manage buffers of what major mode? "
-               (mapcar #'symbol-name
-                       (eglot--all-major-modes)) nil t
-               (symbol-name major-mode) nil
-               (symbol-name major-mode) nil)))
-            (t major-mode)))
-          (guessed-command
-           (cdr (assoc managed-major-mode eglot-executables))))
-     (list
-      managed-major-mode
-      (let ((prompt
-             (cond (current-prefix-arg
-                    "[eglot] Execute program (or connect to <host>:<port>) ")
-                   ((null guessed-command)
-                    (format "[eglot] Sorry, couldn't guess for `%s'!\n\
-Execute program (or connect to <host>:<port>) "
-                            managed-major-mode)))))
-        (if prompt
-            (split-string-and-unquote
-             (read-shell-command prompt
-                                 (combine-and-quote-strings guessed-command)
-                                 'eglot-command-history))
-          guessed-command))
-      t)))
+  (interactive (eglot--interactive))
   (let* ((project (project-current))
          (short-name (eglot--project-short-name project)))
     (unless project (eglot--error "Cannot work without a current project!"))
     (unless command (eglot--error "Don't know how to start EGLOT for %s buffers"
                                   major-mode))
     (let ((current-process (eglot--current-process)))
-      (cond ((and (process-live-p current-process)
-                  interactive
-                  (y-or-n-p "[eglot] Live process found, reconnect instead? "))
-             (eglot-reconnect current-process interactive))
-            (t
-             (when (process-live-p current-process)
-               (eglot-shutdown current-process 'sync))
-             (eglot--connect
-              project
-              managed-major-mode
-              short-name
-              command
-              (lambda (proc)
-                (eglot--message "Connected! Process `%s' now managing `%s' \
+      (if (and (process-live-p current-process)
+               interactive
+               (y-or-n-p "[eglot] Live process found, reconnect instead? "))
+          (eglot-reconnect current-process interactive)
+        (when (process-live-p current-process)
+          (eglot-shutdown current-process 'sync))
+        (eglot--connect
+         project
+         managed-major-mode
+         short-name
+         command
+         (lambda (proc)
+           (eglot--message "Connected! Process `%s' now managing `%s' \
 buffers in project %s."
-                                proc
-                                managed-major-mode
-                                short-name)
-                (dolist (buffer (buffer-list))
-                  (with-current-buffer buffer
-                    (eglot--maybe-activate-editing-mode proc))))))))))
+                           proc
+                           managed-major-mode
+                           short-name)
+           (dolist (buffer (buffer-list))
+             (with-current-buffer buffer
+               (eglot--maybe-activate-editing-mode proc)))))))))
 
 (defun eglot-reconnect (process &optional interactive)
   "Reconnect to PROCESS.