Compare commits
No commits in common. "abf8f706ad6060e31f5445c925925900bcdd85b3" and "7393fc696a040b613d132dfcfee37f40edfb3613" have entirely different histories.
abf8f706ad
...
7393fc696a
7 changed files with 15 additions and 290 deletions
|
@ -53,6 +53,16 @@ with final.pkgs.lib; let
|
||||||
which-key-nvim
|
which-key-nvim
|
||||||
gitsigns-nvim
|
gitsigns-nvim
|
||||||
|
|
||||||
|
# Coding
|
||||||
|
friendly-snippets
|
||||||
|
lexima-vim
|
||||||
|
(mkNvimPlugin inputs.neotab-nvim "neotab.nvim")
|
||||||
|
ts-comments-nvim
|
||||||
|
mini-ai
|
||||||
|
|
||||||
|
# Formatting
|
||||||
|
conform-nvim
|
||||||
|
|
||||||
# Treesitter
|
# Treesitter
|
||||||
nvim-treesitter-textobjects
|
nvim-treesitter-textobjects
|
||||||
nvim-ts-autotag
|
nvim-ts-autotag
|
||||||
|
@ -87,22 +97,6 @@ with final.pkgs.lib; let
|
||||||
yaml
|
yaml
|
||||||
]
|
]
|
||||||
))
|
))
|
||||||
|
|
||||||
# LSP
|
|
||||||
nvim-lspconfig
|
|
||||||
|
|
||||||
# Coding
|
|
||||||
friendly-snippets
|
|
||||||
lexima-vim
|
|
||||||
(mkNvimPlugin inputs.neotab-nvim "neotab.nvim")
|
|
||||||
ts-comments-nvim
|
|
||||||
mini-ai
|
|
||||||
|
|
||||||
# Formatting
|
|
||||||
conform-nvim
|
|
||||||
|
|
||||||
# Linting
|
|
||||||
nvim-lint
|
|
||||||
];
|
];
|
||||||
|
|
||||||
extraPackages = with pkgs; [
|
extraPackages = with pkgs; [
|
||||||
|
|
|
@ -12,10 +12,10 @@ return {
|
||||||
},
|
},
|
||||||
delete = '',
|
delete = '',
|
||||||
diagnostics = {
|
diagnostics = {
|
||||||
Error = '',
|
Error = ' ',
|
||||||
Warn = '',
|
Warn = ' ',
|
||||||
Hint = '',
|
Hint = ' ',
|
||||||
Info = '',
|
Info = ' ',
|
||||||
},
|
},
|
||||||
explorer = '',
|
explorer = '',
|
||||||
first = '',
|
first = '',
|
||||||
|
|
|
@ -63,10 +63,7 @@ return {
|
||||||
for _, type in ipairs({ 'Error', 'Warn', 'Info', 'Hint' }) do
|
for _, type in ipairs({ 'Error', 'Warn', 'Info', 'Hint' }) do
|
||||||
vim.fn.sign_define(
|
vim.fn.sign_define(
|
||||||
'DiagnosticSign' .. type,
|
'DiagnosticSign' .. type,
|
||||||
{
|
{ text = icons.diagnostics[type], texthl = 'DiagnosticSign' .. type }
|
||||||
text = icons.diagnostics[type] .. ' ',
|
|
||||||
texthl = 'DiagnosticSign' .. type,
|
|
||||||
}
|
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -1,5 +0,0 @@
|
||||||
local req = MarleyVim.local_require('plugins.linting')
|
|
||||||
|
|
||||||
return {
|
|
||||||
req('nvim-lint'),
|
|
||||||
}
|
|
|
@ -1,21 +0,0 @@
|
||||||
return {
|
|
||||||
'nvim-lint',
|
|
||||||
event = { 'BufReadPost', 'BufWritePost', 'BufNewFile' },
|
|
||||||
after = function()
|
|
||||||
local lint = require('lint')
|
|
||||||
|
|
||||||
lint.linters_by_ft = {
|
|
||||||
fish = { 'fish' },
|
|
||||||
}
|
|
||||||
|
|
||||||
vim.api.nvim_create_autocmd(
|
|
||||||
{ 'BufWritePost', 'BufReadPost', 'InsertLeave' },
|
|
||||||
{
|
|
||||||
group = vim.api.nvim_create_augroup('nvim-lint', { clear = true }),
|
|
||||||
callback = function()
|
|
||||||
require('lint').try_lint()
|
|
||||||
end,
|
|
||||||
}
|
|
||||||
)
|
|
||||||
end,
|
|
||||||
}
|
|
|
@ -1,5 +0,0 @@
|
||||||
local req = MarleyVim.local_require('plugins.lsp')
|
|
||||||
|
|
||||||
return {
|
|
||||||
req('nvim-lspconfig'),
|
|
||||||
}
|
|
|
@ -1,235 +0,0 @@
|
||||||
return {
|
|
||||||
'nvim-lspconfig',
|
|
||||||
event = { 'BufReadPost', 'BufWritePost', 'BufNewFile' },
|
|
||||||
before = function()
|
|
||||||
require('lz.n').trigger_load('blink.cmp')
|
|
||||||
end,
|
|
||||||
after = function()
|
|
||||||
local i = require('icons')
|
|
||||||
|
|
||||||
local opts = {
|
|
||||||
---@class vim.diagnostic.Opts
|
|
||||||
diagnostics = {
|
|
||||||
underline = true,
|
|
||||||
update_in_insert = false,
|
|
||||||
virtual_text = {
|
|
||||||
spacing = 4,
|
|
||||||
source = 'if_many',
|
|
||||||
prefix = function(diagnostic)
|
|
||||||
for d, icon in pairs(i.diagnostics) do
|
|
||||||
if diagnostic.severity == vim.diagnostic.severity[d:upper()] then
|
|
||||||
return icon
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
return '●'
|
|
||||||
end,
|
|
||||||
},
|
|
||||||
severity_sort = true,
|
|
||||||
signs = {
|
|
||||||
text = {
|
|
||||||
[vim.diagnostic.severity.ERROR] = i.diagnostics.Error,
|
|
||||||
[vim.diagnostic.severity.WARN] = i.diagnostics.Warn,
|
|
||||||
[vim.diagnostic.severity.HINT] = i.diagnostics.Hint,
|
|
||||||
[vim.diagnostic.severity.INFO] = i.diagnostics.Info,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
|
|
||||||
capabilities = {
|
|
||||||
workspace = {
|
|
||||||
fileOperations = {
|
|
||||||
didRename = true,
|
|
||||||
willRename = true,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
|
|
||||||
servers = {
|
|
||||||
lua_ls = {
|
|
||||||
settings = {
|
|
||||||
Lua = {
|
|
||||||
workspace = { checkThirdParty = false },
|
|
||||||
codeLens = { enable = true },
|
|
||||||
completion = { callSnippet = 'Replace' },
|
|
||||||
doc = { privateName = { '^_' } },
|
|
||||||
hint = {
|
|
||||||
enable = true,
|
|
||||||
setType = false,
|
|
||||||
paramType = true,
|
|
||||||
paramName = 'Disable',
|
|
||||||
semicolon = 'Disable',
|
|
||||||
arrayIndex = 'Disable',
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
}
|
|
||||||
|
|
||||||
-- Codelens.
|
|
||||||
vim.api.nvim_create_autocmd('User', {
|
|
||||||
pattern = 'LspSupportsMethod',
|
|
||||||
callback = function(args)
|
|
||||||
local client = vim.lsp.get_client_by_id(args.data.client_id)
|
|
||||||
local buffer = args.data.buffer
|
|
||||||
|
|
||||||
if client and args.data.method == 'textDocument/codeLens' then
|
|
||||||
vim.lsp.codelens.refresh()
|
|
||||||
|
|
||||||
vim.api.nvim_create_autocmd(
|
|
||||||
{ 'BufEnter', 'CursorHold', 'InsertLeave' },
|
|
||||||
{
|
|
||||||
buffer = buffer,
|
|
||||||
callback = vim.lsp.codelens.refresh,
|
|
||||||
}
|
|
||||||
)
|
|
||||||
end
|
|
||||||
end,
|
|
||||||
})
|
|
||||||
|
|
||||||
-- Diagnostics.
|
|
||||||
vim.diagnostic.config(vim.deepcopy(opts.diagnostics))
|
|
||||||
|
|
||||||
-- Server setup.
|
|
||||||
local has_blink, blink = pcall(require, 'blink.cmp')
|
|
||||||
local capabilities = vim.tbl_deep_extend(
|
|
||||||
'force',
|
|
||||||
{},
|
|
||||||
vim.lsp.protocol.make_client_capabilities(),
|
|
||||||
has_blink and blink.get_lsp_capabilities() or {},
|
|
||||||
opts.capabilities
|
|
||||||
)
|
|
||||||
|
|
||||||
local function setup(server)
|
|
||||||
local server_opts = vim.tbl_deep_extend('force', {
|
|
||||||
capabilities = vim.deepcopy(capabilities),
|
|
||||||
}, opts.servers[server] or {})
|
|
||||||
|
|
||||||
if server_opts.enabled == false then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
if opts.setup and opts.setup[server] then
|
|
||||||
if opts.setup[server](server, server_opts) then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
require('lspconfig')[server].setup(server_opts)
|
|
||||||
end
|
|
||||||
|
|
||||||
for server, server_opts in pairs(opts.servers) do
|
|
||||||
if server_opts.enabled ~= false then
|
|
||||||
setup(server)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Set keymaps.
|
|
||||||
vim.api.nvim_create_autocmd('LspAttach', {
|
|
||||||
callback = function(args)
|
|
||||||
local client = vim.lsp.get_client_by_id(args.data.client_id)
|
|
||||||
|
|
||||||
if not client then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
local set = vim.keymap.set
|
|
||||||
|
|
||||||
set('n', '<LEADER>cl', '<CMD>LspInfo<CR>', { desc = 'lsp info' })
|
|
||||||
set('n', 'gD', vim.lsp.buf.declaration, { desc = 'declaration' })
|
|
||||||
set('n', 'gI', vim.lsp.buf.implementation, { desc = 'implementation' })
|
|
||||||
|
|
||||||
set(
|
|
||||||
'n',
|
|
||||||
'gr',
|
|
||||||
vim.lsp.buf.references,
|
|
||||||
{ desc = 'references', nowait = true }
|
|
||||||
)
|
|
||||||
|
|
||||||
set(
|
|
||||||
'n',
|
|
||||||
'gy',
|
|
||||||
vim.lsp.buf.type_definition,
|
|
||||||
{ desc = 'type definition' }
|
|
||||||
)
|
|
||||||
|
|
||||||
set('n', 'K', function()
|
|
||||||
return vim.lsp.buf.hover()
|
|
||||||
end, { desc = 'hover' })
|
|
||||||
|
|
||||||
if client.supports_method('textDocument/codeAction') then
|
|
||||||
set(
|
|
||||||
{ 'n', 'v' },
|
|
||||||
'<LEADER>ca',
|
|
||||||
vim.lsp.buf.code_action,
|
|
||||||
{ desc = 'code action' }
|
|
||||||
)
|
|
||||||
end
|
|
||||||
|
|
||||||
if client.supports_method('textDocument/codeLens') then
|
|
||||||
set(
|
|
||||||
{ 'n', 'v' },
|
|
||||||
'<LEADER>cc',
|
|
||||||
vim.lsp.codelens.run,
|
|
||||||
{ desc = 'run codelens' }
|
|
||||||
)
|
|
||||||
|
|
||||||
set(
|
|
||||||
'n',
|
|
||||||
'<LEADER>cC',
|
|
||||||
vim.lsp.codelens.refresh,
|
|
||||||
{ desc = 'refresh & display codelens' }
|
|
||||||
)
|
|
||||||
end
|
|
||||||
|
|
||||||
if client.supports_method('textDocument/definition') then
|
|
||||||
set('n', 'gd', vim.lsp.buf.definition, { desc = 'definition' })
|
|
||||||
end
|
|
||||||
|
|
||||||
if client.supports_method('textDocument/documentHighlight') then
|
|
||||||
if Snacks.words.is_enabled() then
|
|
||||||
set('n', '<A-n>', function()
|
|
||||||
Snacks.words.jump(vim.v.count1, true)
|
|
||||||
end, { desc = 'next reference' })
|
|
||||||
|
|
||||||
set('n', '<A-p>', function()
|
|
||||||
Snacks.words.jump(-vim.v.count1, true)
|
|
||||||
end, { desc = 'prev reference' })
|
|
||||||
|
|
||||||
set('n', ']]', function()
|
|
||||||
Snacks.words.jump(vim.v.count1)
|
|
||||||
end, { desc = 'next reference' })
|
|
||||||
|
|
||||||
set('n', '[[', function()
|
|
||||||
Snacks.words.jump(-vim.v.count1)
|
|
||||||
end, { desc = 'prev reference' })
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
if client.supports_method('textDocument/rename') then
|
|
||||||
set('n', '<LEADER>cr', vim.lsp.buf.rename, { desc = 'rename' })
|
|
||||||
end
|
|
||||||
|
|
||||||
if client.supports_method('textDocument/signatureHelp') then
|
|
||||||
set('i', '<C-k>', function()
|
|
||||||
return vim.lsp.buf.signature_help()
|
|
||||||
end, { desc = 'signature help' })
|
|
||||||
|
|
||||||
set('n', 'gK', function()
|
|
||||||
vim.lsp.buf.signature_help()
|
|
||||||
end, { desc = 'signature help' })
|
|
||||||
end
|
|
||||||
|
|
||||||
if
|
|
||||||
client.supports_method('workspace/didRenameFiles')
|
|
||||||
or client.supports_method('workspace/willRenameFiles')
|
|
||||||
then
|
|
||||||
set('n', '<LEADER>cR', function()
|
|
||||||
Snacks.rename.rename_file()
|
|
||||||
end, { desc = 'rename file' })
|
|
||||||
end
|
|
||||||
end,
|
|
||||||
})
|
|
||||||
end,
|
|
||||||
}
|
|
Loading…
Reference in a new issue