neovim: overhaul plugin config and keybinds
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:
@@ -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
|
||||||
|
|||||||
@@ -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' })
|
||||||
|
|||||||
@@ -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 {
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user