2019-04-06 00:38:46 -04:00
|
|
|
#+TITLE: tools/lsp
|
|
|
|
#+DATE: March 05, 2019
|
|
|
|
#+SINCE: v2.1
|
|
|
|
#+STARTUP: inlineimages
|
|
|
|
|
|
|
|
* Table of Contents :TOC_3:noexport:
|
|
|
|
- [[#description][Description]]
|
|
|
|
- [[#module-flags][Module Flags]]
|
|
|
|
- [[#plugins][Plugins]]
|
|
|
|
- [[#prerequisites][Prerequisites]]
|
|
|
|
- [[#features][Features]]
|
2019-12-20 00:49:27 +01:00
|
|
|
- [[#lsp-powered-project-search][LSP-powered project search]]
|
2019-04-06 00:38:46 -04:00
|
|
|
- [[#configuration][Configuration]]
|
|
|
|
- [[#troubleshooting][Troubleshooting]]
|
|
|
|
|
|
|
|
* Description
|
2019-10-26 04:05:34 -04:00
|
|
|
This module integrates [[https://langserver.org/][language servers]] into Doom Emacs. They provide features
|
2019-04-06 00:38:46 -04:00
|
|
|
you'd expect from IDEs, like code completion, realtime linting, language-aware
|
|
|
|
imenu/xref integration, jump-to-definition/references support, and more.
|
|
|
|
|
2019-10-26 04:05:34 -04:00
|
|
|
To get LSP working, you'll need to do three things:
|
2019-04-06 00:38:46 -04:00
|
|
|
|
2019-10-26 04:05:34 -04:00
|
|
|
1. Enable this module,
|
|
|
|
2. Install a language server appropriate for your targeted language(s) (you'll
|
2019-04-06 00:38:46 -04:00
|
|
|
find a table mapping languages to available servers [[https://github.com/emacs-lsp/lsp-mode#supported-languages][in the lsp-mode project
|
|
|
|
README]]).
|
2019-10-26 04:05:34 -04:00
|
|
|
3. Enable the =+lsp= flag on the =:lang= modules you want to enable LSP support
|
|
|
|
for. If your language's module doesn't have LSP support, and you know it can
|
|
|
|
(or should), please let us know! In the meantime, you must configure it
|
|
|
|
yourself (described in the Configuration section).
|
2019-04-06 00:38:46 -04:00
|
|
|
|
2019-04-08 23:02:50 -04:00
|
|
|
As of this writing, this is the state of LSP support in Doom Emacs:
|
2019-04-06 00:38:46 -04:00
|
|
|
|
|
|
|
| Module | Major modes | Default language server |
|
|
|
|
|------------------+---------------------------------------------------------+---------------------------------------------------------------|
|
|
|
|
| [[../../lang/cc/README.org][:lang cc]] | c-mode, c++-mode, objc-mode | ccls |
|
2019-10-26 04:05:34 -04:00
|
|
|
| [[../../lang/csharp/README.org][:lang csharp]] | csharp-mode | omnisharp |
|
2019-07-26 21:32:20 +03:00
|
|
|
| [[../../lang/elixir/README.org][:lang elixir]] | elixir-mode | elixir-ls |
|
2019-10-26 04:05:34 -04:00
|
|
|
| [[../../lang/fsharp/README.org][:lang fsharp]] | fsharp-mode | Mono, .NET core |
|
2019-04-06 00:38:46 -04:00
|
|
|
| [[../../lang/go/README.org][:lang go]] | go-mode | go-langserver |
|
2019-04-07 16:46:59 -04:00
|
|
|
| [[../../lang/haskell/README.org][:lang haskell]] | haskell-mode | haskell-ide-engine |
|
2019-04-06 00:38:46 -04:00
|
|
|
| [[../../lang/java/README.org][:lang java]] | java-mode | lsp-java |
|
2019-10-26 04:05:34 -04:00
|
|
|
| [[../../lang/javascript/README.org][:lang javascript]] | js2-mode, rjsx-mode, typescript-mode | typescript-language-server |
|
2020-02-24 10:57:06 +01:00
|
|
|
| [[../../lang/ocaml/README.org][:lang ocaml]] | tuareg-mode | ocaml-language-server |
|
2019-04-06 00:38:46 -04:00
|
|
|
| [[../../lang/php/README.org][:lang php]] | php-mode | php-language-server |
|
|
|
|
| [[../../lang/python/README.org][:lang python]] | python-mode | lsp-python-ms |
|
2020-03-12 11:29:54 -04:00
|
|
|
| [[../../lang/ruby/README.org][:lang ruby]] | ruby-mode | solargraph |
|
2019-04-06 00:38:46 -04:00
|
|
|
| [[../../lang/rust/README.org][:lang rust]] | rust-mode | rls |
|
2019-10-26 04:05:34 -04:00
|
|
|
| [[../../lang/scala/README.org][:lang scala]] | scala-mode | metals |
|
2019-04-06 00:38:46 -04:00
|
|
|
| [[../../lang/sh/README.org][:lang sh]] | sh-mode | bash-language-server |
|
2019-10-26 04:05:34 -04:00
|
|
|
| [[../../lang/swift/README.org][:lang swift]] | swift-mode | sourcekit |
|
2019-04-06 00:38:46 -04:00
|
|
|
| [[../../lang/web/README.org][:lang web]] | web-mode, css-mode, scss-mode, sass-mode, less-css-mode | vscode-css-languageserver-bin, vscode-html-languageserver-bin |
|
|
|
|
|
|
|
|
** Module Flags
|
2020-02-23 16:37:16 +01:00
|
|
|
+ =+peek= Enables the =lsp-ui-peek= navigation frontend provided by the =lsp-ui= package.
|
2019-04-06 00:38:46 -04:00
|
|
|
|
|
|
|
** Plugins
|
|
|
|
+ [[https://github.com/emacs-lsp/lsp-mode][lsp-mode]]
|
|
|
|
+ [[https://github.com/emacs-lsp/lsp-ui][lsp-ui]]
|
|
|
|
|
|
|
|
* Prerequisites
|
2019-04-08 23:02:50 -04:00
|
|
|
This module has no direct prerequisites, but major-modes require you to install
|
|
|
|
language servers.
|
2019-04-06 00:38:46 -04:00
|
|
|
|
|
|
|
You'll find a table that lists available language servers and how to install
|
|
|
|
them [[https://github.com/emacs-lsp/lsp-mode#supported-languages][in the lsp-mode project README]]. The documentation of the module for your
|
|
|
|
targeted language will contain brief instructions as well.
|
|
|
|
|
|
|
|
* TODO Features
|
2019-12-20 00:49:27 +01:00
|
|
|
** LSP-powered project search
|
|
|
|
When =:completion ivy= or =:completion helm= is active, LSP is used to search a
|
|
|
|
symbol indexed by the LSP server :
|
|
|
|
| Keybind | Description |
|
|
|
|
|-----------+-------------------------------------|
|
|
|
|
| =SPC c j= | Jump to symbol in current workspace |
|
|
|
|
| =SPC c J= | Jump to symbol in any workspace |
|
2019-04-06 00:38:46 -04:00
|
|
|
|
|
|
|
* TODO Configuration
|
|
|
|
|
|
|
|
* TODO Troubleshooting
|