mirror of https://github.com/golang/go.git
194 lines
4.9 KiB
Markdown
194 lines
4.9 KiB
Markdown
# Vim / Neovim
|
|
|
|
## vim-go
|
|
|
|
Use [vim-go] ver 1.20+, with the following configuration:
|
|
|
|
```
|
|
let g:go_def_mode='gopls'
|
|
let g:go_info_mode='gopls'
|
|
```
|
|
|
|
## LanguageClient-neovim
|
|
|
|
Use [LanguageClient-neovim], with the following configuration:
|
|
|
|
```
|
|
" Launch gopls when Go files are in use
|
|
let g:LanguageClient_serverCommands = {
|
|
\ 'go': ['gopls']
|
|
\ }
|
|
" Run gofmt on save
|
|
autocmd BufWritePre *.go :call LanguageClient#textDocument_formatting_sync()
|
|
```
|
|
|
|
## Ale
|
|
|
|
Use [ale]:
|
|
|
|
```vim
|
|
let g:ale_linters = {
|
|
\ 'go': ['gopls'],
|
|
\}
|
|
```
|
|
|
|
see [this issue][ale-issue-2179]
|
|
|
|
## vim-lsp
|
|
|
|
Use [prabirshrestha/vim-lsp], with the following configuration:
|
|
|
|
```vim
|
|
augroup LspGo
|
|
au!
|
|
autocmd User lsp_setup call lsp#register_server({
|
|
\ 'name': 'go-lang',
|
|
\ 'cmd': {server_info->['gopls']},
|
|
\ 'whitelist': ['go'],
|
|
\ })
|
|
autocmd FileType go setlocal omnifunc=lsp#complete
|
|
"autocmd FileType go nmap <buffer> gd <plug>(lsp-definition)
|
|
"autocmd FileType go nmap <buffer> ,n <plug>(lsp-next-error)
|
|
"autocmd FileType go nmap <buffer> ,p <plug>(lsp-previous-error)
|
|
augroup END
|
|
```
|
|
|
|
## vim-lsc
|
|
|
|
Use [natebosch/vim-lsc], with the following configuration:
|
|
|
|
```vim
|
|
let g:lsc_server_commands = {
|
|
\ "go": {
|
|
\ "command": "gopls serve",
|
|
\ "log_level": -1,
|
|
\ "suppress_stderr": v:true,
|
|
\ },
|
|
\}
|
|
```
|
|
|
|
The `log_level` and `suppress_stderr` parts are needed to prevent breakage from logging. See
|
|
issues [#180](https://github.com/natebosch/vim-lsc/issues/180) and
|
|
[#213](https://github.com/natebosch/vim-lsc/issues/213).
|
|
|
|
## coc.nvim
|
|
|
|
Use [coc.nvim], with the following `coc-settings.json` configuration:
|
|
|
|
```json
|
|
"languageserver": {
|
|
"golang": {
|
|
"command": "gopls",
|
|
"rootPatterns": ["go.mod", ".vim/", ".git/", ".hg/"],
|
|
"filetypes": ["go"],
|
|
"initializationOptions": {
|
|
"usePlaceholders": true
|
|
}
|
|
}
|
|
}
|
|
```
|
|
|
|
Other [settings](settings.md) can be added in `initializationOptions` too.
|
|
|
|
The `editor.action.organizeImport` code action will auto-format code and add missing imports. To run this automatically on save, add the following line to your `init.vim`:
|
|
|
|
```vim
|
|
autocmd BufWritePre *.go :call CocAction('runCommand', 'editor.action.organizeImport')
|
|
```
|
|
|
|
## govim
|
|
|
|
In vim classic only, use the experimental [`govim`], simply follow the [install steps][govim-install].
|
|
|
|
## Neovim v0.5.0+
|
|
|
|
To use the new (still experimental) native LSP client in Neovim, make sure you
|
|
[install][nvim-install] the prerelease v0.5.0 version of Neovim (aka “nightly”),
|
|
the `nvim-lspconfig` configuration helper plugin, and check the
|
|
[`gopls` configuration section][nvim-lspconfig] there.
|
|
|
|
### Custom configuration
|
|
|
|
You can add custom configuration using Lua. Here is an example of enabling the
|
|
`unusedparams` check as well as `staticcheck`:
|
|
|
|
```vim
|
|
lua <<EOF
|
|
nvim_lsp = require "nvim_lsp"
|
|
nvim_lsp.gopls.setup {
|
|
cmd = {"gopls", "serve"},
|
|
settings = {
|
|
gopls = {
|
|
analyses = {
|
|
unusedparams = true,
|
|
},
|
|
staticcheck = true,
|
|
},
|
|
},
|
|
}
|
|
EOF
|
|
```
|
|
|
|
### Imports
|
|
|
|
To get your imports ordered on save, like `goimports` does, you can define
|
|
a helper function in Lua:
|
|
|
|
```vim
|
|
lua <<EOF
|
|
-- …
|
|
|
|
function goimports(timeoutms)
|
|
local context = { source = { organizeImports = true } }
|
|
vim.validate { context = { context, "t", true } }
|
|
|
|
local params = vim.lsp.util.make_range_params()
|
|
params.context = context
|
|
|
|
local method = "textDocument/codeAction"
|
|
local resp = vim.lsp.buf_request_sync(0, method, params, timeoutms)
|
|
if resp and resp[1] then
|
|
local result = resp[1].result
|
|
if result and result[1] then
|
|
local edit = result[1].edit
|
|
vim.lsp.util.apply_workspace_edit(edit)
|
|
end
|
|
end
|
|
|
|
vim.lsp.buf.formatting()
|
|
end
|
|
EOF
|
|
|
|
autocmd BufWritePre *.go lua goimports(1000)
|
|
```
|
|
|
|
(Taken from the [discussion][nvim-lspconfig-imports] on Neovim issue tracker.)
|
|
|
|
### Omnifunc
|
|
|
|
To make your <kbd>Ctrl</kbd>+<kbd>x</kbd>,<kbd>Ctrl</kbd>+<kbd>o</kbd> work, add
|
|
this to your `init.vim`:
|
|
|
|
```vim
|
|
autocmd FileType go setlocal omnifunc=v:lua.vim.lsp.omnifunc
|
|
```
|
|
|
|
### Additional Links
|
|
|
|
* [Neovim's official LSP documentation][nvim-docs].
|
|
|
|
[vim-go]: https://github.com/fatih/vim-go
|
|
[LanguageClient-neovim]: https://github.com/autozimu/LanguageClient-neovim
|
|
[ale]: https://github.com/w0rp/ale
|
|
[ale-issue-2179]: https://github.com/w0rp/ale/issues/2179
|
|
[prabirshrestha/vim-lsp]: https://github.com/prabirshrestha/vim-lsp/
|
|
[natebosch/vim-lsc]: https://github.com/natebosch/vim-lsc/
|
|
[natebosch/vim-lsc#180]: https://github.com/natebosch/vim-lsc/issues/180
|
|
[coc.nvim]: https://github.com/neoclide/coc.nvim/
|
|
[`govim`]: https://github.com/myitcv/govim
|
|
[govim-install]: https://github.com/myitcv/govim/blob/master/README.md#govim---go-development-plugin-for-vim8
|
|
[nvim-docs]: https://neovim.io/doc/user/lsp.html
|
|
[nvim-install]: https://github.com/neovim/neovim/wiki/Installing-Neovim
|
|
[nvim-lspconfig]: https://github.com/neovim/nvim-lspconfig#gopls
|
|
[nvim-lspconfig-imports]: https://github.com/neovim/nvim-lspconfig/issues/115
|