init.lua 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. -- TODO figure out why this don't work
  2. vim.fn.sign_define("LspDiagnosticsSignError",
  3. {texthl = "LspDiagnosticsSignError", text = "", numhl = "LspDiagnosticsSignError"})
  4. vim.fn.sign_define("LspDiagnosticsSignWarning",
  5. {texthl = "LspDiagnosticsSignWarning", text = "", numhl = "LspDiagnosticsSignWarning"})
  6. vim.fn.sign_define("LspDiagnosticsSignInformation",
  7. {texthl = "LspDiagnosticsSignInformation", text = "", numhl = "LspDiagnosticsSignInformation"})
  8. vim.fn.sign_define("LspDiagnosticsSignHint",
  9. {texthl = "LspDiagnosticsSignHint", text = "", numhl = "LspDiagnosticsSignHint"})
  10. vim.cmd('nnoremap <silent> gd <cmd>lua vim.lsp.buf.definition()<CR>')
  11. vim.cmd('nnoremap <silent> gD <cmd>lua vim.lsp.buf.declaration()<CR>')
  12. vim.cmd('nnoremap <silent> gr <cmd>lua vim.lsp.buf.references()<CR>')
  13. vim.cmd('nnoremap <silent> gi <cmd>lua vim.lsp.buf.implementation()<CR>')
  14. vim.cmd('nnoremap <silent> ca :Lspsaga code_action<CR>')
  15. vim.cmd('nnoremap <silent> K :Lspsaga hover_doc<CR>')
  16. -- vim.cmd('nnoremap <silent> <C-k> <cmd>lua vim.lsp.buf.signature_help()<CR>')
  17. vim.cmd('nnoremap <silent> <C-p> :Lspsaga diagnostic_jump_prev<CR>')
  18. vim.cmd('nnoremap <silent> <C-n> :Lspsaga diagnostic_jump_next<CR>')
  19. -- scroll down hover doc or scroll in definition preview
  20. vim.cmd('nnoremap <silent> <C-f> <cmd>lua require(\'lspsaga.action\').smart_scroll_with_saga(1)<CR>')
  21. -- scroll up hover doc
  22. vim.cmd('nnoremap <silent> <C-b> <cmd>lua require(\'lspsaga.action\').smart_scroll_with_saga(-1)<CR>')
  23. vim.cmd('command! -nargs=0 LspVirtualTextToggle lua require("lsp/virtual_text").toggle()')
  24. --[[ " autoformat
  25. autocmd BufWritePre *.js lua vim.lsp.buf.formatting_sync(nil, 100)
  26. autocmd BufWritePre *.jsx lua vim.lsp.buf.formatting_sync(nil, 100)
  27. autocmd BufWritePre *.lua lua vim.lsp.buf.formatting_sync(nil, 100) ]]
  28. -- Java
  29. -- autocmd FileType java nnoremap ca <Cmd>lua require('jdtls').code_action()<CR>
  30. local function documentHighlight(client, bufnr)
  31. -- Set autocommands conditional on server_capabilities
  32. if client.resolved_capabilities.document_highlight then
  33. vim.api.nvim_exec([[
  34. hi LspReferenceRead cterm=bold ctermbg=red guibg=#464646
  35. hi LspReferenceText cterm=bold ctermbg=red guibg=#464646
  36. hi LspReferenceWrite cterm=bold ctermbg=red guibg=#464646
  37. augroup lsp_document_highlight
  38. autocmd! * <buffer>
  39. autocmd CursorHold <buffer> lua vim.lsp.buf.document_highlight()
  40. autocmd CursorMoved <buffer> lua vim.lsp.buf.clear_references()
  41. augroup END
  42. ]], false)
  43. end
  44. end
  45. local lsp_config = {}
  46. function lsp_config.common_on_attach(client, bufnr)
  47. documentHighlight(client, bufnr)
  48. end
  49. function lsp_config.tsserver_on_attach(client, bufnr)
  50. lsp_config.common_on_attach(client, bufnr)
  51. client.resolved_capabilities.document_formatting = false
  52. end
  53. -- Use a loop to conveniently both setup defined servers
  54. -- and map buffer local keybindings when the language server attaches
  55. -- local servers = {"pyright", "tsserver"}
  56. -- for _, lsp in ipairs(servers) do nvim_lsp[lsp].setup {on_attach = on_attach} end
  57. return lsp_config