nvim-config/lua/plugins/lsp.lua

131 lines
4.4 KiB
Lua
Raw Permalink Normal View History

2023-02-10 21:20:55 -08:00
return {
"neovim/nvim-lspconfig",
dependencies = {
-- Useful status updates for LSP
"j-hui/fidget.nvim",
-- Additional lua configuration, makes nvim stuff amazing
"folke/neodev.nvim",
2024-09-21 20:11:13 -07:00
-- schemas for json and yaml files
"b0o/schemastore.nvim",
2023-02-10 21:20:55 -08:00
},
config = function()
-- LSP settings.
2024-09-07 11:12:10 -07:00
-- Require the lspconfig module
local lspconfig = require("lspconfig")
2023-02-10 21:20:55 -08:00
-- This function gets run when an LSP connects to a particular buffer.
local on_attach = function(_, bufnr)
2024-11-09 10:43:20 -08:00
-- We create a function that lets us more easily define mappings specific
2023-02-10 21:20:55 -08:00
-- for LSP related items. It sets the mode, buffer and description for us each time.
local nmap = function(keys, func, desc)
if desc then
desc = "LSP: " .. desc
end
vim.keymap.set("n", keys, func, { buffer = bufnr, desc = desc })
end
nmap("<leader>rn", vim.lsp.buf.rename, "[R]e[n]ame")
nmap("<leader>ca", vim.lsp.buf.code_action, "[C]ode [A]ction")
nmap("gd", vim.lsp.buf.definition, "[G]oto [D]efinition")
nmap("gr", require("telescope.builtin").lsp_references, "[G]oto [R]eferences")
nmap("gI", vim.lsp.buf.implementation, "[G]oto [I]mplementation")
nmap("<leader>D", vim.lsp.buf.type_definition, "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
nmap("K", vim.lsp.buf.hover, "Hover Documentation")
nmap("<C-k>", vim.lsp.buf.signature_help, "Signature Documentation")
-- Lesser used LSP functionality
nmap("gD", vim.lsp.buf.declaration, "[G]oto [D]eclaration")
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")
-- 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
local servers = {
2024-11-09 10:43:20 -08:00
basedpyright = {
analysis = {
autoImportCompletions = true,
autoSearchPaths = true,
diagnosticMode = "openFilesOnly",
reportMissingImports = true,
reportMissingParameterType = true,
reportUnnecessaryComparison = true,
reportUnnecessaryContains = true,
reportUnusedClass = true,
reportUnusedFunction = true,
reportUnsedImports = true,
reportUnsusedVariables = true,
typeCheckingMode = "all",
useLibraryCodeForTypes = true,
},
},
2023-10-20 22:44:25 -07:00
bashls = {
bashIde = {
2024-03-23 09:42:10 -07:00
globPattern = "*@(.sh|.inc|.bash|.command)",
},
2023-10-20 22:44:25 -07:00
},
html = {},
jqls = {},
2024-09-21 20:11:13 -07:00
jsonls = {
json = {
format = {
enable = true,
},
schemas = require("schemastore").json.schemas(),
validate = true,
},
},
2024-11-09 10:43:20 -08:00
lua_ls = {
Lua = {
diagnostics = { globals = { "vim" } },
workspace = { checkThirdParty = false },
telemetry = { enable = false },
},
},
2023-10-20 22:44:25 -07:00
marksman = {},
2024-06-07 23:18:34 -07:00
nil_ls = {},
2024-09-07 10:04:14 -07:00
nixd = {},
2024-03-23 09:42:10 -07:00
rust_analyzer = {
diagnostics = {
enable = true,
},
},
2024-11-09 10:43:20 -08:00
sourcekit = {
workspace = {
didChangeConfiguration = {
dynamicRegistration = true,
},
},
},
2024-09-07 10:04:14 -07:00
ts_ls = {},
2023-10-20 22:44:25 -07:00
yamlls = {},
2023-02-10 21:20:55 -08:00
}
-- nvim-cmp supports additional completion capabilities, so broadcast that to servers
local capabilities = vim.lsp.protocol.make_client_capabilities()
capabilities = require("cmp_nvim_lsp").default_capabilities(capabilities)
2024-09-07 11:12:10 -07:00
-- Iterate over the servers table and configure each one
for server, config in pairs(servers) do
-- Set up the server using the `config` if provided, otherwise just `on_attach` and `capabilities`
lspconfig[server].setup({
on_attach = on_attach,
capabilities = capabilities,
settings = config, -- Pass the specific server settings here
})
end
2023-02-10 21:20:55 -08:00
end,
}