2020-12-07 21:46:39 +11:00
|
|
|
# Deno Language Server
|
|
|
|
|
|
|
|
The Deno Language Server provides a server implementation of the
|
|
|
|
[Language Server Protocol](https://microsoft.github.io/language-server-protocol/)
|
|
|
|
which is specifically tailored to provide a _Deno_ view of code. It is
|
|
|
|
integrated into the command line and can be started via the `lsp` sub-command.
|
|
|
|
|
|
|
|
> :warning: The Language Server is highly experimental and far from feature
|
2020-12-21 14:44:26 +01:00
|
|
|
> complete. This document gives an overview of the structure of the language
|
|
|
|
> server.
|
2020-12-07 21:46:39 +11:00
|
|
|
|
|
|
|
## Structure
|
|
|
|
|
2020-12-21 14:44:26 +01:00
|
|
|
When the language server is started, a `LanguageServer` instance is created
|
|
|
|
which holds all of the state of the language server. It also defines all of the
|
|
|
|
methods that the client calls via the Language Server RPC protocol.
|
2021-02-05 05:53:02 +11:00
|
|
|
|
|
|
|
## Custom requests
|
|
|
|
|
|
|
|
The LSP currently supports the following custom requests. A client should
|
|
|
|
implement these in order to have a fully functioning client that integrates well
|
|
|
|
with Deno:
|
|
|
|
|
|
|
|
- `deno/cache` - This command will instruct Deno to attempt to cache a module
|
|
|
|
and all of its dependencies. It expects an argument of
|
|
|
|
`{ textDocument: TextDocumentIdentifier }` to be passed.
|
|
|
|
- `deno/performance` - Requests the return of the timing averages for the
|
|
|
|
internal instrumentation of Deno.
|
|
|
|
- `deno/virtualTextDocument` - Requests a virtual text document from the LSP,
|
|
|
|
which is a read only document that can be displayed in the client. This allows
|
|
|
|
clients to access documents in the Deno cache, like remote modules and
|
|
|
|
TypeScript library files built into Deno. It also supports a special URL of
|
|
|
|
`deno:/status.md` which provides a markdown formatted text document that
|
|
|
|
contains details about the status of the LSP for display to a user.
|