]> git.eshelyaron.com Git - emacs.git/log
emacs.git
5 years ago* eglot.el (version): bump to 1.5
João Távora [Sun, 20 Oct 2019 11:56:41 +0000 (12:56 +0100)]
* eglot.el (version): bump to 1.5

* NEWS.md: update.

5 years agoLet user keep control of some variables during eglot sessions
João Távora [Sat, 19 Oct 2019 22:07:47 +0000 (23:07 +0100)]
Let user keep control of some variables during eglot sessions

* NEWS.md: Mention new variable eglot-stay-out-of

* eglot.el (eglot-stay-out-of): New variable.
(eglot--setq-saving): Use it.
(eglot--managed-mode): Use eglot--setq-saving for imenu.  No need
to remove 'eglot-flymake-backend from diagnostic functions.

GitHub-reference: fix https://github.com/joaotavora/eglot/issues/324

5 years agoDon't immediately request completions in eglot-completion-at-point
João Távora [Fri, 18 Oct 2019 15:43:50 +0000 (16:43 +0100)]
Don't immediately request completions in eglot-completion-at-point

Yet another adjustment to this function.  According to the
documentation of completion-at-point-functions, we should strive to
make functions like eglot-completion-at-point "cheap to run".
Requesting completion from the server immediately after calling the
function goes against that.  The reason we were doing it is that it
might have helped compute more accurate "bounds" for the return value
(START and END) from possible TextEdit completion items.  But I've
decided it's not worth the effort, at least for now.

* eglot.el (eglot-completion-at-point): Request completions
asynchronously.

5 years agoProtect against zero-length completions
João Távora [Wed, 16 Oct 2019 22:13:09 +0000 (23:13 +0100)]
Protect against zero-length completions

