From 083ed923a7517ca63d4f259f4bfee7b8986ea03f Mon Sep 17 00:00:00 2001 From: =?utf8?q?Jo=C3=A3o=20T=C3=A1vora?= Date: Mon, 7 May 2018 15:04:02 +0100 Subject: [PATCH] Support javascript's javascript-typescript-langserver * README.md: Improve a bit * eglot.el (eglot--make-process): Take MANAGED-MAJOR-MODE arg (eglot-executables): Add basic javascript support. (eglot--connect): Pass mode to eglot--make-process (eglot--interactive): Check that guessed command is a listp. (eglot): Minor improvement to message. (eglot--current-buffer-TextDocumentItem): Guess language from mode symbol. --- lisp/progmodes/eglot.el | 41 +++++++++++++++++++++++------------------ 1 file changed, 23 insertions(+), 18 deletions(-) diff --git a/lisp/progmodes/eglot.el b/lisp/progmodes/eglot.el index cd485196b2e..045588de997 100644 --- a/lisp/progmodes/eglot.el +++ b/lisp/progmodes/eglot.el @@ -42,8 +42,10 @@ :prefix "eglot-" :group 'applications) -(defvar eglot-executables '((rust-mode . ("rls")) - (python-mode . ("pyls"))) +(defvar eglot-executables + '((rust-mode . ("rls")) + (python-mode . ("pyls")) + (js-mode . ("javascript-typescript-stdio"))) "Alist mapping major modes to server executables.") (defface eglot-mode-line @@ -145,23 +147,24 @@ list of a single string of the form :") (eglot--define-process-var eglot--buffer-open-count (make-hash-table) "Keeps track of didOpen/didClose notifs for each buffer.") -(defun eglot--make-process (name contact) +(defun eglot--make-process (name managed-major-mode contact) "Make a process from CONTACT. NAME is a name to give the inferior process or connection. +MANAGED-MAJOR-MODE is a symbol naming a major mode. CONTACT is as `eglot--contact'. Returns a process object." - (let* ((readable-name (format "EGLOT server (%s)" name)) + (let* ((readable-name (format "EGLOT server (%s/%s)" name managed-major-mode)) (buffer (get-buffer-create (format "*%s inferior*" readable-name))) - (singleton (and (null (cdr contact)) (car contact))) + singleton (proc - (if (and - singleton - (string-match "^[\s\t]*\\(.*\\):\\([[:digit:]]+\\)[\s\t]*$" - singleton)) + (if (and (setq singleton (and (null (cdr contact)) (car contact))) + (string-match "^[\s\t]*\\(.*\\):\\([[:digit:]]+\\)[\s\t]*$" + singleton)) (open-network-stream readable-name buffer (match-string 1 singleton) - (string-to-number (match-string 2 singleton))) + (string-to-number + (match-string 2 singleton))) (make-process :name readable-name :buffer buffer @@ -236,7 +239,7 @@ CONTACT is as `eglot--contact'. Returns a process object." short-name contact &optional success-fn) "Connect for PROJECT, MANAGED-MAJOR-MODE, SHORT-NAME and CONTACT. SUCCESS-FN with no args if all goes well." - (let* ((proc (eglot--make-process short-name contact)) + (let* ((proc (eglot--make-process short-name managed-major-mode contact)) (buffer (process-buffer proc))) (setf (eglot--contact proc) contact (eglot--project proc) project @@ -297,15 +300,16 @@ SUCCESS-FN with no args if all goes well." managed-major-mode (let ((prompt (cond (current-prefix-arg - "[eglot] Execute program (or connect to :) ") + "[eglot] Enter program to execute (or :): ") ((null guessed-command) (format "[eglot] Sorry, couldn't guess for `%s'!\n\ -Execute program (or connect to :) " +Enter program to execute (or :): " managed-major-mode))))) (if prompt (split-string-and-unquote (read-shell-command prompt - (combine-and-quote-strings guessed-command) + (if (listp guessed-command) + (combine-and-quote-strings guessed-command)) 'eglot-command-history)) guessed-command)) t))) @@ -347,7 +351,7 @@ INTERACTIVE is t if called interactively." command (lambda (proc) (eglot--message "Connected! Process `%s' now managing `%s' \ -buffers in project %s." +buffers in project `%s'." proc managed-major-mode short-name))))))) @@ -1101,9 +1105,10 @@ running. INTERACTIVE is t if called interactively." "Compute TextDocumentItem object for current buffer." (append (eglot--current-buffer-VersionedTextDocumentIdentifier) - (eglot--obj :languageId (cdr (assoc major-mode - '((rust-mode . rust) - (emacs-lisp-mode . emacs-lisp)))) + (eglot--obj :languageId + (if (string-match "\\(.*\\)-mode" (symbol-name major-mode)) + (match-string 1 (symbol-name major-mode)) + "unknown") :text (save-restriction (widen) -- 2.39.2