From 0aaaea5ae9be07e979cbcd636226a088c1650017 Mon Sep 17 00:00:00 2001 From: =?utf8?q?Jo=C3=A3o=20T=C3=A1vora?= Date: Sun, 13 Oct 2019 22:32:52 +0100 Subject: [PATCH] Unbreak xref-find-definitions * eglot-tests.el (basic-xref): New test. * eglot.el (eglot--collecting-xrefs): Add an edebug spec. (eglot--lsp-xrefs-for-method): Actually collect xref. (xref-backend-apropos): Fix indentation slightly. GitHub-reference: fix https://github.com/joaotavora/eglot/issues/318 --- lisp/progmodes/eglot.el | 29 +++++++++++++++-------------- 1 file changed, 15 insertions(+), 14 deletions(-) diff --git a/lisp/progmodes/eglot.el b/lisp/progmodes/eglot.el index 9d5c546cefe..7b0e3e28a6d 100644 --- a/lisp/progmodes/eglot.el +++ b/lisp/progmodes/eglot.el @@ -1724,6 +1724,7 @@ Calls REPORT-FN maybe if server publishes diagnostics in time." (cl-defmacro eglot--collecting-xrefs ((collector) &rest body) "Sort and handle xrefs collected with COLLECTOR in BODY." + (declare (indent 1) (debug (sexp &rest form))) (let ((collected (cl-gensym "collected"))) `(unwind-protect (let (,collected) @@ -1786,13 +1787,13 @@ Try to visit the target file for a richer summary line." "/")))))) (eglot--error "Sorry, this server doesn't do %s" method)) (eglot--collecting-xrefs (collect) - (mapc - (eglot--lambda ((Location) uri range) - (eglot--xref-make (symbol-at-point) uri range)) - (jsonrpc-request - (eglot--current-server-or-lose) method (append - (eglot--TextDocumentPositionParams) - extra-params))))) + (mapc + (eglot--lambda ((Location) uri range) + (collect (eglot--xref-make (symbol-at-point) uri range))) + (jsonrpc-request + (eglot--current-server-or-lose) method (append + (eglot--TextDocumentPositionParams) + extra-params))))) (cl-defun eglot--lsp-xref-helper (method &key extra-params capability ) "Helper for `eglot-find-declaration' & friends." @@ -1829,13 +1830,13 @@ Try to visit the target file for a richer summary line." (cl-defmethod xref-backend-apropos ((_backend (eql eglot)) pattern) (when (eglot--server-capable :workspaceSymbolProvider) (eglot--collecting-xrefs (collect) - (mapc - (eglot--lambda ((SymbolInformation) name location) - (eglot--dbind ((Location) uri range) location - (collect (eglot--xref-make name uri range)))) - (jsonrpc-request (eglot--current-server-or-lose) - :workspace/symbol - `(:query ,pattern)))))) + (mapc + (eglot--lambda ((SymbolInformation) name location) + (eglot--dbind ((Location) uri range) location + (collect (eglot--xref-make name uri range)))) + (jsonrpc-request (eglot--current-server-or-lose) + :workspace/symbol + `(:query ,pattern)))))) (defun eglot-format-buffer () "Format contents of current buffer." -- 2.39.2