init.lua 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. local M = {}
  2. local Log = require "core.log"
  3. function M.config()
  4. vim.lsp.protocol.CompletionItemKind = lvim.lsp.completion.item_kind
  5. for _, sign in ipairs(lvim.lsp.diagnostics.signs.values) do
  6. vim.fn.sign_define(sign.name, { texthl = sign.name, text = sign.text, numhl = sign.name })
  7. end
  8. require("lsp.handlers").setup()
  9. end
  10. local function lsp_highlight_document(client)
  11. if lvim.lsp.document_highlight == false then
  12. return -- we don't need further
  13. end
  14. -- Set autocommands conditional on server_capabilities
  15. if client.resolved_capabilities.document_highlight then
  16. vim.api.nvim_exec(
  17. [[
  18. hi LspReferenceRead cterm=bold ctermbg=red guibg=#464646
  19. hi LspReferenceText cterm=bold ctermbg=red guibg=#464646
  20. hi LspReferenceWrite cterm=bold ctermbg=red guibg=#464646
  21. augroup lsp_document_highlight
  22. autocmd! * <buffer>
  23. autocmd CursorHold <buffer> lua vim.lsp.buf.document_highlight()
  24. autocmd CursorMoved <buffer> lua vim.lsp.buf.clear_references()
  25. augroup END
  26. ]],
  27. false
  28. )
  29. end
  30. end
  31. local function add_lsp_buffer_keybindings(bufnr)
  32. local status_ok, wk = pcall(require, "which-key")
  33. if not status_ok then
  34. return
  35. end
  36. local keys = {
  37. ["K"] = { "<cmd>lua vim.lsp.buf.hover()<CR>", "Show hover" },
  38. ["gd"] = { "<cmd>lua vim.lsp.buf.definition()<CR>", "Goto Definition" },
  39. ["gD"] = { "<cmd>lua vim.lsp.buf.declaration()<CR>", "Goto declaration" },
  40. ["gr"] = { "<cmd>lua vim.lsp.buf.references()<CR>", "Goto references" },
  41. ["gi"] = { "<cmd>lua vim.lsp.buf.implementation()<CR>", "Goto implementation" },
  42. ["gs"] = { "<cmd>lua vim.lsp.buf.signature_help()<CR>", "show signature help" },
  43. ["gp"] = { "<cmd>lua require'lsp.peek'.Peek('definition')<CR>", "Peek definition" },
  44. ["gl"] = {
  45. "<cmd>lua vim.lsp.diagnostic.show_line_diagnostics({ show_header = false, border = 'single' })<CR>",
  46. "Show line diagnostics",
  47. },
  48. }
  49. wk.register(keys, { mode = "n", buffer = bufnr })
  50. end
  51. function M.common_capabilities()
  52. local capabilities = vim.lsp.protocol.make_client_capabilities()
  53. capabilities.textDocument.completion.completionItem.snippetSupport = true
  54. capabilities.textDocument.completion.completionItem.resolveSupport = {
  55. properties = {
  56. "documentation",
  57. "detail",
  58. "additionalTextEdits",
  59. },
  60. }
  61. return capabilities
  62. end
  63. function M.get_ls_capabilities(client_id)
  64. local client
  65. if not client_id then
  66. local buf_clients = vim.lsp.buf_get_clients()
  67. for _, buf_client in ipairs(buf_clients) do
  68. if buf_client.name ~= "null-ls" then
  69. client_id = buf_client.id
  70. break
  71. end
  72. end
  73. end
  74. if not client_id then
  75. error "Unable to determine client_id"
  76. end
  77. client = vim.lsp.get_client_by_id(tonumber(client_id))
  78. local enabled_caps = {}
  79. for k, v in pairs(client.resolved_capabilities) do
  80. if v == true then
  81. table.insert(enabled_caps, k)
  82. end
  83. end
  84. return enabled_caps
  85. end
  86. function M.common_on_init(client, bufnr)
  87. if lvim.lsp.on_init_callback then
  88. lvim.lsp.on_init_callback(client, bufnr)
  89. Log:get_default().info "Called lsp.on_init_callback"
  90. return
  91. end
  92. local formatters = lvim.lang[vim.bo.filetype].formatters
  93. if not vim.tbl_isempty(formatters) and formatters[1]["exe"] ~= nil and formatters[1].exe ~= "" then
  94. client.resolved_capabilities.document_formatting = false
  95. Log:get_default().info(
  96. string.format("Overriding language server [%s] with format provider [%s]", client.name, formatters[1].exe)
  97. )
  98. end
  99. end
  100. function M.common_on_attach(client, bufnr)
  101. if lvim.lsp.on_attach_callback then
  102. lvim.lsp.on_attach_callback(client, bufnr)
  103. Log:get_default().info "Called lsp.on_init_callback"
  104. end
  105. lsp_highlight_document(client)
  106. add_lsp_buffer_keybindings(bufnr)
  107. require("lsp.null-ls").setup(vim.bo.filetype)
  108. end
  109. function M.setup(lang)
  110. local lsp_utils = require "lsp.utils"
  111. local lsp = lvim.lang[lang].lsp
  112. if lsp_utils.is_client_active(lsp.provider) then
  113. return
  114. end
  115. local overrides = lvim.lsp.override
  116. if type(overrides) == "table" then
  117. if vim.tbl_contains(overrides, lang) then
  118. return
  119. end
  120. end
  121. if lsp.provider ~= nil and lsp.provider ~= "" then
  122. local lspconfig = require "lspconfig"
  123. if not lsp.setup.on_attach then
  124. lsp.setup.on_attach = M.common_on_attach
  125. end
  126. if not lsp.setup.on_init then
  127. lsp.setup.on_init = M.common_on_init
  128. end
  129. if not lsp.setup.capabilities then
  130. lsp.setup.capabilities = M.common_capabilities()
  131. end
  132. lspconfig[lsp.provider].setup(lsp.setup)
  133. end
  134. end
  135. return M