return { { -- Main LSP Configuration 'neovim/nvim-lspconfig', dependencies = { -- Automatically install LSPs and related tools to stdpath for Neovim -- Mason must be loaded before its dependents so we need to set it up here. { 'mason-org/mason.nvim', opts = { registries = { 'github:mason-org/mason-registry', 'github:Crashdummyy/mason-registry', }, }, }, { 'mason-org/mason-lspconfig.nvim', opts = {} }, 'WhoIsSethDaniel/mason-tool-installer.nvim', -- Useful status updates for LSP. { 'j-hui/fidget.nvim', opts = {} }, -- Allows extra capabilities provided by blink.cmp 'saghen/blink.cmp', -- Roslyn { 'seblyng/roslyn.nvim', ft = 'cs', opts = {} }, -- SchemaStores for yamlls and jsonls 'b0o/schemastore.nvim', }, config = function() vim.api.nvim_create_autocmd('LspAttach', { group = vim.api.nvim_create_augroup('kickstart-lsp-attach', { clear = true }), callback = function(event) local map = function(keys, func, desc, mode) mode = mode or 'n' vim.keymap.set(mode, keys, func, { buffer = event.buf, desc = 'LSP: ' .. desc }) end -- Rename the variable under your cursor. -- Most Language Servers support renaming across files, etc. map('grn', vim.lsp.buf.rename, '[R]e[n]ame') -- Execute a code action, usually your cursor needs to be on top of an error -- or a suggestion from your LSP for this to activate. map('gra', vim.lsp.buf.code_action, '[G]oto Code [A]ction', { 'n', 'x' }) -- Find references for the word under your cursor. map('grr', require('telescope.builtin').lsp_references, '[G]oto [R]eferences') -- Jump to the implementation of the word under your cursor. -- Useful when your language has ways of declaring types without an actual implementation. map('gri', require('telescope.builtin').lsp_implementations, '[G]oto [I]mplementation') -- Jump to the definition of the word under your cursor. -- This is where a variable was first declared, or where a function is defined, etc. -- To jump back, press . map('grd', require('telescope.builtin').lsp_definitions, '[G]oto [D]efinition') -- WARN: This is not Goto Definition, this is Goto Declaration. -- For example, in C this would take you to the header. map('grD', vim.lsp.buf.declaration, '[G]oto [D]eclaration') -- Fuzzy find all the symbols in your current document. -- Symbols are things like variables, functions, types, etc. map('gO', require('telescope.builtin').lsp_document_symbols, 'Open Document Symbols') -- Fuzzy find all the symbols in your current workspace. -- Similar to document symbols, except searches over your entire project. map('gW', require('telescope.builtin').lsp_dynamic_workspace_symbols, 'Open Workspace Symbols') -- Jump to the type of the word under your cursor. -- Useful when you're not sure what type a variable is and you want to see -- the definition of its *type*, not where it was *defined*. map('grt', require('telescope.builtin').lsp_type_definitions, '[G]oto [T]ype Definition') -- This function resolves a difference between neovim nightly (version 0.11) and stable (version 0.10) ---@param client vim.lsp.Client ---@param method vim.lsp.protocol.Method ---@param bufnr? integer some lsp support methods only in specific files ---@return boolean local function client_supports_method(client, method, bufnr) if vim.fn.has 'nvim-0.11' == 1 then return client:supports_method(method, bufnr) else return client.supports_method(method, { bufnr = bufnr }) end end -- The following two autocommands are used to highlight references of the -- word under your cursor when your cursor rests there for a little while. -- See `:help CursorHold` for information about when this is executed -- -- When you move your cursor, the highlights will be cleared (the second autocommand). local client = vim.lsp.get_client_by_id(event.data.client_id) if client and client_supports_method(client, vim.lsp.protocol.Methods.textDocument_documentHighlight, event.buf) then local highlight_augroup = vim.api.nvim_create_augroup('kickstart-lsp-highlight', { clear = false }) vim.api.nvim_create_autocmd({ 'CursorHold', 'CursorHoldI' }, { buffer = event.buf, group = highlight_augroup, callback = vim.lsp.buf.document_highlight, }) vim.api.nvim_create_autocmd({ 'CursorMoved', 'CursorMovedI' }, { buffer = event.buf, group = highlight_augroup, callback = vim.lsp.buf.clear_references, }) vim.api.nvim_create_autocmd('LspDetach', { group = vim.api.nvim_create_augroup('kickstart-lsp-detach', { clear = true }), callback = function(event2) vim.lsp.buf.clear_references() vim.api.nvim_clear_autocmds { group = 'kickstart-lsp-highlight', buffer = event2.buf } end, }) end -- The following code creates a keymap to toggle inlay hints in your -- code, if the language server you are using supports them -- -- This may be unwanted, since they displace some of your code if client and client_supports_method(client, vim.lsp.protocol.Methods.textDocument_inlayHint, event.buf) then map('th', function() vim.lsp.inlay_hint.enable(not vim.lsp.inlay_hint.is_enabled { bufnr = event.buf }) end, '[T]oggle Inlay [H]ints') end end, }) -- Diagnostic Config -- See :help vim.diagnostic.Opts vim.diagnostic.config { severity_sort = true, float = { border = 'rounded', source = 'if_many' }, underline = { severity = vim.diagnostic.severity.ERROR }, signs = vim.g.have_nerd_font and { text = { [vim.diagnostic.severity.ERROR] = '󰅚 ', [vim.diagnostic.severity.WARN] = '󰀪 ', [vim.diagnostic.severity.INFO] = '󰋽 ', [vim.diagnostic.severity.HINT] = '󰌶 ', }, } or {}, virtual_text = { source = 'if_many', spacing = 2, format = function(diagnostic) local diagnostic_message = { [vim.diagnostic.severity.ERROR] = diagnostic.message, [vim.diagnostic.severity.WARN] = diagnostic.message, [vim.diagnostic.severity.INFO] = diagnostic.message, [vim.diagnostic.severity.HINT] = diagnostic.message, } return diagnostic_message[diagnostic.severity] end, }, -- virtual_lines = true, } local servers = { --ts_ls = { -- init_options = { -- hostInfo = 'neovim', -- plugins = { -- { -- name = '@vue/typescript-plugin', -- --location = '', -- use local node_modules path -- location = vue_typescript_plugin_path, -- languages = { 'vue', 'javascript', 'typescript' }, -- }, -- }, -- }, -- filetypes = { 'javascript', 'javascriptreact', 'javascript.jsx', 'typescript', 'typescriptreact', 'typescript.tsx', 'vue' }, --}, -- Volar is deprecated in favor of vue_ls --volar = { -- filetypes = { 'typescript', 'javascript', 'javascriptreact', 'typescriptreact', 'vue' }, -- init_options = { -- vue = { -- -- disable hybrid mode -- hybridMode = true, -- }, -- }, --}, -- hybrid mode is default vue_ls = {}, vtsls = { filetypes = { 'typescript', 'javascript', 'javascriptreact', 'typescriptreact', 'vue' }, settings = { typescript = { format = { enable = false, }, }, vtsls = { tsserver = { globalPlugins = { { name = '@vue/typescript-plugin', location = vue_language_server_path, languages = { 'vue' }, configNamespace = 'typescript', }, }, }, }, }, }, eslint = { flags = { debounce_text_changes = 500 }, settings = { codeActionOnSave = { enable = true, }, }, -- on_attach = function(client, bufnr) -- client.server_capabilities.documentFormattingProvider = true -- if client.server_capabilities.documentFormattingProvider then -- local au_lsp = vim.api.nvim_create_augroup('eslint_lsp', { clear = true }) -- vim.api.nvim_create_autocmd('BufWritePre', { -- pattern = '*', -- callback = function() -- vim.lsp.buf.format { async = true } -- end, -- group = au_lsp, -- }) -- end -- end, }, html = {}, cssls = {}, jsonls = { settings = { json = { schemas = require('schemastore').json.schemas { extra = { { -- Can be found here: https://github.com/wraith13/vscode-schemas?tab=readme-ov-file description = 'vscode launch.json schema', fileMatch = '/.vscode/launch.json', name = 'launch.json', url = 'https://raw.githubusercontent.com/wraith13/vscode-schemas/refs/heads/master/en/latest/schemas/launch.json', }, }, }, validate = { enable = true }, }, }, }, lua_ls = { settings = { Lua = { completion = { callSnippet = 'Replace', }, }, }, }, yamlls = { settings = { yaml = { schemas = { ['kubernetes'] = { '/*.manifest.yaml', '/*.k8s.yaml' }, -- Azure pipelines support (azure_pipelines_ls not needed for syntax) ['https://raw.githubusercontent.com/microsoft/azure-pipelines-vscode/master/service-schema.json'] = { '/azure-pipeline*.y*l', '/*.azure*', 'Azure-Pipelines/**/*.y*l', 'azure-pipelines/**/*.y*l', 'Pipelines/*.y*l', '/*.pipeline.yaml', }, }, }, }, }, lemminx = {}, -- C# Csharp roslyn = {}, pylsp = { settings = { pylsp = { plugins = { pycodestyle = { ignore = { 'E501', 'E503' }, -- ignore line length, let black formatter manage this, sometimes lines must be long, ignore cr before binary operator }, }, }, }, }, powershell_es = {}, } -- Ensure the servers and tools above are installed -- -- To check the current status of installed tools and/or manually install -- other tools, you can run -- :Mason -- -- You can press `g?` for help in this menu. -- -- `mason` had to be setup earlier: to configure its options see the -- `dependencies` table for `nvim-lspconfig` above. -- -- You can add other tools here that you want Mason to install -- for you, so that they are available from within Neovim. local ensure_installed = vim.tbl_keys(servers or {}) vim.list_extend(ensure_installed, { 'stylua', -- Used to format Lua code 'vue-language-server', 'eslint_d', -- Used in lint.lua 'markdownlint', -- Used in lint.lua 'xmlformatter', 'isort', 'black', 'prettierd', 'netcoredbg', -- Used in debug.lua 'js-debug-adapter', -- Used in debug.lua }) require('mason-tool-installer').setup { ensure_installed = ensure_installed } -- Installed LSPs are configured and enabled automatically with mason-lspconfig -- The loop below is for overriding the default configuration of LSPs with the ones in the servers table for server_name, config in pairs(servers) do if config ~= nil then vim.lsp.config(server_name, config) end vim.lsp.enable(server_name, true) end -- NOTE: Some servers may require an old setup until they are updated. For the full list refer here: https://github.com/neovim/nvim-lspconfig/issues/3705 -- These servers will have to be manually set up with require("lspconfig").server_name.setup{} end, }, }