Dotfiles/site-modules/core/files/vim/plugin/lsp.lua

150 lines
5.3 KiB
Lua
Raw Normal View History

local lspconfig = require "lspconfig"
2022-06-12 19:25:17 +00:00
local workspace_library = vim.api.nvim_get_runtime_file("lua", true)
2023-11-24 08:01:34 +00:00
table.insert(workspace_library, os.getenv "HOME" .. "/Code/src/github.com/AdeAttwood/Configz/definitions/configz.lua")
local function has_file(file)
return vim.fn.filereadable(vim.fn.getcwd() .. "/" .. file) == 1
end
local servers = {
-- Language servers for the day to day web development, could probably think
2023-01-20 07:55:11 +00:00
-- about loosing the html and css one and living with typescript, rescript
-- and emmet
ts_ls = { enabled = has_file "tsconfig.json" or has_file "yarn.lock" },
2024-11-28 18:17:23 +00:00
denols = { enabled = has_file "deno.json" or has_file "deno.jsonc" },
html = {},
cssls = {},
marksman = {},
nushell = {},
clojure_lsp = {},
emmet_ls = {
filetypes = { "html", "typescriptreact", "javascriptreact", "css", "scss", "eruby", "liquid" },
},
-- Ruby
solargraph = {
cmd = { "bundle", "exec", "solargraph", "stdio" },
},
-- Rust
rust_analyzer = {
settings = {
["rust-analyzer"] = {
checkOnSave = {
command = "clippy",
},
},
},
},
-- Lua for the vim config and plugin dev
lua_ls = {
settings = {
Lua = {
telemetry = { enable = false },
runtime = { version = "LuaJIT" },
diagnostics = {
globals = { "vim", "configz", "describe", "it", "assert", "spy", "stub", "before_each", "after_each" },
},
workspace = {
library = workspace_library,
checkThirdParty = false,
},
},
},
},
2024-05-03 06:26:20 +00:00
csharp_ls = {
handlers = {
["textDocument/definition"] = require("csharpls_extended").handler,
["textDocument/typeDefinition"] = require("csharpls_extended").handler,
},
},
}
local on_attach = function(_, bufnr)
vim.api.nvim_buf_set_option(bufnr, "omnifunc", "v:lua.vim.lsp.omnifunc")
2022-06-12 19:25:17 +00:00
local opts = { noremap = true, silent = true }
2022-06-12 19:25:17 +00:00
-- Mappings.
-- See `:help vim.lsp.*` for documentation on any of the below functions
vim.api.nvim_buf_set_keymap(bufnr, "n", "gD", "<cmd>lua vim.lsp.buf.declaration()<CR>", opts)
vim.api.nvim_buf_set_keymap(bufnr, "n", "gd", "<cmd>lua vim.lsp.buf.definition()<CR>", opts)
vim.api.nvim_buf_set_keymap(bufnr, "n", "K", "<cmd>lua vim.lsp.buf.hover()<CR>", opts)
vim.api.nvim_buf_set_keymap(bufnr, "n", "gi", "<cmd>lua vim.lsp.buf.implementation()<CR>", opts)
vim.api.nvim_buf_set_keymap(bufnr, "n", "gr", "<cmd>lua vim.lsp.buf.references()<CR>", opts)
2022-06-12 19:25:17 +00:00
vim.api.nvim_buf_set_keymap(bufnr, "n", "<leader>rn", "<cmd>lua vim.lsp.buf.rename()<CR>", opts)
vim.api.nvim_buf_set_keymap(bufnr, "n", "<leader>ca", "<cmd>lua vim.lsp.buf.code_action()<CR>", opts)
vim.api.nvim_create_augroup("lsp_document_highlight", { clear = true })
vim.api.nvim_create_autocmd({ "CursorHold", "CursorHoldI" }, {
buffer = bufnr,
2023-11-24 08:01:34 +00:00
callback = function()
-- Highlight document symbles for every file type other erb files because
-- solargraph only supports textDocument/documentHighlight in rb files.
local file_type = vim.api.nvim_buf_get_option(0, "filetype")
if file_type ~= "eruby" and file_type ~= "markdown" and file_type ~= "liquid" and file_type ~= "nu" then
vim.lsp.buf.document_highlight()
end
end,
group = "lsp_document_highlight",
desc = "Document Highlight",
})
vim.api.nvim_create_autocmd("CursorMoved", {
buffer = bufnr,
2023-11-24 08:01:34 +00:00
callback = function()
vim.lsp.buf.clear_references()
end,
group = "lsp_document_highlight",
desc = "Clear All the References",
})
2022-06-12 19:25:17 +00:00
end
local capabilities = require("cmp_nvim_lsp").default_capabilities(vim.lsp.protocol.make_client_capabilities())
2022-06-12 19:25:17 +00:00
capabilities.textDocument.completion.completionItem.snippetSupport = true
for lsp, config in pairs(servers) do
config["on_attach"] = on_attach
config["capabilities"] = capabilities
config["init_options"] = { usePlaceholders = true }
2022-06-12 19:25:17 +00:00
lspconfig[lsp].setup(config)
end
2024-11-28 18:17:23 +00:00
require("ionide").setup { on_attach = on_attach, capabilities = capabilities }
2024-05-03 06:26:20 +00:00
2022-06-12 19:25:17 +00:00
-- Change the diagnostic signs
vim.fn.sign_define("DiagnosticSignHint", { text = "", texthl = "DiagnosticSignHint", numhl = "DiagnosticSignHint" })
vim.fn.sign_define("DiagnosticSignInfo", { text = "", texthl = "DiagnosticSignInfo", numhl = "DiagnosticSignInfo" })
vim.fn.sign_define("DiagnosticSignWarn", { text = "", texthl = "DiagnosticSignWarn", numhl = "DiagnosticSignWarn" })
2022-12-22 20:12:50 +00:00
vim.fn.sign_define(
"DiagnosticSignError",
{ text = "", texthl = "DiagnosticSignError", numhl = "DiagnosticSignError" }
2022-12-22 20:12:50 +00:00
)
2023-11-24 08:01:34 +00:00
local border = "rounded"
2023-11-24 08:01:34 +00:00
vim.lsp.handlers["textDocument/hover"] = vim.lsp.with(vim.lsp.handlers.hover, { border = border })
vim.lsp.handlers["textDocument/show_line_diagnostics"] = vim.lsp.with(vim.lsp.handlers.hover, { border = border })
vim.lsp.handlers["textDocument/diagnostic"] = vim.lsp.with(vim.lsp.handlers.hover, { border = border })
vim.lsp.handlers["textDocument/diagnostics"] = vim.lsp.with(vim.lsp.handlers.hover, { border = border })
vim.diagnostic.config {
float = {
2023-11-24 08:01:34 +00:00
focusable = false,
border = border,
},
virtual_text = {
prefix = "",
},
2023-11-24 08:01:34 +00:00
}
2023-11-24 08:01:34 +00:00
vim.cmd [[set updatetime=1000]]
vim.api.nvim_create_augroup("diagnostic_float", { clear = true })
vim.api.nvim_create_autocmd({ "CursorHold", "CursorHoldI" }, {
2023-11-24 08:01:34 +00:00
callback = function()
vim.diagnostic.open_float()
end,
group = "diagnostic_float",
desc = "Open Diagnostic Float",
})