Apparently the Vue Language Server sends such things (see https://github.com/joaotavora/eglot/issues/319).

* eglot.el (eglot-completion-at-point): Protect against
zero-length completions.

5 years agoDon't choke on single-location reply to td/definition
João Távora [Wed, 16 Oct 2019 18:25:51 +0000 (19:25 +0100)]
Don't choke on single-location reply to td/definition

* eglot.el (eglot--lsp-xrefs-for-method): Accept non-vector
Location.

GitHub-reference: fix https://github.com/joaotavora/eglot/issues/321

5 years agoUnbreak eglot--setq-saving if symbol is unbound
João Távora [Wed, 16 Oct 2019 15:46:03 +0000 (16:46 +0100)]
Unbreak eglot--setq-saving if symbol is unbound

* eglot.el (eglot--setq-saving): check if symbol is bound

5 years agoUse of company-capf backend in eglot-managed buffers
João Távora [Wed, 16 Oct 2019 15:29:41 +0000 (16:29 +0100)]
Use of company-capf backend in eglot-managed buffers

* eglot.el (company-backends): forward-declare
(eglot--managed-mode): Force company-backends to company-capf

5 years agoPlay along with lsp's filtertext hacks
João Távora [Wed, 16 Oct 2019 13:16:52 +0000 (14:16 +0100)]
Play along with lsp's filtertext hacks

Reworked important parts of eglot-completion-at-point.

One of the tasks was to cleanup the nomenclature so it's easier to
spot how LSP and Emacs's views of completion techniques differ.  When
reading this rather long function, remember an "item" is a plist
representing the LSP completionItem object, and "proxy" is a
propertized string that Emacs's frontends will use to represent that
completion.  When the completion is close to done, the :exit-function
is called, to potentially rework the inserted text so that the final
result might be quite different from the proxy (it might be a snippet,
or even a suprising text edit).

The most important change in this commit reworks the way the
completion "bounds" are calculated in the buffer.  This is the region
that Emacs needs to know that is being targeted for the completion.  A
server can specify this region by using textEdit-based completions all
consistently pointing to the same range.  If it does so, Emacs will
use that region instead of its own understanding of symbol
boundaries (provided by thingatpt.el and syntax tables).

To implement server-side completion filtering, the server can also
provide a filterText "cookie" in each completion, which, when
prefix-matched to the intended region, selects or rejects the
completion.  Given the feedback in
https://github.com/microsoft/language-server-protocol/issues/651, we
have no choice but to play along with that inneficient and grotesque
strategy to implement flex-style matching.  Like ever in LSP, we do so
while being backward-compatible to all previously supported behaviour.

* eglot.el (eglot-completion-at-point): rework.

GitHub-reference: close https://github.com/joaotavora/eglot/issues/235

5 years agoAlways filter completions client-side by prefix
João Távora [Wed, 16 Oct 2019 08:49:09 +0000 (09:49 +0100)]
Always filter completions client-side by prefix

Prefix completion is all we get in LSP because there are some servers
that send *all* completions everytime.  This is horrible, but it's the
currently defined behaviour.  See
https://github.com/microsoft/language-server-protocol/issues/651.

* eglot.el (eglot-completion-at-point): Use all-completions.

GitHub-reference: per https://github.com/joaotavora/eglot/issues/319

5 years agoFix bug in workspace/didchangewatchedfiles
João Távora [Tue, 15 Oct 2019 17:42:33 +0000 (18:42 +0100)]
Fix bug in workspace/didchangewatchedfiles

* eglot.el (eglot-register-capability): Fix a bug and a couple of
warnings.

5 years agoAdd support for the ada language server
Tom Tromey [Tue, 15 Oct 2019 16:32:57 +0000 (10:32 -0600)]
Add support for the ada language server

* eglot.el (eglot-server-programs): Add ada-mode entry.

* README.md (Connecting to a server): Add Ada entry.

GitHub-reference: close https://github.com/joaotavora/eglot/issues/316

5 years agoFix eglot-completion-at-point to work with bare completion-at-point
João Távora [Sat, 12 Oct 2019 00:57:00 +0000 (01:57 +0100)]
Fix eglot-completion-at-point to work with bare completion-at-point

Fixes https://github.com/joaotavora/eglot/issues/313, fixes https://github.com/joaotavora/eglot/issues/311, fixes https://github.com/joaotavora/eglot/issues/279

As is well known, LSP's and Emacs's completion mechanics don't fit
very well together, mostly because Emacs expects completion to be a
something of a pure function of a string argument and LSP treats as a
function of a concrete buffer position.

A further complication arises because some completion frontends like
"bare" completion-at-point make Emacs modify the buffer's contents
during the completion process, while other (notably company-mode)
don't do that.  Thus, 'eglot-completion-at-point' must take extra care
to answer to the questions listed in the "(elisp)Programmed
Completion" info node based on its (quite hacky) "completions" local
var and _not_ based on the intermediate buffer contents.  That var is
also used to cache the last LSP response and allow the :exit-function
callback to retrieve much more than just the completion text in

In yet another related problem, :exit-function won't be called at all
with completion-at-point if the completion table doesn't answer
properly to test-completion.  A previous use of
completion-table-dynamic was found to be unsuitable here: we must
answer all the requests separately.

* eglot.el (eglot-completion-at-point): Rework.

5 years agoUnbreak xref-find-definitions
João Távora [Sun, 13 Oct 2019 21:32:52 +0000 (22:32 +0100)]
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

5 years agoMisc improvements to the xref glue code
João Távora [Wed, 9 Oct 2019 18:30:27 +0000 (19:30 +0100)]
Misc improvements to the xref glue code

* eglot.el (eglot-xref-backend): Don't check capability here.
(eglot--collecting-xrefs): Reworked from  eglot--handling-xrefs.
(eglot--handling-xrefs): Remove.
(xref-backend-apropos, eglot--lsp-xrefs-for-method): Use eglot--collecting-xrefs.

5 years agoRework and correct major part of xref glue code
João Távora [Sun, 6 Oct 2019 15:10:33 +0000 (16:10 +0100)]
Rework and correct major part of xref glue code

See comments of https://github.com/joaotavora/eglot/pull/314.  Up to
now, xref-backend-indentifier-completion-table was a gross hack that
only worked sometimes.  It relied on some fugly gymnastics to cache a
response from :textDocument/documentSymbol and somehow used that
information to build a completion table.  But it doesn't work well.

Summarily, LSP doesn't lend itself well to the xref interface of
prompting for an arbitrary identifier and then go look for whichever
type of references of that identifier.  All the LSP
:textDocument/{definition,references,implementation,...} methods
expect to know the exact context of the search the user is about to
perform, in the form of a document location.  That conflicts with the
xref "arbitrary string" requirement.

Therefore, the slightly limited, but much more correct way, for Eglot
to function is to override the user's preference of
xref-prompt-for-identifier, temporarily setting it to nil in
eglot--managed-mode (ideally, though, xref-prompt-for-identifier
should be a function of the backend.)

Later on, a possibly better behaved identifier completion table can be
built on top of the :workspace/symbol LSP method.

* eglot.el (xref-backend-identifier-at-point): Rewrite.
(eglot--lsp-xrefs-for-method): New helper.
(eglot--lsp-xref-helper): Use eglot--lsp-xrefs-for-method.
(eglot--xref-definitions-method): Delete.
(eglot--lsp-xref-refs): New variable.
(xref-backend-references, xref-backend-definitions): Use
eglot--lsp-xrefs-for-method.
(eglot--managed-mode): Set xref-prompt-for-identifier
to nil.
(eglot--xref-reset-known-symbols, eglot--xref-known-symbols): Delete
(xref-backend-identifier-completion-table): Nullify.
(eglot-find-declaration, eglot-find-implementation)
(eglot-find-typeDefinition): Use eglot--lsp-xref-helper.

5 years agoSupport goto-{declaration, implementation, typedefinition}
Felicián Németh [Thu, 3 Oct 2019 19:11:18 +0000 (21:11 +0200)]
Support goto-{declaration, implementation, typedefinition}

Closes https://github.com/joaotavora/eglot/issues/302.

* eglot.el (eglot--xref-definitions-method): New variable.
(xref-backend-definitions): Use it.
(eglot-find-declaration, eglot-find-implementation,
eglot-find-typeDefinition): New functions.

* README.md (Language features): Add new capabilities.

* eglot.el (eglot-client-capabilities): Add new capabilities.
(eglot-ignored-server-capabilites): Add new capability.

5 years agoAllow user to set idle time to wait before processing changes
ambihelical [Sat, 11 May 2019 18:41:52 +0000 (11:41 -0700)]
Allow user to set idle time to wait before processing changes

* eglot.el (eglot-send-changes-idle-time): New defcustom.
(eglot--after-change): Use it.

Co-authored-by: João Távora <joaotavora@gmail.com>
Copyright-paperwork-exempt: yes
GitHub-reference: fix https://github.com/joaotavora/eglot/issues/258

5 years agoMuch less noisy mode line
João Távora [Sat, 5 Oct 2019 11:32:23 +0000 (12:32 +0100)]
Much less noisy mode line

* eglot.el (eglot--mode-line-format): Simplify.

GitHub-reference: fix https://github.com/joaotavora/eglot/issues/236

5 years agoUnbreak elm language server which does use :triggercharacters
João Távora [Mon, 30 Sep 2019 16:06:48 +0000 (18:06 +0200)]
Unbreak elm language server which does use :triggercharacters

Only query completionProvider -> triggerCharacter information if the
server has provided it.  Elm's, and probaly other's, do not provide
it, which doesn't mean they don't support completion.

* eglot.el (eglot-completion-at-point): Check that completion
capability is a list before treating it like one.

GitHub-reference: fix https://github.com/joaotavora/eglot/issues/285

5 years agoRevert "treat null/nil server capabilities as false"
João Távora [Sat, 5 Oct 2019 10:46:08 +0000 (11:46 +0100)]
Revert "treat null/nil server capabilities as false"

This reverts commit 645bcfc6e57181c39dae1f238758e76c1759a765.

A capability of "null" is downright invalid, and must NOT be mistaken
for a value of "{}" (which indicates the presence of the capability)
or "False" (which indicates its asence).  See
https://github.com/microsoft/language-server-protocol/issues/830#issuecomment-537849292
for a clarification from the LSP maintainer.

5 years agoDon't send dummy json object in "initialized" notification ()
Vladimir Panteleev [Fri, 4 Oct 2019 10:13:32 +0000 (10:13 +0000)]
Don't send dummy json object in "initialized" notification ()

Eglot uses a JSON object { __dummy__ : true } as a placeholder instead
of the empty object {}.  It does this out of necessity, since encoding
an empty object can't currently be easily using the current jsonrpc.el
library.  However, this also causes the parameter to be actually sent
to the server.

Since the JSON-RPC specification states "The names MUST match exactly,
including case, to the method's expected parameters" this is
non-conforming to the protocol.

The LSP specification does not seem to indicate how servers should
handle method calls with parameters they do not support.  As such,
ignoring the parameter, or reporting an error, or crashing all seem to
be "valid" behaviors as far as the specification is concerned.

We can avoid this by using an empty hash table instead of a dummy
parameter.  Currently, an empty hash table is the only Emacs Lisp
object which jsonrpc.el serializes to an empty JSON object in
jsonrpc--json-encode.

* eglot.el (eglot--connect): Use make-hash-table instead of dummy
  object.

Copyright-paperwork-exempt: yes
GitHub-reference: https://github.com/joaotavora/eglot/issues/312

5 years agoOptionally shutdown after killing last buffer of managed project ()
Ingo Lohmar [Wed, 2 Oct 2019 16:05:15 +0000 (18:05 +0200)]
Optionally shutdown after killing last buffer of managed project ()

This should close issue https://github.com/joaotavora/eglot/issues/217, also cf. https://github.com/joaotavora/eglot/issues/270.

* eglot.el (eglot-autoshutdown): New defcustom.
(eglot--managed-mode-onoff): Shutdown if so configured and
no managed buffers left.

Co-authored-by: João Távora <joaotavora@gmail.com>
GitHub-reference: https://github.com/joaotavora/eglot/issues/309

5 years agoOn buffer kill, first send didclose then teardown local structures
Ingo Lohmar [Wed, 2 Oct 2019 16:03:48 +0000 (18:03 +0200)]
On buffer kill, first send didclose then teardown local structures

It used to be the reverse way around, which doesn't make sense.

* eglot.el (eglot-managed-mode): Fix order in `kill-buffer-hook'

Co-authored-by: João Távora <joaotavora@gmail.com>
5 years agoAlso use signature label offsets for parameter info
galeo [Thu, 26 Sep 2019 12:04:13 +0000 (20:04 +0800)]
Also use signature label offsets for parameter info

According to the LSP specification, a parameter of a callable-signature
has a label and a optional doc-commet. The label of a parameter
information is either a string or an inclusive start and exclusive end
offsets within its containing signature label.

Previously, this was only taken in account for highlighting the
parameter in the definition signature.

* eglot.el (eglot--sig-info): Handle signature label offsets
  when printing the signature parameter information.

Copyright-paperwork-exempt: yes
GitHub-reference: fix https://github.com/joaotavora/eglot/issues/272

5 years agoMerge pull request from jorams/nil-capabilities-as-false
Felicián Németh [Tue, 24 Sep 2019 15:47:58 +0000 (17:47 +0200)]
Merge pull request from jorams/nil-capabilities-as-false

Treat null/nil server capabilities as false

GitHub-reference: https://github.com/joaotavora/eglot/issues/298

5 years agoUse gopls server as the default for go ()
Ingo Lohmar [Mon, 23 Sep 2019 18:05:55 +0000 (20:05 +0200)]
Use gopls server as the default for go ()

Developers recommend it: see
https://github.com/sourcegraph/go-langserver/blob/master/README.md

* eglot (eglot-server-programs): Use gopls.

* README.md: mention gopls instead of go-langserver.

GitHub-reference: https://github.com/joaotavora/eglot/issues/304

5 years agoTreat null/nil server capabilities as false
Joram Schrijver [Fri, 13 Sep 2019 09:48:10 +0000 (11:48 +0200)]
Treat null/nil server capabilities as false

Some language servers may specify null for some capabilities in the list
of server capabilities. This does not conform to the specification, but
treating it as false is more reasonable than treating it as true.

A current example is the PHP language server. which specifies null for
every capability it does not handle, like documentHighlightProvider.
This would cause Eglot to send constant textDocument/documentHighlight
requests, which all timed out.

* eglot.el (eglot--server-capable): Change the handling of null values
  for capabilities to treat them as false instead of true.

Copyright-paperwork-exempt: yes

5 years agoChange the default of eglot-move-to-column-function
Felicián Németh [Tue, 10 Sep 2019 13:31:16 +0000 (15:31 +0200)]
Change the default of eglot-move-to-column-function

Previous default (move-to-column) works on visual columns, the LSP
specification and the new default (eglot-move-to-column) use "real"
columns.  Fixes https://github.com/joaotavora/eglot/issues/293 and https://github.com/joaotavora/eglot/issues/297.

* eglot.el (eglot-move-to-column): New function.
(eglot-move-to-column-function): Use it as default.

5 years agoRequire array package to use current-line ()
David Florness [Mon, 19 Aug 2019 00:09:13 +0000 (18:09 -0600)]
Require array package to use current-line ()

The jsonrpc package (one of eglot's dependencies) recently
updated and removed the line requiring the array package. Since
current-line is provided by array and is used by eglot, require
array explicitly.

Here's jsonrpc's guilty commit:

https://git.savannah.gnu.org/cgit/emacs.git/commit/lisp/jsonrpc.el?id=c676444a43e4634c1f98ec286b5bd9e46b23216b

Copyright-paperwork-exempt: Yes

* eglot.el (array): Require it.

GitHub-reference: https://github.com/joaotavora/eglot/issues/294

5 years agoExpand directory watcher globs containing ** ()
Jürgen Hötzel [Mon, 12 Aug 2019 20:13:47 +0000 (22:13 +0200)]
Expand directory watcher globs containing ** ()

Previously, if the server requested a glob pattern like foo/**/*
to be watched, we would just error.  Now we watch foo/bar/ and
foo/baz/ as if the server had requested those two watchers
instead of just the one with the **.

As a limitation, the implementation of file-expand-wildcards
doesn't fully handle ** globstars (** matches at most one path
segment).

* eglot.el (eglot-register-capability workspace/didChangeWatchedFiles):
Use file-expand-wildcards to make a ** glob into multiple **-less
globs.

GitHub-reference: https://github.com/joaotavora/eglot/issues/293

5 years agoFix invalid guess for php language server ()
Jürgen Hötzel [Thu, 18 Jul 2019 19:36:56 +0000 (21:36 +0200)]
Fix invalid guess for php language server ()

* eglot.el (eglot-server-programs): Change the position of the php
language server, otherwise it will always be hidden by the c-mode
server (php-mode is derived from c-mode).

Copyright-paperwork-exempt: yes
GitHub-reference: https://github.com/joaotavora/eglot/issues/288

5 years agoFix a typo
haqle314 [Tue, 2 Jul 2019 21:58:41 +0000 (16:58 -0500)]
Fix a typo

* eglot.el (eglot--lsp-position-to-point): fix eglot--warn
call

Copyright-paperwork-exempt: yes
GitHub-reference: fix https://github.com/joaotavora/eglot/issues/273

5 years agoSimplify eldoc usage ()
Ingo Lohmar [Thu, 27 Jun 2019 16:56:45 +0000 (18:56 +0200)]
Simplify eldoc usage ()

* eglot-tests.el (hover-after-completions): Protect test.  Rewrite
docstring.

* eglot.el (eglot--managed-mode): Don't mess with eldoc-message-function.
(eglot--eldoc-hint): Remove.
(eglot--update-doc): Rename and rewrite from eglot--eldoc-message.
(eglot-eldoc-function): Don't set eglot--eldoc-hint.
Call eglot--update-doc.

GitHub-reference: https://github.com/joaotavora/eglot/issues/269

5 years agoLeniently handle invalid positions sent by some servers
João Távora [Thu, 27 Jun 2019 16:55:05 +0000 (17:55 +0100)]
Leniently handle invalid positions sent by some servers

* eglot.el (eglot--lsp-position-to-point): Leniently squash
invalid character positions to 0.

GitHub-reference: fix https://github.com/joaotavora/eglot/issues/273

5 years agoAdd built-in support for elixir's elixir-ls ()
Akash Hiremath [Sun, 12 May 2019 10:47:37 +0000 (16:17 +0530)]
Add built-in support for elixir's elixir-ls ()

* README.md: add elixir-ls.

* eglot.el (eglot-server-programs): add elixir-ls.

Copyright-paperwork-exempt: yes
GitHub-reference: https://github.com/joaotavora/eglot/issues/264

5 years agoWork around a bug in emacs's change detection
João Távora [Thu, 9 May 2019 10:38:58 +0000 (11:38 +0100)]
Work around a bug in emacs's change detection

When using capitalize-word, or any case-fiddling function,
before-change-functions will record e.g. the whole word's start and
end, even though only the first character has changed.  Not only is
this longer than needed but also conflicts with what we get in
after-change-functions, which records just the one-char-long change.

Also, if the word didn't need any fiddling at all then
before-change-function will run but after-change-functions won't: an
"orphan" before-change will erroneously be sent to the server.

* eglot.el (eglot--after-change): Detect problematic case and fix
change description.
(eglot--before-change): Store markers of changed region.
(eglot--signal-textDocument/didChange): Weed out orphan changes.

GitHub-reference: fix https://github.com/joaotavora/eglot/issues/259

5 years agoFix case when eglot-put-doc-in-help-buffer is nil
João Távora [Thu, 9 May 2019 18:49:31 +0000 (19:49 +0100)]
Fix case when eglot-put-doc-in-help-buffer is nil

* eglot.el (eglot--eldoc-message): Check eglot-put-doc-in-help-buffer.

GitHub-reference: fix https://github.com/joaotavora/eglot/issues/263

5 years agoOnly consider eglot's own diagnostics in eglot-code-actions
Michal Krzywkowski [Wed, 8 May 2019 11:33:34 +0000 (13:33 +0200)]
Only consider eglot's own diagnostics in eglot-code-actions

* eglot.el (eglot-code-actions): Filter out non-eglot diagnostics
  before sending a request to the server.

GitHub-reference: fix https://github.com/joaotavora/eglot/issues/260

5 years agoFix local function call in directory watcher ()
vjoki [Tue, 30 Apr 2019 09:35:24 +0000 (12:35 +0300)]
Fix local function call in directory watcher ()

Copyright-paperwork-exempt: yes

* eglot.el (eglot-register-capability
workspace/didChangeWatchFiles): fix call to handle-event.

GitHub-reference: https://github.com/joaotavora/eglot/issues/255

5 years agoUnbreak build
João Távora [Wed, 13 Feb 2019 09:24:02 +0000 (09:24 +0000)]
Unbreak build

Messed up the name of eglot-xref-lessp-function.

* eglot.el (eglot--handling-xrefs): Use eglot-xref-lessp-function

GitHub-reference: per https://github.com/joaotavora/eglot/issues/220

5 years ago* eglot.el (xref-backend-references): don't use return-from.
João Távora [Mon, 11 Feb 2019 21:34:50 +0000 (21:34 +0000)]
* eglot.el (xref-backend-references): don't use return-from.

5 years agoDon't sort xref's by default
João Távora [Mon, 11 Feb 2019 21:33:49 +0000 (21:33 +0000)]
Don't sort xref's by default

But use a eglot-xref-lessp-function in case someone wants to tweak
this.

* eglot.el (eglot-xref-lessp-function): New variable.
(eglot--handling-xrefs): Use it.

GitHub-reference: fix https://github.com/joaotavora/eglot/issues/220

5 years agoUse a less buggy flymake
João Távora [Mon, 11 Feb 2019 21:21:49 +0000 (21:21 +0000)]
Use a less buggy flymake

* eglot.el (Package-Requires) Require flymake 1.0.5

GitHub-reference: fix https://github.com/joaotavora/eglot/issues/223

5 years agoDon't teardown company if started via trigger chars
João Távora [Tue, 5 Feb 2019 21:49:38 +0000 (21:49 +0000)]
Don't teardown company if started via trigger chars

Reported by zhanghj in https://github.com/company-mode/company-mode/issues/866

* eglot.el (eglot-completion-at-point): More carefully calculate
:company-prefix-length

5 years agoConsider mode derivation when guessing servers
João Távora [Mon, 14 Jan 2019 15:31:26 +0000 (15:31 +0000)]
Consider mode derivation when guessing servers

* eglot.el (eglot-server-programs): Remove js2-mode and rjsx-mode.
(eglot--guess-contact): Use provided-mode-derived-p

GitHub-reference: per https://github.com/joaotavora/eglot/issues/177

5 years agoProtect against null messages from eldoc
João Távora [Mon, 14 Jan 2019 14:15:20 +0000 (14:15 +0000)]
Protect against null messages from eldoc

* eglot.el (eglot--eldoc-message): Protect against nil FORMAT.

GitHub-reference: fix https://github.com/joaotavora/eglot/issues/209

5 years agoFix bug introduced by commit fixing this issue
Sergey Kostyaev [Thu, 10 Jan 2019 19:45:30 +0000 (02:45 +0700)]
Fix bug introduced by commit fixing this issue

* eglot.el (eglot--sig-info): Protect against invalid label.

GitHub-reference: per https://github.com/joaotavora/eglot/issues/121

5 years agoAdd built-in support for dart's dart_language_server
Brady Trainor [Wed, 26 Dec 2018 00:21:53 +0000 (16:21 -0800)]
Add built-in support for dart's dart_language_server

Closes https://github.com/joaotavora/eglot/issues/194.

Copyright-paperwork-exempt: yes

* README.md (Connecting to a server): Add dart_language_server.

* eglot.el (eglot-server-programs): Add dart_language_server.

5 years agoHandle label offsets in parameterinformation
João Távora [Wed, 9 Jan 2019 21:09:35 +0000 (21:09 +0000)]
Handle label offsets in parameterinformation

At least ccls uses this.

* eglot.el (eglot-client-capabilities): Declare support for
:labelOffsetSupport.
(eglot--sig-info): Handle label offsets in ParameterInformation

GitHub-reference: fix https://github.com/joaotavora/eglot/issues/201

5 years agoDisplay truncated docstring if too large for echo area
João Távora [Mon, 7 Jan 2019 08:44:37 +0000 (08:44 +0000)]
Display truncated docstring if too large for echo area

* eglot.el (eglot--eldoc-message): Display first line doc.

5 years agoRename new defcustoms with friendlier names
João Távora [Sun, 6 Jan 2019 22:14:27 +0000 (22:14 +0000)]
Rename new defcustoms with friendlier names

* eglot.el (eglot-doc-too-large-for-echo-area): Rename from
eglot-eldoc-extra-buffer-if-too-large.
(eglot-put-doc-in-help-buffer): Rename from
eglot-eldoc-extra-buffer.
(eglot-auto-display-help-buffer): Rename from
eglot-auto-display-eldoc-extra-buffer.
(eglot--eldoc-message): Use new variable names.

5 years agoFix test failure introduced by previous commit
João Távora [Sun, 6 Jan 2019 12:55:21 +0000 (12:55 +0000)]
Fix test failure introduced by previous commit

Remove the hack of unsetting eldoc-last-message in
eglot--eldoc-message.  This allows any subsequent eglot-eldoc-function
calls (prompted by simple cursor movement) to return it immediately,
thus refreshing the help buffer with the same contents.  For this to
work, we also have to set eglot--eldoc-hint globally in
eglot-eldoc-function.

An alternative to making the test pass would be to keep the hack of
unsetting eldoc-last-message only in the case that we actually get to
display the help buffer.  This would actually be more efficient, but
potentially more hacky.

The bottom line here is that eldoc doesn't have a good API to deal
with asynchronous docstring fetching.  See this thread:

https://lists.gnu.org/archive/html/emacs-devel/2018-05/msg00151.html

* eglot.el (eglot--eldoc-message): Don't unset eldoc-last-message.
(eglot-eldoc-function): Set eglot--eldoc-hint for synchronous
operation too.

6 years agoShow large docs in help buffer instead of echo are by default
João Távora [Sat, 5 Jan 2019 22:47:43 +0000 (22:47 +0000)]
Show large docs in help buffer instead of echo are by default

* eglot.el (eglot--managed-mode): Add and remove from eglot--eldoc-message
(eglot--eldoc-hint, eglot--help-buffer): New helpers.
(eglot-eldoc-extra-buffer)
(eglot-auto-display-eldoc-extra-buffer): New defcustoms.
(eglot--eldoc-message): New helper.
(eglot-eldoc-function): Set eglot--eldoc-hint.
(eglot-help-at-point): Use new helpers.
(eglot-eldoc-extra-buffer-if-too-large): New predicate.

GitHub-reference: per https://github.com/joaotavora/eglot/issues/198

6 years agoPrevent eldoc flicker when moving around
João Távora [Sat, 5 Jan 2019 14:35:01 +0000 (14:35 +0000)]
Prevent eldoc flicker when moving around

* eglot.el (eglot-eldoc-function): Return eldoc-last-message
immediately.

GitHub-reference: fix https://github.com/joaotavora/eglot/issues/198

6 years agoHandle (un)registercapability requests via generic functions
João Távora [Sat, 5 Jan 2019 13:32:13 +0000 (13:32 +0000)]
Handle (un)registercapability requests via generic functions

* eglot.el (Version): Bump to 1.4
(eglot-register-capability, eglot-unregister-capability): New
generic functions.
(eglot--register-unregister): Call eglot-register-capability,
eglot-unregister-capability.
(eglot-register-capability s (eql
workspace/didChangeWatchedFiles)): Rename from
eglot--register-workspace/didChangeWatchedFiles.
(eglot-unregister-capability s (eql
workspace/didChangeWatchedFiles)): Rename from
eglot--unregister-workspace/didChangeWatchedFiles.

6 years agoAppease checkdoc
João Távora [Sat, 5 Jan 2019 13:03:01 +0000 (13:03 +0000)]
Appease checkdoc

* eglot.el (eglot--post-self-insert-hook)
(eglot--pre-command-hook, eglot--before-change)
(eglot--eclipse-jdt-contact): Fix docstrings.

6 years ago* eglot.el (eglot-workspace-configuration): safe when listp.
João Távora [Wed, 2 Jan 2019 20:34:09 +0000 (20:34 +0000)]
* eglot.el (eglot-workspace-configuration): safe when listp.

6 years agoRun connection hooks with proper dir-locals
João Távora [Wed, 2 Jan 2019 17:12:36 +0000 (17:12 +0000)]
Run connection hooks with proper dir-locals

eglot-connect-hook and eglot-server-initialized-hook must run in a
buffer with properly setup directory-local variables for the project.

This is crucial for things like eglot-signal-didChangeConfiguration,
which needs a properly setup value of eglot-workspace-configuration to
succeed.

I could have chosen any of the buffers where Eglot is activating
itself, but the approach using
hack-dir-local-variables-non-file-buffer seems more correct, despite
the name.

* eglot.el (eglot--connect): Run connection hooks with proper
dir-locals.

GitHub-reference: fix https://github.com/joaotavora/eglot/issues/196

6 years agoAllow read-only modes for markup rendering
João Távora [Tue, 1 Jan 2019 14:56:46 +0000 (14:56 +0000)]
Allow read-only modes for markup rendering

gfm-mode is read-only, so it must be set after the string has been
inserted in the temporary buffer.

* eglot.el (eglot--format-markup): Insert string before setting
mode.

GitHub-reference: close https://github.com/joaotavora/eglot/issues/197

6 years agoRemove a hard dependency on flymake-mode
João Távora [Thu, 27 Dec 2018 18:31:42 +0000 (18:31 +0000)]
Remove a hard dependency on flymake-mode

* eglot.el (eglot-handle-notification): Don't specifically check for
flymake-mode before reporting diagnostics.

GitHub-reference: close https://github.com/joaotavora/eglot/issues/195

6 years agoSlightly simplify eglot-completion-at-point
João Távora [Sun, 23 Dec 2018 14:01:38 +0000 (14:01 +0000)]
Slightly simplify eglot-completion-at-point

* eglot.el (eglot-completion-at-point): Don't propertize
completion string with all LSP properties.

6 years agoActually make completion sorting work
João Távora [Sat, 22 Dec 2018 15:23:41 +0000 (15:23 +0000)]
Actually make completion sorting work

* eglot.el (eglot-completion-at-point): Complicate severely.

GitHub-reference: fix https://github.com/joaotavora/eglot/issues/190

6 years agoFix previous commit where workaround had been removed
João Távora [Sat, 22 Dec 2018 15:27:27 +0000 (15:27 +0000)]
Fix previous commit where workaround had been removed

Do remove the workaround, but not more than that.

* eglot.el (eglot-completion-at-point): set local var strings.

6 years agoUse gfm-view-mode
João Távora [Sat, 22 Dec 2018 15:18:55 +0000 (15:18 +0000)]
Use gfm-view-mode

* eglot.el (eglot--format-markup): Use gfm-view-mode instead of gfm-mode.

GitHub-reference: per https://github.com/joaotavora/eglot/issues/188

6 years agoRemove workaround for company bug that has been fixed
João Távora [Sat, 22 Dec 2018 15:17:41 +0000 (15:17 +0000)]
Remove workaround for company bug that has been fixed

See https://github.com/company-mode/company-mode/pull/845.

* eglot.el (eglot-completion-at-point): Remove workaround for
company-mode bug.

6 years ago* eglot.el (package-requires): require jsonrpc 1.0.7.
João Távora [Wed, 19 Dec 2018 21:57:00 +0000 (21:57 +0000)]
* eglot.el (package-requires): require jsonrpc 1.0.7.

6 years agoTake over flymake and eldoc completely while managing buffers
João Távora [Sun, 16 Dec 2018 19:03:06 +0000 (19:03 +0000)]
Take over flymake and eldoc completely while managing buffers

Take a pragmatic approach and override all other Flymake and Eglot
backends while Eglot is enabled.  Restore previous values after
eglot-shutdown.

Certainly cases might arise where using more than one datasource
besides LSP while Eglot is managing the buffer is useful.  But
currently contrary, it confuses users enabling Eglot in buffers that
already have flymake/eldoc backends configured.

The reasons are slightly different for Eldoc and Flymake:

- For Eldoc the :before-until strategy only makes sense for
  synchronous backends, which Eglot isn't.  This conflicts with
  python.el default python-eldoc-function, which is also asynchronous.

- For Flymake, the default backends in Emacs (python-mode, c-mode, and
  a few others) are mainly repetitions of what LSP does.  The global
  value is still run though (in case you want to put, say, a
  spell-checking backend there).

* eglot.el (eglot--saved-bindings, eglot--setq-saving): New
helpers.
(eglot--managed-mode): Use them.

6 years agoBe more careful when making xref summaries
João Távora [Sun, 16 Dec 2018 14:33:14 +0000 (14:33 +0000)]
Be more careful when making xref summaries

* eglot.el (eglot--xref-make): Only highlight to end-of-line at
most.

GitHub-reference: fix https://github.com/joaotavora/eglot/issues/187

6 years agoDon't make bogus responses to client/(un)registercapability
João Távora [Sun, 16 Dec 2018 14:22:57 +0000 (14:22 +0000)]
Don't make bogus responses to client/(un)registercapability

* eglot.el (eglot--register-unregister): Response is void.

6 years agoAdd edebug specs to destructuring macros
João Távora [Sun, 16 Dec 2018 13:51:14 +0000 (13:51 +0000)]
Add edebug specs to destructuring macros

* eglot.el (eglot--dbind, eglot--lambda, eglot--dcase): Add edebug
specs.

6 years agoRewrite eglot--sig-info a bit for readability
João Távora [Sun, 16 Dec 2018 13:48:57 +0000 (13:48 +0000)]
Rewrite eglot--sig-info a bit for readability

* eglot.el (eglot--sig-info): Rewrite a bit.

6 years agoAdjust active param highlighting in first line of signature (3/3)
Fredrik Bergroth [Thu, 13 Dec 2018 12:03:42 +0000 (13:03 +0100)]
Adjust active param highlighting in first line of signature (3/3)

Highlight only first active parameter match (even if there are many)

Copyright-paperwork-exempt: yes

* eglot.el (eglot--sig-info): Simplify.

6 years agoAdjust active param highlighting in first line of signature (2/3)
Fredrik Bergroth [Thu, 13 Dec 2018 12:02:15 +0000 (13:02 +0100)]
Adjust active param highlighting in first line of signature (2/3)

Use regex with word boundaries when scanning for active param, to
avoid matching substrings.

Copyright-paperwork-exempt: yes

* eglot.el (eglot--sig-info): Use `re-search-forward`.

6 years agoAdjust active param highlighting in first line of signature (1/3)
Fredrik Bergroth [Thu, 13 Dec 2018 11:59:57 +0000 (12:59 +0100)]
Adjust active param highlighting in first line of signature (1/3)

JT@2018/12/16: Previously, the whole first line of the rendered
documentation was searched for, potentially highlighting params
in the wrong place.

Copyright-paperwork-exempt: yes

* eglot.el (eglot--sig-info): Search for active parameter within
`params-start` and `params-end`.

6 years agoApply eglot--format-markup to signature documentation
Fredrik Bergroth [Thu, 13 Dec 2018 11:55:28 +0000 (12:55 +0100)]
Apply eglot--format-markup to signature documentation

Copyright-paperwork-exempt: yes

* eglot.el (eglot--sig-info): Call eglot--format-markup on signature
  documentation.

6 years ago* eglot.el (version): bump to 1.3
João Távora [Mon, 10 Dec 2018 00:10:57 +0000 (00:10 +0000)]
* eglot.el (version): bump to 1.3

6 years agoBe lenient by default to unknown methods or notifications
João Távora [Fri, 7 Dec 2018 22:51:40 +0000 (22:51 +0000)]
Be lenient by default to unknown methods or notifications

* eglot.el (eglot-strict-mode): Describe meaning of
disallow-non-standard-keys.
(eglot-handle-notification, eglot-handle-request): Check
eglot-strict-mode.

6 years agoHandle array params to server notification or requests
João Távora [Fri, 7 Dec 2018 22:43:13 +0000 (22:43 +0000)]
Handle array params to server notification or requests

* eglot.el (eglot-handle-notification): Remove extraneous id
(eglot--connect): If params is an array, make it a list.

6 years agoScratch/use elpa flymake ()
João Távora [Fri, 7 Dec 2018 14:46:23 +0000 (14:46 +0000)]
Scratch/use elpa flymake ()

Use GNU ELPA's Flymake

* eglot.el (Package-Requires): require Flymake 1.0.2.
(version< emacs-version "27.0"): Remove horrible hack

* Makefile (ELPADEPS): Renamed from JSONRPC.
(%.elc): Use it.
(eglot-check): Use it.

GitHub-reference: https://github.com/joaotavora/eglot/issues/178

6 years agoWarn about suspicious interface usage at compile-time
João Távora [Thu, 6 Dec 2018 18:26:17 +0000 (18:26 +0000)]
Warn about suspicious interface usage at compile-time

For fun, set eglot-strict-mode to '(disallow-non-standard-keys
enforce-required-keys enforce-optional-keys) when compiling, or just
use flymake-mode in eglot.el.

* eglot.el (eglot--lsp-interface-alist): Use in compile-time.
Order alphabetically.  Fix a few bugs.
(eglot-strict-mode): Disallow non-standard-keys when compiling.
Update docstring.
(eglot--keywordize-vars, eglot--check-interface): New
compile-time-helpers.
(eglot--dbind, eglot--dcase): Use new helpers.

6 years agoUse eglot--dbind and eglot--lambda throughout
João Távora [Wed, 5 Dec 2018 19:54:55 +0000 (19:54 +0000)]
Use eglot--dbind and eglot--lambda throughout

The default behaviour of these macros is to be lenient towards servers
sending unknown keys, which should fix the issue.

* eglot.el (eglot--lsp-interface-alist): Add a bunch of new interfaces.
(eglot--connect, eglot-handle-notification)
(xref-backend-identifier-completion-table)
(xref-backend-definitions, xref-backend-apropos)
(xref-backend-references, eglot-completion-at-point)
(eglot--sig-info, eglot-help-at-point, eglot-eldoc-function)
(eglot-imenu, eglot--apply-text-edits)
(eglot--apply-workspace-edit)
(eglot--register-workspace/didChangeWatchedFiles): Use
eglot--dbind and eglot--lambda to destructure LSP objects.

GitHub-reference: fix https://github.com/joaotavora/eglot/issues/144

6 years agoAdjust previous fix
João Távora [Tue, 4 Dec 2018 23:10:35 +0000 (23:10 +0000)]
Adjust previous fix

* eglot.el (eglot--before-change): Don't reset
eglot--last-inserted-char here.
(eglot--pre-command-hook): Do it here.
(eglot--managed-mode): Add/remove eglot--pre-command-hook to/from
pre-command-hook.

GitHub-reference: per https://github.com/joaotavora/eglot/issues/173

6 years agoFix bug introduced by previous fix
João Távora [Tue, 4 Dec 2018 09:47:36 +0000 (09:47 +0000)]
Fix bug introduced by previous fix

* eglot.el (eglot--CompletionParams): Don't use last-input-event.

GitHub-reference: per https://github.com/joaotavora/eglot/issues/173

6 years agoHandle codeaction/command polymorphism with eglot--dcase
João Távora [Mon, 3 Dec 2018 14:07:21 +0000 (14:07 +0000)]
Handle codeaction/command polymorphism with eglot--dcase

* eglot-tests.el (eglot-dcase): Augment test.

* eglot.el (eglot--lsp-interface-alist): Add Command interface.
(eglot--dcase): Fix indentation.  When given interface, always
assume strict mode.
(eglot-code-actions): Use eglot--dcase.

GitHub-reference: fix https://github.com/joaotavora/eglot/issues/164

6 years agoRobustify previous fix against non-standard insertion bindings
João Távora [Mon, 3 Dec 2018 12:24:26 +0000 (12:24 +0000)]
Robustify previous fix against non-standard insertion bindings

* eglot.el (eglot--managed-mode): Manage post-self-insert-hook.
(eglot--last-inserted-char): New variable.
(eglot--post-self-insert-hook): Set it.
(eglot--before-change): Reset it.
(eglot--CompletionParams): Use it.

GitHub-reference: per https://github.com/joaotavora/eglot/issues/173

6 years agoProperly clear old diagnostics when making new ones
Michal Krzywkowski [Mon, 3 Dec 2018 11:49:34 +0000 (12:49 +0100)]
Properly clear old diagnostics when making new ones

* eglot.el (eglot-handle-notification
  textDocument/publishDiagnostics): Call flymake report function with
  :region.

GitHub-reference: fix https://github.com/joaotavora/eglot/issues/159

6 years agoUse javascript-typescript-langserver for typescript-mode ()
Mario Rodas [Sun, 2 Dec 2018 19:16:58 +0000 (14:16 -0500)]
Use javascript-typescript-langserver for typescript-mode ()

Copyright-paperwork-exempt: Yes

* eglot.el (eglot-server-programs): add typescript-mode to
  javascript-typescript-langserver's contact

GitHub-reference: https://github.com/joaotavora/eglot/issues/174

6 years agoSupport completioncontext to help servers like ccls
João Távora [Sun, 2 Dec 2018 10:54:09 +0000 (10:54 +0000)]
Support completioncontext to help servers like ccls

* eglot.el (eglot-client-capabilities): Annouce
textDocument/completion/contextSupport.
(eglot--CompletionParams): New helper.
(eglot-completion-at-point): Use it.

GitHub-reference: close https://github.com/joaotavora/eglot/issues/173

6 years agoDon't break in indirect buffers
João Távora [Sat, 1 Dec 2018 22:47:56 +0000 (22:47 +0000)]
Don't break in indirect buffers

Indirect buffers, such as the ones created by ediff-regions-wordwise,
have eglot enabled but not buffer-file-name.  Resort to the finding
the file-name of the original buffer for these.

* eglot.el (eglot--TextDocumentIdentifier): Work in indirect
buffers.

GitHub-reference: fix https://github.com/joaotavora/eglot/issues/116
GitHub-reference: fix https://github.com/joaotavora/eglot/issues/150

6 years agoUse eglot--dbind for destructuring
Michal Krzywkowski [Tue, 27 Nov 2018 22:42:45 +0000 (23:42 +0100)]
Use eglot--dbind for destructuring

* eglot.el (eglot--lsp-interface-alist): Add CodeAction,
  FileSystemWatcher, Registration, TextDocumentEdit, WorkspaceEdit.
(eglot-handle-notification): Use eglot--dbind.
(eglot--apply-workspace-edit): Use eglot--dbind and eglot--lambda.
(eglot-code-actions): Use eglot--lambda.
(eglot--register-workspace/didChangeWatchedFiles): Use eglot--lambda.

6 years agoIntroduce eglot--dcase
João Távora [Thu, 29 Nov 2018 22:36:03 +0000 (22:36 +0000)]
Introduce eglot--dcase

* eglot.el (eglot--dcase): New macro.

* eglot-tests.el (eglot-dcase-with-interface)
(eglot-dcase-no-interface): New tests.

GitHub-reference: per https://github.com/joaotavora/eglot/issues/171
GitHub-reference: per https://github.com/joaotavora/eglot/issues/156

6 years agoSimplify interface of eglot--dbind macro
João Távora [Wed, 28 Nov 2018 20:26:37 +0000 (20:26 +0000)]
Simplify interface of eglot--dbind macro

* eglot.el (eglot--dbind): Use new interface.
(eglot--lambda): Use new eglot--dbind interface.
(eglot--lsp-interface-alist): Fix docstring.
(eglot--call-with-interface): Simplify.
(eglot--plist-keys): New helper.

* eglot-tests.el (eglot-strict-interfaces):
Add a new test clause.

6 years agoTouch up last commit
Michal Krzywkowski [Wed, 28 Nov 2018 18:53:35 +0000 (19:53 +0100)]
Touch up last commit

* eglot.el (eglot-current-column): Rename from eglot--current-column.
(eglot-current-column-function): Use it as value and mention in docstring.
(eglot--xref-make): Use eglot-current-column.

6 years ago* eglot.el (eglot--current-column): new helper.
Michal Krzywkowski [Tue, 27 Nov 2018 22:28:11 +0000 (23:28 +0100)]
* eglot.el (eglot--current-column): new helper.

(eglot-current-column-function): Set to eglot--current-column.
(eglot--pos-to-lsp-position): Don't bind tab-width anymore.
(eglot--xref-make): Use eglot--current-column.

6 years agoImprove performance of xref summary line collection
João Távora [Tue, 27 Nov 2018 13:49:30 +0000 (13:49 +0000)]
Improve performance of xref summary line collection

* eglot.el (eglot--temp-location-buffers): New variable.
(eglot--handling-xrefs): New macro.
(eglot--xref-make): Use eglot--temp-location-buffers.
(xref-backend-definitions, xref-backend-references)
(xref-backend-apropos): Use eglot--handling-xrefs.

GitHub-reference: per https://github.com/joaotavora/eglot/issues/52
GitHub-reference: per https://github.com/joaotavora/eglot/issues/127

6 years agoUse entire line as xref summary when available
João Távora [Tue, 27 Nov 2018 12:42:56 +0000 (12:42 +0000)]
Use entire line as xref summary when available

After an original implementation by Michael Livshin.  Also close https://github.com/joaotavora/eglot/issues/127.

* eglot.el (eglot--xref-make): Rework.
(xref-backend-definitions, xref-backend-references)
(xref-backend-apropos): Simplify call to `eglot--xref-make'.

GitHub-reference: fix https://github.com/joaotavora/eglot/issues/52

6 years agoRevert "codeaction command can be a command object ()"
João Távora [Fri, 23 Nov 2018 18:12:14 +0000 (18:12 +0000)]
Revert "codeaction command can be a command object ()"

This reverts commit 1e7f94d75a30628be56ad00de8c6245f5f3e9fdf.

The spec doesn't define Command as implemented in the commit.

GitHub-reference: fix https://github.com/joaotavora/eglot/issues/164
GitHub-reference: fix https://github.com/joaotavora/eglot/issues/165

6 years agoCodeaction command can be a command object ()
Michal Krzywkowski [Fri, 23 Nov 2018 18:00:00 +0000 (19:00 +0100)]
Codeaction command can be a command object ()

* eglot.el (eglot-code-actions): Handle case when the :command field
  is not a string.

GitHub-reference: fix https://github.com/joaotavora/eglot/issues/164
GitHub-reference: fix https://github.com/joaotavora/eglot/issues/165

6 years agoControl strictness towards incoming lsp messages
João Távora [Fri, 23 Nov 2018 12:31:15 +0000 (12:31 +0000)]
Control strictness towards incoming lsp messages

A new variable, eglot-strict-mode controls whether Eglot is strict or
lax with regard to incoming LSP messages.

1. Bug reports should be tested with eglot-strict-mode set to
   '(disallow-non-standard-keys enforce-required-keys)

2. Users struggling to get non-standard servers working set this
   variable to '(), nil.  For now, by popular demand, this is the
   default value.

Note that this commit in particular introduces a new infrastructure,
but does not yet alter any code in Eglot to use it.  Neither is the
variable eglot--lsp-interface-alist populated.

* eglot-tests.el (eglot-strict-interfaces): New test.

* eglot.el (eglot--lsp-interface-alist): New variable.
(eglot-strict-mode): New variable.
(eglot--call-with-interface): New helper.
(eglot--dbind): New macro.
(eglot--lambda): New macro.

GitHub-reference: per https://github.com/joaotavora/eglot/issues/144
GitHub-reference: per https://github.com/joaotavora/eglot/issues/156

6 years ago* eglot.el (version): bump to 1.2
João Távora [Fri, 23 Nov 2018 00:12:45 +0000 (00:12 +0000)]
* eglot.el (version): bump to 1.2