Ever wondered how you can use neovim's builtin LSP client without plugins? This example configuration can show you one way of doing it.
This is not a neovim distribution.
- Neovim v0.8 or greater.
For Neovim v0.7 checkout the branch 07-compat.
At the heart of everything there are two functions:
-
vim.lsp.start_client()
: This function creates a "client object" that handles all communications with a language server. -
vim.lsp.buf_attach_client()
: With it we tell the language server it needs track the changes made to a particular file.
In order to simplify the code automatic "root dir" detection is not included. Instead, you should specify in a "local config" the servers you want to enable. Once a language server start running an autocommand is created, if the language server supports the filetype of the current buffer then it call vim.lsp.buf_attach_client()
.
For this configuration to work we need to call each server explicitly. It means we would need to have a configuration file per project. How can we do this without plugins? I propose we use the builtin session mechanism. If you didn't know, a session can have configuration file, let's just use that.
Navigate to a lua project and create a .nvim
folder in the root directory.
Open neovim. Create a session file in the new folder.
:mksession ./.nvim/Session.vim
Now create a config file for this session.
:edit ./.nvim/Sessionx.vim
Inside Sessionx.vim
we can call our language servers. For the moment we are trying out lua-language-server
. Add this.
LspStart sumneko_lua
Save the file and exit neovim. Now start neovim with this command.
nvim -S ./.nvim/Session.vim
After the session state is restored neovim will source Sessionx.vim
and this will call our language server. If you have any errors the diagnostic signs will show in the gutter. Completion suggestion can be triggered in insert mode using <C-x><C-o>
. Check out user.keymaps to know what kind of actions you can do once the language server is attached to a buffer.
-
lsp.config: Is used to build the configuration for a language server. Here you can find initialization hooks, clean up hooks, capabilities. All the boilerplate necessary to reuse a language server instance in a project.
-
lsp:
init.lua
in the lsp folder, contains some custimizations to diagnostics and the functions to start a language server in proper way. -
user.sessions: As a bonus I've added some helper to make it easier to manage sessions.
If you find this useful and want to support my efforts you can buy me a coffee ☕.