Compare commits
3 Commits
3ff49b2567
...
2cc2998907
Author | SHA1 | Date | |
---|---|---|---|
2cc2998907 | |||
2a35077571 | |||
5c17ad21d2 |
@ -22,6 +22,7 @@ return {
|
|||||||
'norg',
|
'norg',
|
||||||
'gitcommit',
|
'gitcommit',
|
||||||
'jj',
|
'jj',
|
||||||
|
'jjdescription',
|
||||||
'rst',
|
'rst',
|
||||||
'typst'
|
'typst'
|
||||||
},
|
},
|
||||||
|
@ -8,7 +8,7 @@ luasnip.config.setup {
|
|||||||
updateevents = "TextChanged,TextChangedI",
|
updateevents = "TextChanged,TextChangedI",
|
||||||
enable_autosnippets = true,
|
enable_autosnippets = true,
|
||||||
}
|
}
|
||||||
luasnip.filetype_extend("jj", { "gitcommit" })
|
luasnip.filetype_extend("jjdescription", { "gitcommit" })
|
||||||
|
|
||||||
local has_words_before = function()
|
local has_words_before = function()
|
||||||
unpack = unpack or table.unpack
|
unpack = unpack or table.unpack
|
||||||
|
99
lua/lsp.lua
99
lua/lsp.lua
@ -1,55 +1,60 @@
|
|||||||
|
local lspattach = vim.api.nvim_create_augroup("LspMapping", { clear = true })
|
||||||
|
|
||||||
-- This function gets run when an LSP connects to a particular buffer.
|
-- This function gets run when an LSP connects to a particular buffer.
|
||||||
local on_attach = function(_, bufnr)
|
vim.api.nvim_create_autocmd("LspAttach", {
|
||||||
-- NOTE: Remember that lua is a real programming language, and as such it is possible
|
group = lspattach,
|
||||||
-- to define small helper and utility functions so you don't have to repeat yourself
|
callback = function(args)
|
||||||
-- many times.
|
-- NOTE: Remember that lua is a real programming language, and as such it is possible
|
||||||
--
|
-- to define small helper and utility functions so you don't have to repeat yourself
|
||||||
-- In this case, we create a function that lets us more easily define mappings specific
|
-- many times.
|
||||||
-- for LSP related items. It sets the mode, buffer and description for us each time.
|
--
|
||||||
local nmap = function(keys, func, desc)
|
-- In this case, we create a function that lets us more easily define mappings specific
|
||||||
if desc then
|
-- for LSP related items. It sets the mode, buffer and description for us each time.
|
||||||
desc = 'LSP: ' .. desc
|
local nmap = function(keys, func, desc)
|
||||||
|
if desc then
|
||||||
|
desc = 'LSP: ' .. desc
|
||||||
|
end
|
||||||
|
|
||||||
|
vim.keymap.set('n', keys, func, { buffer = args.buf, silent = true, desc = desc })
|
||||||
end
|
end
|
||||||
|
|
||||||
vim.keymap.set('n', keys, func, { buffer = bufnr, desc = desc })
|
nmap('<leader>rn', vim.lsp.buf.rename, '[R]e[n]ame')
|
||||||
end
|
nmap('<leader>c', vim.lsp.buf.code_action, '[C]ode action') -- NOTE: to see if ca is needed
|
||||||
|
nmap('<leader>f', function() -- https://stackoverflow.com/a/74303272
|
||||||
|
vim.lsp.buf.code_action({
|
||||||
|
filter = function(a)
|
||||||
|
return a.isPreferred
|
||||||
|
end,
|
||||||
|
apply = true
|
||||||
|
})
|
||||||
|
end, 'code action: [F]ix'
|
||||||
|
)
|
||||||
|
|
||||||
nmap('<leader>rn', vim.lsp.buf.rename, '[R]e[n]ame')
|
nmap('gd', require('telescope.builtin').lsp_definitions, '[G]oto [D]efinition')
|
||||||
nmap('<leader>c', vim.lsp.buf.code_action, '[C]ode action') -- NOTE: to see if ca is needed
|
nmap('gr', require('telescope.builtin').lsp_references, '[G]oto [R]eferences')
|
||||||
nmap('<leader>f', function() -- https://stackoverflow.com/a/74303272
|
nmap('gI', require('telescope.builtin').lsp_implementations, '[G]oto [I]mplementation')
|
||||||
vim.lsp.buf.code_action({
|
nmap('<leader>D', require('telescope.builtin').lsp_type_definitions, 'Type [D]efinition')
|
||||||
filter = function(a)
|
nmap('<leader>ds', require('telescope.builtin').lsp_document_symbols, '[D]ocument [S]ymbols')
|
||||||
return a.isPreferred
|
nmap('<leader>ws', require('telescope.builtin').lsp_dynamic_workspace_symbols, '[W]orkspace [S]ymbols')
|
||||||
end,
|
|
||||||
apply = true
|
|
||||||
})
|
|
||||||
end, 'code action: [F]ix'
|
|
||||||
)
|
|
||||||
|
|
||||||
nmap('gd', require('telescope.builtin').lsp_definitions, '[G]oto [D]efinition')
|
-- See `:help K` for why this keymap
|
||||||
nmap('gr', require('telescope.builtin').lsp_references, '[G]oto [R]eferences')
|
nmap('K', vim.lsp.buf.hover, 'Hover Documentation')
|
||||||
nmap('gI', require('telescope.builtin').lsp_implementations, '[G]oto [I]mplementation')
|
nmap('<C-k>', vim.lsp.buf.signature_help, 'Signature Documentation')
|
||||||
nmap('<leader>D', require('telescope.builtin').lsp_type_definitions, 'Type [D]efinition')
|
|
||||||
nmap('<leader>ds', require('telescope.builtin').lsp_document_symbols, '[D]ocument [S]ymbols')
|
|
||||||
nmap('<leader>ws', require('telescope.builtin').lsp_dynamic_workspace_symbols, '[W]orkspace [S]ymbols')
|
|
||||||
|
|
||||||
-- See `:help K` for why this keymap
|
-- Lesser used LSP functionality
|
||||||
nmap('K', vim.lsp.buf.hover, 'Hover Documentation')
|
nmap('gD', vim.lsp.buf.declaration, '[G]oto [D]eclaration')
|
||||||
nmap('<C-k>', vim.lsp.buf.signature_help, 'Signature Documentation')
|
nmap('<leader>wa', vim.lsp.buf.add_workspace_folder, '[W]orkspace [A]dd Folder')
|
||||||
|
nmap('<leader>wr', vim.lsp.buf.remove_workspace_folder, '[W]orkspace [R]emove Folder')
|
||||||
|
nmap('<leader>wl', function()
|
||||||
|
print(vim.inspect(vim.lsp.buf.list_workspace_folders()))
|
||||||
|
end, '[W]orkspace [L]ist Folders')
|
||||||
|
|
||||||
-- Lesser used LSP functionality
|
-- Create a command `:Format` local to the LSP buffer
|
||||||
nmap('gD', vim.lsp.buf.declaration, '[G]oto [D]eclaration')
|
vim.api.nvim_buf_create_user_command(args.buf, 'Format', function(_)
|
||||||
nmap('<leader>wa', vim.lsp.buf.add_workspace_folder, '[W]orkspace [A]dd Folder')
|
vim.lsp.buf.format()
|
||||||
nmap('<leader>wr', vim.lsp.buf.remove_workspace_folder, '[W]orkspace [R]emove Folder')
|
end, { desc = 'Format current buffer with LSP' })
|
||||||
nmap('<leader>wl', function()
|
end,
|
||||||
print(vim.inspect(vim.lsp.buf.list_workspace_folders()))
|
})
|
||||||
end, '[W]orkspace [L]ist Folders')
|
|
||||||
|
|
||||||
-- Create a command `:Format` local to the LSP buffer
|
|
||||||
vim.api.nvim_buf_create_user_command(bufnr, 'Format', function(_)
|
|
||||||
vim.lsp.buf.format()
|
|
||||||
end, { desc = 'Format current buffer with LSP' })
|
|
||||||
end
|
|
||||||
|
|
||||||
-- document existing key chains
|
-- document existing key chains
|
||||||
require('which-key').add {
|
require('which-key').add {
|
||||||
@ -125,7 +130,6 @@ mason_lspconfig.setup_handlers {
|
|||||||
function(server_name)
|
function(server_name)
|
||||||
require('lspconfig')[server_name].setup {
|
require('lspconfig')[server_name].setup {
|
||||||
capabilities = capabilities,
|
capabilities = capabilities,
|
||||||
on_attach = on_attach,
|
|
||||||
settings = servers[server_name],
|
settings = servers[server_name],
|
||||||
filetypes = (servers[server_name] or {}).filetypes,
|
filetypes = (servers[server_name] or {}).filetypes,
|
||||||
}
|
}
|
||||||
@ -159,7 +163,6 @@ servers = {
|
|||||||
for server_name, server_settings in pairs(servers) do
|
for server_name, server_settings in pairs(servers) do
|
||||||
lspconfig[server_name].setup {
|
lspconfig[server_name].setup {
|
||||||
capabilities = capabilities,
|
capabilities = capabilities,
|
||||||
on_attach = on_attach,
|
|
||||||
settings = server_settings,
|
settings = server_settings,
|
||||||
filetypes = (servers[server_name] or {}).filetypes,
|
filetypes = (servers[server_name] or {}).filetypes,
|
||||||
}
|
}
|
||||||
@ -186,7 +189,7 @@ local setup_godot_dap = function()
|
|||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
vim.diagnostic.config({ virtual_lines = true })
|
vim.diagnostic.config({ virtual_text = true })
|
||||||
vim.lsp.enable({ "ltex_plus" })
|
vim.lsp.enable({ "ltex_plus" })
|
||||||
|
|
||||||
setup_godot_dap()
|
setup_godot_dap()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user