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
|
local on_attach = require('myConfig.exports').on_attach
require("rust-tools").setup {
server = {
cmd = { vim.g.rust_analyzer_path },
settings = {
["rust-analyzer"] = {
checkOnSave = {
command = "clippy",
},
experimental = {
procAttrMacros = true,
},
},
},
on_attach = on_attach,
},
}
-- TODO: setup nvim-cmp completion score
require("clangd_extensions").setup {
server = {
cmd = { vim.g.clangd_path },
}
}
require("neodev").setup({})
-- Refactoring
require("refactoring").setup {}
-- Null LSP
local null_ls = require("null-ls")
null_ls.setup({
sources = {
null_ls.builtins.code_actions.gitrebase,
null_ls.builtins.code_actions.gitsigns,
null_ls.builtins.code_actions.refactoring.with {
filetypes = { "typescript", "javascript", "lua", "c", "cpp", "go", "python", "java", "php", "ruby" },
},
null_ls.builtins.code_actions.shellcheck,
null_ls.builtins.code_actions.statix,
null_ls.builtins.diagnostics.deadnix,
null_ls.builtins.diagnostics.shellcheck,
null_ls.builtins.diagnostics.statix,
null_ls.builtins.diagnostics.vale.with {
filetypes = { "markdown", "pandoc", "rst", "tex", "asciidoc" },
},
null_ls.builtins.formatting.alejandra,
null_ls.builtins.formatting.shfmt,
null_ls.builtins.formatting.taplo,
},
on_attach = on_attach,
})
-- Vim Pandoc
vim.g["pandoc#formatting#equalprg"] = "pandoc -t markdown --wrap=preserve"
vim.g["pandoc#formatting#extra_equalprg"] = "--reference-links --reference-location=section"
-- Actions preview
require("actions-preview").setup()
|