init.lua 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. -- TODO figure out why this don't work
  2. vim.fn.sign_define(
  3. "LspDiagnosticsSignError",
  4. {texthl = "LspDiagnosticsSignError", text = "", numhl = "LspDiagnosticsSignError"}
  5. )
  6. vim.fn.sign_define(
  7. "LspDiagnosticsSignWarning",
  8. {texthl = "LspDiagnosticsSignWarning", text = "", numhl = "LspDiagnosticsSignWarning"}
  9. )
  10. vim.fn.sign_define(
  11. "LspDiagnosticsSignHint",
  12. {texthl = "LspDiagnosticsSignHint", text = "", numhl = "LspDiagnosticsSignHint"}
  13. )
  14. vim.fn.sign_define(
  15. "LspDiagnosticsSignInformation",
  16. {texthl = "LspDiagnosticsSignInformation", text = "", numhl = "LspDiagnosticsSignInformation"}
  17. )
  18. vim.cmd("nnoremap <silent> gd <cmd>lua vim.lsp.buf.definition()<CR>")
  19. vim.cmd("nnoremap <silent> gD <cmd>lua vim.lsp.buf.declaration()<CR>")
  20. vim.cmd("nnoremap <silent> gr <cmd>lua vim.lsp.buf.references()<CR>")
  21. vim.cmd("nnoremap <silent> gi <cmd>lua vim.lsp.buf.implementation()<CR>")
  22. vim.cmd("nnoremap <silent> K :Lspsaga hover_doc<CR>")
  23. -- vim.cmd('nnoremap <silent> <C-k> <cmd>lua vim.lsp.buf.signature_help()<CR>')
  24. vim.cmd("nnoremap <silent> <C-p> :Lspsaga diagnostic_jump_prev<CR>")
  25. vim.cmd("nnoremap <silent> <C-n> :Lspsaga diagnostic_jump_next<CR>")
  26. -- scroll down hover doc or scroll in definition preview
  27. vim.cmd("nnoremap <silent> <C-f> <cmd>lua require('lspsaga.action').smart_scroll_with_saga(1)<CR>")
  28. -- scroll up hover doc
  29. vim.cmd("nnoremap <silent> <C-b> <cmd>lua require('lspsaga.action').smart_scroll_with_saga(-1)<CR>")
  30. vim.cmd('command! -nargs=0 LspVirtualTextToggle lua require("lsp/virtual_text").toggle()')
  31. -- Set Default Prefix.
  32. -- Note: You can set a prefix per lsp server in the lv-globals.lua file
  33. vim.lsp.handlers["textDocument/publishDiagnostics"] = vim.lsp.with(
  34. vim.lsp.diagnostic.on_publish_diagnostics, {
  35. virtual_text = {
  36. prefix = "",
  37. spacing = 0,
  38. },
  39. signs = true,
  40. underline = true,
  41. }
  42. )
  43. -- symbols for autocomplete
  44. vim.lsp.protocol.CompletionItemKind = {
  45. "  (Text) ",
  46. "  (Method)",
  47. "  (Function)",
  48. "  (Constructor)",
  49. " ﴲ (Field)",
  50. "[] (Variable)",
  51. "  (Class)",
  52. " ﰮ (Interface)",
  53. "  (Module)",
  54. " 襁 (Property)",
  55. "  (Unit)",
  56. "  (Value)",
  57. " 練 (Enum)",
  58. "  (Keyword)",
  59. "  (Snippet)",
  60. "  (Color)",
  61. "  (File)",
  62. "  (Reference)",
  63. "  (Folder)",
  64. "  (EnumMember)",
  65. " ﲀ (Constant)",
  66. " ﳤ (Struct)",
  67. "  (Event)",
  68. "  (Operator)",
  69. "  (TypeParameter)"
  70. }
  71. --[[ " autoformat
  72. autocmd BufWritePre *.js lua vim.lsp.buf.formatting_sync(nil, 100)
  73. autocmd BufWritePre *.jsx lua vim.lsp.buf.formatting_sync(nil, 100)
  74. autocmd BufWritePre *.lua lua vim.lsp.buf.formatting_sync(nil, 100) ]]
  75. -- Java
  76. -- autocmd FileType java nnoremap ca <Cmd>lua require('jdtls').code_action()<CR>
  77. local function documentHighlight(client, bufnr)
  78. -- Set autocommands conditional on server_capabilities
  79. if client.resolved_capabilities.document_highlight then
  80. vim.api.nvim_exec(
  81. [[
  82. hi LspReferenceRead cterm=bold ctermbg=red guibg=#464646
  83. hi LspReferenceText cterm=bold ctermbg=red guibg=#464646
  84. hi LspReferenceWrite cterm=bold ctermbg=red guibg=#464646
  85. augroup lsp_document_highlight
  86. autocmd! * <buffer>
  87. autocmd CursorHold <buffer> lua vim.lsp.buf.document_highlight()
  88. autocmd CursorMoved <buffer> lua vim.lsp.buf.clear_references()
  89. augroup END
  90. ]],
  91. false
  92. )
  93. end
  94. end
  95. local lsp_config = {}
  96. if O.document_highlight then
  97. function lsp_config.common_on_attach(client, bufnr)
  98. documentHighlight(client, bufnr)
  99. end
  100. end
  101. function lsp_config.tsserver_on_attach(client, bufnr)
  102. -- lsp_config.common_on_attach(client, bufnr)
  103. client.resolved_capabilities.document_formatting = false
  104. local ts_utils = require("nvim-lsp-ts-utils")
  105. -- defaults
  106. ts_utils.setup {
  107. debug = false,
  108. disable_commands = false,
  109. enable_import_on_completion = false,
  110. import_all_timeout = 5000, -- ms
  111. -- eslint
  112. eslint_enable_code_actions = true,
  113. eslint_enable_disable_comments = true,
  114. eslint_bin = O.lang.tsserver.linter,
  115. eslint_config_fallback = nil,
  116. eslint_enable_diagnostics = true,
  117. -- formatting
  118. enable_formatting = O.lang.tsserver.autoformat,
  119. formatter = O.lang.tsserver.formatter,
  120. formatter_config_fallback = nil,
  121. -- parentheses completion
  122. complete_parens = false,
  123. signature_help_in_parens = false,
  124. -- update imports on file move
  125. update_imports_on_move = false,
  126. require_confirmation_on_move = false,
  127. watch_dir = nil,
  128. }
  129. -- required to fix code action ranges
  130. ts_utils.setup_client(client)
  131. -- TODO: keymap these?
  132. -- vim.api.nvim_buf_set_keymap(bufnr, "n", "gs", ":TSLspOrganize<CR>", {silent = true})
  133. -- vim.api.nvim_buf_set_keymap(bufnr, "n", "qq", ":TSLspFixCurrent<CR>", {silent = true})
  134. -- vim.api.nvim_buf_set_keymap(bufnr, "n", "gr", ":TSLspRenameFile<CR>", {silent = true})
  135. -- vim.api.nvim_buf_set_keymap(bufnr, "n", "gi", ":TSLspImportAll<CR>", {silent = true})
  136. end
  137. require('lv-utils').define_augroups({
  138. _general_lsp = {
  139. {'FileType', 'lspinfo', 'nnoremap <silent> <buffer> q :q<CR>'},
  140. }
  141. })
  142. -- Use a loop to conveniently both setup defined servers
  143. -- and map buffer local keybindings when the language server attaches
  144. -- local servers = {"pyright", "tsserver"}
  145. -- for _, lsp in ipairs(servers) do nvim_lsp[lsp].setup {on_attach = on_attach} end
  146. return lsp_config