Update neovim setup

Switch from pyright to python-lsp-server
This commit is contained in:
Sonny Bakker 2023-08-04 10:29:11 +02:00
parent 9891f205f4
commit b0cdf7b854
6 changed files with 47 additions and 38 deletions

View file

@ -16,7 +16,6 @@
- { domain: '{{ gitlab_domain }}', key: '{{ gitlab_host_key }}' } - { domain: '{{ gitlab_domain }}', key: '{{ gitlab_host_key }}' }
roles: roles:
- common - common
- npm
tasks: tasks:
- import_tasks: 'tasks/main.yml' - import_tasks: 'tasks/main.yml'
- import_tasks: 'tasks/dotfiles.yml' - import_tasks: 'tasks/dotfiles.yml'

View file

@ -20,25 +20,20 @@
version: '{{ item.version|default("HEAD") }}' version: '{{ item.version|default("HEAD") }}'
loop: '{{ neovim_plugins }}' loop: '{{ neovim_plugins }}'
- name: install neovim python packages
pip:
name:
- neovim
- pynvim
extra_args: --user
- name: install neovim node package - name: install neovim node package
become: true become: true
npm: npm:
name: neovim name: neovim
global: true global: true
# Note that the "python-lsp-server", "python-lsp-ruff" and "neovim" python
# packages should be installed to the corresponding virtualenv as well.
- name: install language servers - name: install language servers
become: true become: true
npm: package:
name: '{{ item }}' name: '{{ item }}'
global: true state: present
loop: '{{ language_servers + neovim_node_packages }}' loop: '{{ language_servers }}'
- name: remove old neovim configuration file - name: remove old neovim configuration file
file: file:

View file

@ -23,7 +23,9 @@ end
--enable some language servers with the additional completion capabilities --enable some language servers with the additional completion capabilities
--offered by nvim-cmp --offered by nvim-cmp
local servers = { 'ansiblels', 'yamlls', 'cssls', 'jsonls', 'tsserver', } local servers = {
'ansiblels', 'yamlls', 'cssls', 'jsonls', 'tsserver', 'bashls', 'lua_ls'
}
--add additional capabilities supported by nvim-cmp --add additional capabilities supported by nvim-cmp
local capabilities = vim.lsp.protocol.make_client_capabilities() local capabilities = vim.lsp.protocol.make_client_capabilities()
@ -40,9 +42,19 @@ end
local util = require('lspconfig/util') local util = require('lspconfig/util')
nvim_lsp.pyright.setup({ nvim_lsp.pylsp.setup({
on_attach = on_attach, on_attach = on_attach,
capabilities = capabilities, capabilities = capabilities,
cmd = { 'pylsp', '--verbose' },
settings = {
pylsp = {
plugins = {
ruff = {
enabled = true
}
}
}
},
root_dir = function(fname) root_dir = function(fname)
return util.root_pattern('.git', 'setup.cfg', 'requirements')(fname) or return util.root_pattern('.git', 'setup.cfg', 'requirements')(fname) or
util.path.dirname(fname) util.path.dirname(fname)

View file

@ -1,58 +1,62 @@
-- {{ ansible_managed }} {{ ansible_date_time.time }} {{ ansible_date_time.date }} -- {{ ansible_managed }} {{ ansible_date_time.time }} {{ ansible_date_time.date }}
--fix different locale settings when ssh'ing -- fix different locale settings when ssh'ing
vim.o.encoding = 'utf-8' vim.o.encoding = 'utf-8'
vim.o.syntax = 'on' vim.o.syntax = 'on'
--display all matching files when we tab complete -- display all matching files when we tab complete
vim.o.wildmenu = true vim.o.wildmenu = true
--replace vertical split pipe character with space -- replace vertical split pipe character with space
vim.o.fillchars = 'vert:|,fold: ' vim.o.fillchars = 'vert:|,fold: '
--Having longer updatetime (default is 4000 ms = 4 s) leads to noticeable -- Having longer updatetime (default is 4000 ms = 4 s) leads to noticeable
--delays and poor user experience. -- delays and poor user experience.
vim.o.updatetime = 300 vim.o.updatetime = 300
vim.o.splitright = true vim.o.splitright = true
vim.o.splitbelow = true vim.o.splitbelow = true
--switch buffers without writing to file -- switch buffers without writing to file
vim.o.hidden = true vim.o.hidden = true
--fold indents -- folding
vim.o.foldmethod = 'indent' vim.o.foldmethod = 'expr'
vim.o.foldexpr = 'nvim_treesitter#foldexpr()'
--don't open folds when jumping over one with (, {, [[ or [{ -- don't open folds when jumping over one with (, {, [[ or [{
vim.opt.foldopen = vim.opt.foldopen - { 'block' } vim.opt.foldopen = vim.opt.foldopen - { 'block' }
--search down into subfolders -- search down into subfolders
--provides tab-completion for all file-related tasks -- provides tab-completion for all file-related tasks
vim.opt.path = vim.opt.path + { '**' } vim.opt.path = vim.opt.path + { '**' }
--line numbers -- line numbers
vim.o.number = true vim.o.number = true
--higlhight search -- higlhight search
vim.o.hls = true vim.o.hls = true
--search as characters are entered -- search as characters are entered
vim.o.incsearch = true vim.o.incsearch = true
--line for linewrapping -- line for linewrapping
vim.o.colorcolumn = '80' vim.o.colorcolumn = '80'
--wrap text instead of being on one line -- wrap text instead of being on one line
vim.o.lbr = true vim.o.lbr = true
--default Colors for CursorLine -- default Colors for CursorLine
vim.o.cursorline = true vim.o.cursorline = true
-- theme related -- theme related
vim.o.termguicolors = true vim.o.termguicolors = true
vim.o.background = 'light' vim.o.background = 'light'
--enable statusbar -- enable statusbar
vim.o.laststatus = 2 vim.o.laststatus = 2
vim.o.statusline = ' %F %m%r%w %= %{hostname()} %{strlen(&ft)?&ft:"none"} %{(&bomb?",BOM":"")} %{&ff} %l/%L %c %P' vim.o.statusline = ' %F %m%r%w %= %{hostname()} %{strlen(&ft)?&ft:"none"} %{(&bomb?",BOM":"")} %{&ff} %l/%L %c %P'
-- python interpreter
vim.g.python3_host_prog = './env/bin/python'

View file

@ -8,7 +8,7 @@ local tree_sitter_config = require('nvim-treesitter.configs')
tree_sitter_config.setup { tree_sitter_config.setup {
ensure_installed = { ensure_installed = {
'lua', 'yaml', 'bash', 'python', 'javascript', 'css', 'scss', 'html', 'lua', 'yaml', 'bash', 'python', 'javascript', 'css', 'scss', 'html',
'json', 'dockerfile', 'markdown', 'htmldjango', 'json', 'dockerfile', 'markdown',
}, },
auto_install = true, auto_install = true,
highlight = { highlight = {

View file

@ -57,16 +57,15 @@ neovim_plugins:
version: '0.1.x', version: '0.1.x',
} }
- { url: 'https://github.com/L3MON4D3/LuaSnip', name: 'luasnip', version: 'v1.0.0' } - { url: 'https://github.com/L3MON4D3/LuaSnip', name: 'luasnip', version: 'v1.0.0' }
- { url: 'https://github.com/lewis6991/gitsigns.nvim', name: 'gitsigns.nvim' }
neovim_node_packages:
- typescript
language_servers: language_servers:
- pyright
- ansible-language-server - ansible-language-server
- yaml-language-server - yaml-language-server
- vscode-langservers-extracted
- typescript-language-server - typescript-language-server
- vscode-html-languageserver
- bash-language-server
- lua-language-server
python_download_url: 'https://www.python.org/ftp/python' python_download_url: 'https://www.python.org/ftp/python'
python_versions: python_versions: