Update neovim setup
Switch from pyright to python-lsp-server
This commit is contained in:
parent
9891f205f4
commit
b0cdf7b854
6 changed files with 47 additions and 38 deletions
|
|
@ -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'
|
||||||
|
|
|
||||||
|
|
@ -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:
|
||||||
|
|
|
||||||
|
|
@ -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)
|
||||||
|
|
|
||||||
|
|
@ -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'
|
||||||
|
|
|
||||||
|
|
@ -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 = {
|
||||||
|
|
|
||||||
9
vars.yml
9
vars.yml
|
|
@ -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:
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue