1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
|
local config = function()
local lsp = vim.lsp
local capabilities = require("cmp_nvim_lsp").default_capabilities()
-- setting custom signs
local signs = { Error = "", Warn = "", Hint = "", Info = "" }
for type, icon in pairs(signs) do
local hl = "DiagnosticSign" .. type
vim.fn.sign_define(hl, { text = icon, texthl = hl, numhl = "" })
end
vim.api.nvim_create_autocmd('LspAttach', {
callback = function(ev)
local client = lsp.get_client_by_id(ev.data.client_id)
local keymap = vim.keymap
local opts = { noremap = true, silent = true, buffer = ev.buf, desc = "" }
-- setting custom keymaps
opts.desc = "Finder"
keymap.set("n", "<Space>lf", ":Lspsaga finder<Enter>", opts) -- go to definition
opts.desc = "Peek Definition (Lspsaga)"
keymap.set("n", "<Space>lp", ":Lspsaga peek_definition<Enter>", opts) -- peak definition
opts.desc = "Goto Definition (Lspsaga)"
keymap.set("n", "<Space>lg", ":Lspsaga goto_definition<Enter>", opts) -- go to definition
opts.desc = "Code Action (Lspsaga)"
keymap.set("n", "<Space>la", ":Lspsaga code_action<Enter>", opts) -- see available code actions
opts.desc = "Rename (Lspsaga)"
keymap.set("n", "<Space>lr", ":Lspsaga rename<Enter>", opts) -- smart rename
opts.desc = "Hover Documentation (Lspsaga)"
keymap.set("n", "<Space>lk", lsp.buf.hover, opts) -- show documentation for what is under cursor
opts.desc = "Outline (Lspsaga)"
keymap.set("n", "<Space>lo", ":Lspsaga outline<Enter>", opts) -- show outline
opts.desc = "Diagnostic (Lspsaga)"
keymap.set("n", "<Space>ld", ":Lspsaga show_workspace_diagnostics<Enter>", opts) -- show diagnostics
-- enable auto formatting on save
if client ~= nil and client:supports_method("textDocument/formatting") then
vim.api.nvim_create_autocmd("BufWritePre", {
buffer = ev.buf,
callback = function()
lsp.buf.format({ async = true })
end,
})
end
end
})
vim.api.nvim_create_autocmd('LspDetach', {
callback = function(ev)
local client = lsp.get_client_by_id(ev.data.client_id)
local keymap = vim.keymap
keymap.del("n", "<Space>lf")
keymap.del("n", "<Space>lp")
keymap.del("n", "<Space>lg")
keymap.del("n", "<Space>la")
keymap.del("n", "<Space>lr")
keymap.del("n", "<Space>lk")
keymap.del("n", "<Space>lo")
keymap.del("n", "<Space>ld")
if client ~= nil and client:supports_method('textDocument/formatting') then
vim.api.nvim_clear_autocmds({
event = 'BufWritePre',
buffer = ev.buf,
})
end
end,
})
-- C/C++
lsp.enable("clangd")
lsp.config("clangd", {
capabilities = capabilities,
})
-- Rust
lsp.enable("rust_analyzer")
lsp.config("rust_analyzer", {
capabilities = capabilities,
})
-- Haskell
lsp.enable("hls")
lsp.config("hls", {
capabilities = capabilities,
settings = {
['haskell'] = {
cabalFormattingProvider = "cabal-fmt",
formattingProvider = "ormolu"
},
},
})
-- Lua
lsp.enable("lua_ls")
lsp.config("lua_ls", {
capabilities = capabilities,
})
-- JavaScript/Typescript
lsp.enable("ts_ls")
lsp.config("ts_ls", {
capabilities = capabilities,
})
-- CSS
lsp.enable("cssls")
lsp.config("cssls", {
capabilities = capabilities,
})
-- Meson
lsp.enable("mesonlsp")
lsp.config("mesonlsp", {
capabilities = capabilities,
})
-- Zig
lsp.enable("zls")
lsp.config("zls", {
capabilities = capabilities,
})
end
return {
"neovim/nvim-lspconfig",
config = config,
lazy = true,
event = { "BufReadPost", "BufWritePost", "BufNewFile" }
}
|