neovim: overhaul plugin config and keybinds
Some checks failed
Run nix flake check / flake-check (push) Successful in 1m24s
Periodic flake update / flake-update (push) Failing after 6s

Remove lsp-zero (replaced with native Neovim 0.11 LSP support),
vim-fugitive, and pyright. Add basedpyright, gitsigns, which-key,
trouble, todo-comments, indent-blankline, and telescope-fzf-native.
Clean up duplicate keybinds and organize under which-key groups.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
2026-02-21 18:01:27 +01:00
parent 9cde18d173
commit c9c14a193b
3 changed files with 111 additions and 53 deletions

View File

@@ -16,17 +16,21 @@
cmp_luasnip cmp_luasnip
copilot-cmp copilot-cmp
copilot-lua copilot-lua
lsp-zero-nvim gitsigns-nvim
indent-blankline-nvim
lualine-nvim lualine-nvim
luasnip luasnip
nvim-cmp nvim-cmp
nvim-lspconfig nvim-lspconfig
plenary-nvim plenary-nvim
telescope-nvim telescope-nvim
telescope-fzf-native-nvim
todo-comments-nvim
trouble-nvim
undotree undotree
vim-floaterm vim-floaterm
vim-fugitive
vim-sleuth vim-sleuth
which-key-nvim
(nvim-treesitter.withPlugins (p: [ (nvim-treesitter.withPlugins (p: [
p.tree-sitter-yaml p.tree-sitter-yaml
p.tree-sitter-nix p.tree-sitter-nix
@@ -57,7 +61,7 @@
# LSPs # LSPs
gopls gopls
pyright basedpyright
nodePackages.typescript-language-server nodePackages.typescript-language-server
nodePackages.typescript nodePackages.typescript
nil nil

View File

@@ -1,32 +1,57 @@
-- Keybinds -- Keybinds
vim.keymap.set("n", "<Leader>ds", vim.diagnostic.open_float, { desc = "Show diagnostic" })
-- Diagnostics
vim.keymap.set("n", "<leader>ds", vim.diagnostic.open_float, { desc = "Show diagnostic" })
vim.keymap.set("n", "<leader>dd", '<cmd>Trouble diagnostics toggle<CR>', { desc = "Diagnostics list" })
vim.keymap.set("n", "<leader>db", '<cmd>Trouble diagnostics toggle filter.buf=0<CR>', { desc = "Buffer diagnostics" })
-- Term -- Term
vim.g.floaterm_keymap_toggle = '<leader>ft' vim.g.floaterm_keymap_toggle = '<leader>T'
-- Tabs -- Tabs
vim.keymap.set('n', '<leader>n', ':tabnew<CR>', vim.keymap.set('n', '<leader>tn', ':tabnew<CR>',
{ silent = true, desc = '[N]ew tab' }) { silent = true, desc = 'New tab' })
vim.keymap.set('n', '<leader>p', ':tabnext<CR>', vim.keymap.set('n', '<leader>tp', ':tabnext<CR>',
{ silent = true, desc = '[p]Next tab' }) { silent = true, desc = 'Next tab' })
vim.keymap.set('n', '<leader>P', ':tabprev<CR>', vim.keymap.set('n', '<leader>tP', ':tabprev<CR>',
{ silent = true, desc = '[P]Previous tab' }) { silent = true, desc = 'Previous tab' })
-- Telescope -- Telescope
vim.keymap.set('n', '<leader>?', require('telescope.builtin').oldfiles, vim.keymap.set('n', '<leader>?', require('telescope.builtin').oldfiles,
{ desc = '[?] FInd recently opened files' }) { desc = 'Find recently opened files' })
vim.keymap.set('n', '<leader>ff', require('telescope.builtin').find_files, vim.keymap.set('n', '<leader>ff', require('telescope.builtin').find_files,
{ desc = '[F]ind [F]iles' }) { desc = 'Find files' })
vim.keymap.set('n', '<leader>ff', require('telescope.builtin').find_files,
{ desc = '[F]ind [F]iles' })
vim.keymap.set('n', '<leader>fg', require('telescope.builtin').live_grep, vim.keymap.set('n', '<leader>fg', require('telescope.builtin').live_grep,
{ desc = '[F]ind by [G]rep' }) { desc = 'Find by grep' })
vim.keymap.set('n', '<leader>fb', require('telescope.builtin').buffers,
{ desc = 'Find buffers' })
vim.keymap.set('n', '<leader>fd', require('telescope.builtin').diagnostics,
{ desc = 'Find diagnostics' })
vim.keymap.set('n', '<leader>fw', require('telescope.builtin').grep_string,
{ desc = 'Find word under cursor' })
-- Tabs -- Undotree
vim.keymap.set('n', '<leader>tt', ':tabnew<cr>') vim.keymap.set('n', '<leader>u', vim.cmd.UndotreeToggle,
vim.keymap.set('n', '<leader>tn', ':tabnext<cr>') { desc = 'Toggle undotree' })
vim.keymap.set('n', '<leader>tp', ':tabprevious<cr>')
-- Gitsigns
local gs = require('gitsigns')
vim.keymap.set('n', ']h', gs.next_hunk, { desc = 'Next git hunk' })
vim.keymap.set('n', '[h', gs.prev_hunk, { desc = 'Previous git hunk' })
vim.keymap.set('n', '<leader>gs', gs.stage_hunk, { desc = 'Stage hunk' })
vim.keymap.set('n', '<leader>gr', gs.reset_hunk, { desc = 'Reset hunk' })
vim.keymap.set('n', '<leader>gS', gs.stage_buffer, { desc = 'Stage buffer' })
vim.keymap.set('n', '<leader>gR', gs.reset_buffer, { desc = 'Reset buffer' })
vim.keymap.set('n', '<leader>gp', gs.preview_hunk, { desc = 'Preview hunk' })
vim.keymap.set('n', '<leader>gb', gs.blame_line, { desc = 'Blame line' })
-- Todo comments
vim.keymap.set('n', ']t', function() require('todo-comments').jump_next() end, { desc = 'Next todo comment' })
vim.keymap.set('n', '[t', function() require('todo-comments').jump_prev() end, { desc = 'Previous todo comment' })
vim.keymap.set('n', '<leader>ft', '<cmd>TodoTelescope<CR>', { desc = 'Find TODOs' })
-- LSP -- LSP
vim.keymap.set('n', 'gD', vim.lsp.buf.declaration) vim.keymap.set('n', '<leader>lr', vim.lsp.buf.rename, { desc = 'Rename' })
vim.keymap.set('n', 'gd', vim.lsp.buf.definition) vim.keymap.set('n', '<leader>la', vim.lsp.buf.code_action, { desc = 'Code action' })
vim.keymap.set('n', '<leader>lf', function() vim.lsp.buf.format({ async = false }) end,
{ desc = 'Format' })

View File

@@ -1,25 +1,13 @@
-- Plugins -- Plugins
-- LSP stuff -- Format on save for nix, lua, ts/js
local lsp_zero = require('lsp-zero') vim.api.nvim_create_autocmd("BufWritePre", {
pattern = { "*.nix", "*.lua", "*.ts", "*.tsx", "*.js" },
callback = function()
lsp_zero.on_attach(function(_, bufnr) vim.lsp.buf.format({ async = false, timeout_ms = 10000 })
lsp_zero.default_keymaps({ buffer = bufnr }) end,
end)
lsp_zero.format_on_save({
format_opts = {
async = false,
timeout_ms = 10000,
},
servers = {
['gopls'] = { 'go' },
['nil_ls'] = { 'nix' },
['lua_ls'] = { 'lua' },
['ts_ls'] = { 'typescript', 'javascript', 'typescriptreact' },
},
}) })
-- LSP: go -- LSP: go
vim.lsp.config("gopls", { vim.lsp.config("gopls", {
settings = { settings = {
@@ -158,14 +146,12 @@ vim.api.nvim_create_autocmd("LspAttach", {
desc = 'LSP: Disable hover capability from Ruff', desc = 'LSP: Disable hover capability from Ruff',
}) })
-- Pyright -- Basedpyright
vim.lsp.config("pyright", { vim.lsp.config("basedpyright", {
settings = { settings = {
pyright = { basedpyright = {
-- Using Ruff's import organizer -- Using Ruff's import organizer
disableOrganizeImports = true, disableOrganizeImports = true,
},
python = {
analysis = { analysis = {
-- Ignore all files for analysis to exclusively use Ruff for linting -- Ignore all files for analysis to exclusively use Ruff for linting
ignore = { '*' }, ignore = { '*' },
@@ -173,7 +159,10 @@ vim.lsp.config("pyright", {
}, },
}, },
}) })
vim.lsp.enable({ "pyright" }) vim.lsp.enable({ "basedpyright" })
-- Gitsigns
require('gitsigns').setup()
-- Telescope -- Telescope
require('telescope').setup({ require('telescope').setup({
@@ -186,8 +175,9 @@ require('telescope').setup({
} }
}, },
}) })
require('telescope').load_extension('fzf')
-- Tresitter stuff -- Treesitter
require('nvim-treesitter').setup { require('nvim-treesitter').setup {
ensure_installed = {}, ensure_installed = {},
auto_install = false, auto_install = false,
@@ -262,12 +252,12 @@ require('copilot_cmp').setup()
-- Cmp -- Cmp
local cmp = require('cmp') local cmp = require('cmp')
local cmp_action = lsp_zero.cmp_action() local luasnip = require('luasnip')
cmp.setup({ cmp.setup({
snippet = { snippet = {
expand = function(args) expand = function(args)
require('luasnip').lsp_expand(args.body) luasnip.lsp_expand(args.body)
end, end,
}, },
mapping = cmp.mapping.preset.insert({ mapping = cmp.mapping.preset.insert({
@@ -275,9 +265,25 @@ cmp.setup({
['<CR>'] = cmp.mapping.confirm({ select = false }), ['<CR>'] = cmp.mapping.confirm({ select = false }),
-- Ctrl+Space to open completion menu -- Ctrl+Space to open completion menu
['<C-Space>'] = cmp.mapping.complete(), ['<C-Space>'] = cmp.mapping.complete(),
-- Move between snippet placeholders -- Tab to select next item or jump in snippet
['<C-f>'] = cmp_action.luasnip_jump_forward(), ['<Tab>'] = cmp.mapping(function(fallback)
['<C-b>'] = cmp_action.luasnip_jump_backward(), if cmp.visible() then
cmp.select_next_item()
elseif luasnip.expand_or_jumpable() then
luasnip.expand_or_jump()
else
fallback()
end
end, { 'i', 's' }),
['<S-Tab>'] = cmp.mapping(function(fallback)
if cmp.visible() then
cmp.select_prev_item()
elseif luasnip.jumpable(-1) then
luasnip.jump(-1)
else
fallback()
end
end, { 'i', 's' }),
-- Scroll in completion docs -- Scroll in completion docs
['<C-k>'] = cmp.mapping.scroll_docs(-4), ['<C-k>'] = cmp.mapping.scroll_docs(-4),
['<C-j>'] = cmp.mapping.scroll_docs(4), ['<C-j>'] = cmp.mapping.scroll_docs(4),
@@ -292,6 +298,29 @@ cmp.setup({
}) })
-- Indent blankline
require('ibl').setup()
-- Trouble
require('trouble').setup({
icons = false,
})
-- Todo comments
require('todo-comments').setup({
signs = false,
})
-- Which-key
require('which-key').setup()
require('which-key').add({
{ "<leader>d", group = "Diagnostics" },
{ "<leader>f", group = "Find" },
{ "<leader>g", group = "Git" },
{ "<leader>l", group = "LSP" },
{ "<leader>t", group = "Tabs" },
})
-- Colorscheme -- Colorscheme
require('catppuccin').setup { require('catppuccin').setup {
} }