diff options
| -rw-r--r-- | lua/user/lsp/handlers.lua | 55 | ||||
| -rw-r--r-- | lua/user/lsp/init.lua | 17 | ||||
| -rw-r--r-- | lua/user/lsp/lsp-installer.lua | 29 | ||||
| -rw-r--r-- | lua/user/lsp/mason.lua | 63 | ||||
| -rw-r--r-- | lua/user/lsp/null-ls.lua | 4 | ||||
| -rw-r--r-- | lua/user/lsp/settings/jsonls.lua | 200 | ||||
| -rw-r--r-- | lua/user/plugins.lua | 12 | 
7 files changed, 101 insertions, 279 deletions
| diff --git a/lua/user/lsp/handlers.lua b/lua/user/lsp/handlers.lua index 0758841..853beb3 100644 --- a/lua/user/lsp/handlers.lua +++ b/lua/user/lsp/handlers.lua @@ -1,21 +1,21 @@  local M = {} --- TODO: backfill this to template -M.setup = function() -  local signs = { -    { name = "DiagnosticSignError", text = "" }, -    { name = "DiagnosticSignWarn", text = "" }, -    { name = "DiagnosticSignHint", text = "" }, -    { name = "DiagnosticSignInfo", text = "" }, -  } +local cmp_nvim_ok, cmp_nvim_lsp = pcall(require, "cmp_nvim_lsp") +if not cmp_nvim_ok then +  print "cpm_nvim_lsp init failed" +  return +end -  for _, sign in ipairs(signs) do -    vim.fn.sign_define(sign.name, { texthl = sign.name, text = sign.text, numhl = "" }) +M.setup = function() +  local signs = { Error = "", Warn = "", Hint = "", Info = "" } +  for type, icon in pairs(signs) do +    local hl = "DiagnosticSign" .. type +    vim.fn.sign_define(hl, { text = icon, texthl = hl, numhl = hl })    end    local config = {      -- disable virtual text -    virtual_text = true, +    virtual_text = false,      -- show signs      signs = {        active = signs, @@ -44,7 +44,7 @@ M.setup = function()    })  end -local function lsp_highlight_document(client) +local function lsp_highlight(client)    -- Set autocommands conditional on server_capabilities    if client.server_capabilities.document_highlight then      vim.api.nvim_exec( @@ -60,20 +60,22 @@ local function lsp_highlight_document(client)    end  end +local keymap = vim.keymap.set +  local function lsp_keymaps(bufnr) -  local opts = { noremap = true, silent = true } +  local opts = { buffer = bufnr, noremap = true, silent = true }    -- SEE : https://neovim.io/doc/user/lsp.html -  vim.api.nvim_buf_set_keymap(bufnr, "n", "gd", "<cmd>lua vim.lsp.buf.definition()<CR>", opts) -  vim.api.nvim_buf_set_keymap(bufnr, "n", "gi", "<cmd>lua vim.lsp.buf.implementation()<CR>", opts) -  vim.api.nvim_buf_set_keymap(bufnr, "n", "ga", "<cmd>lua vim.lsp.buf.declaration()<CR>", opts) -  vim.api.nvim_buf_set_keymap(bufnr, "n", "gr", "<cmd>lua vim.lsp.buf.references()<CR>", opts) +  keymap("n", "gd", vim.lsp.buf.definition, opts) +  keymap("n", "gr", vim.lsp.buf.references, opts) +  keymap("n", "gi", vim.lsp.buf.implementation, opts) +  keymap("n", "ga", vim.lsp.buf.declaration, opts) -  vim.api.nvim_buf_set_keymap(bufnr, "n", "gb", "<cmd>lua vim.lsp.buf.hover()<CR>", opts) -  vim.api.nvim_buf_set_keymap(bufnr, "n", "gé", "<cmd>lua vim.lsp.buf.signature_help()<CR>", opts) -  vim.api.nvim_buf_set_keymap(bufnr, "n", "gk", '<cmd>lua vim.diagnostic.open_float({ border = "rounded" })<CR>', opts) -  vim.api.nvim_buf_set_keymap(bufnr, "n", "g.", '<cmd>lua vim.diagnostic.goto_next({ border = "rounded" })<CR>', opts) -  vim.api.nvim_buf_set_keymap(bufnr, "n", "gx", '<cmd>lua vim.diagnostic.goto_prev({ border = "rounded" })<CR>', opts) -  vim.api.nvim_buf_set_keymap(bufnr, "n", "<leader>q", "<cmd>lua vim.diagnostic.setloclist()<CR>", opts) +  keymap("n", "gb", vim.lsp.buf.hover, opts) +  keymap("n", "gé", vim.lsp.buf.signature_help, opts) +  keymap("n", "gk", vim.diagnostic.open_float, opts) +  keymap("n", "g.", vim.diagnostic.goto_next, opts) +  keymap("n", "gx", vim.diagnostic.goto_prev, opts) +  keymap("n", "<leader>q", vim.diagnostic.setloclist, opts)    vim.cmd [[ command! Format execute 'lua vim.lsp.buf.formatting()' ]] -- FIXME what ?  end @@ -82,16 +84,11 @@ M.on_attach = function(client, bufnr)      client.server_capabilities.document_formatting = false    end    lsp_keymaps(bufnr) -  lsp_highlight_document(client) +  lsp_highlight(client)  end  local capabilities = vim.lsp.protocol.make_client_capabilities() -local status_ok, cmp_nvim_lsp = pcall(require, "cmp_nvim_lsp") -if not status_ok then -  return -end -  M.capabilities = cmp_nvim_lsp.default_capabilities(capabilities)  return M diff --git a/lua/user/lsp/init.lua b/lua/user/lsp/init.lua index 9dff1be..50c423a 100644 --- a/lua/user/lsp/init.lua +++ b/lua/user/lsp/init.lua @@ -1,14 +1,3 @@ -local status_ok, lspconfig = pcall(require, "lspconfig") -if not status_ok then -  print "lspconfig init failed" -  return -end - -require "user.lsp.lsp-installer" -require("user.lsp.handlers").setup() -require "user.lsp.null-ls" - -lspconfig.gdscript.setup{ -  on_attach = require("user.lsp.handlers").on_attach, -  capabilities = require("user.lsp.handlers").capabilities, -} +require 'user.lsp.mason' +require('user.lsp.handlers').setup() +require 'user.lsp.null-ls' diff --git a/lua/user/lsp/lsp-installer.lua b/lua/user/lsp/lsp-installer.lua deleted file mode 100644 index 6427378..0000000 --- a/lua/user/lsp/lsp-installer.lua +++ /dev/null @@ -1,29 +0,0 @@ -local status_ok, lsp_installer = pcall(require, "nvim-lsp-installer") -if not status_ok then -  print "nvim-lsp-installer init failed" -  return -end - --- Register a handler that will be called for all installed servers. --- Alternatively, you may also register handlers on specific server instances instead (see example below). --- SEE : https://github.com/williamboman/nvim-lsp-installer#setup -lsp_installer.on_server_ready(function(server) -  local opts = { -    on_attach = require("user.lsp.handlers").on_attach, -    capabilities = require("user.lsp.handlers").capabilities, -  } - -  -- if server.name == "jsonls" then -  --   local jsonls_opts = require("user.lsp.settings.jsonls") -  --   opts = vim.tbl_deep_extend("force", jsonls_opts, opts) -  -- end - -  -- if server.name == "sumneko_lua" then -  --   local sumneko_opts = require("user.lsp.settings.sumneko_lua") -  --   opts = vim.tbl_deep_extend("force", sumneko_opts, opts) -  -- end - -  -- This setup() function is exactly the same as lspconfig's setup function. -  -- Refer to https://github.com/neovim/nvim-lspconfig/blob/master/doc/server_configurations.md -  server:setup(opts) -end) diff --git a/lua/user/lsp/mason.lua b/lua/user/lsp/mason.lua new file mode 100644 index 0000000..b841d72 --- /dev/null +++ b/lua/user/lsp/mason.lua @@ -0,0 +1,63 @@ +local mason_ok, mason = pcall(require, "mason") +if not mason_ok then +  print "mason init failed" +  return +end + +local mason_lspconfig_ok, mason_lspconfig = pcall(require, "mason-lspconfig") +if not mason_lspconfig_ok then +  print "mason-lspconfig init failed" +  return +end + +local lspconfig_ok, lspconfig = pcall(require, "lspconfig") +if not lspconfig_ok then +  print "lspconfig init failed" +  return +end + +require('lspconfig.ui.windows').default_options.border = 'rounded' + +local servers = { +  "clangd", +  "jdtls", +  "jsonls", +  "ltex", +  "rust_analyzer", +  "solargraph", +  "sumneko_lua", +} + +mason.setup({ +    ui = { +        border = "single", +        icons = { +            package_installed = "✓", +            package_pending = "➜", +            package_uninstalled = "✗" +        } +    } +}) + +mason_lspconfig.setup({ +  ensure_installed = servers, +}) + +mason_lspconfig.setup_handlers({ +  function(server_name) +    local opts = { +      on_attach = require("user.lsp.handlers").on_attach, +      capabilities = require("user.lsp.handlers").capabilities, +      falgs = { +        debounce_text_changes = 5000, +      }, +    } + +    local require_ok, server = pcall(require, "user.lsp.settings." .. server_name) +    if require_ok then +      opts = vim.tbl_deep_extend("force", server, opts) +    end + +    lspconfig[server_name].setup(opts) +  end, +}) diff --git a/lua/user/lsp/null-ls.lua b/lua/user/lsp/null-ls.lua index 1dc7ace..389e68f 100644 --- a/lua/user/lsp/null-ls.lua +++ b/lua/user/lsp/null-ls.lua @@ -1,5 +1,5 @@ -local null_ls_status_ok, null_ls = pcall(require, "null-ls") -if not null_ls_status_ok then +local null_ls_ok, null_ls = pcall(require, "null-ls") +if not null_ls_ok then    print "null-ls init failed"    return  end diff --git a/lua/user/lsp/settings/jsonls.lua b/lua/user/lsp/settings/jsonls.lua deleted file mode 100644 index da58c44..0000000 --- a/lua/user/lsp/settings/jsonls.lua +++ /dev/null @@ -1,200 +0,0 @@ -local default_schemas = nil -local status_ok, jsonls_settings = pcall(require, "nlspsettings.jsonls") -if not status_ok then -  print "nlspsettings.jsonls init failed" -  return -else -  default_schemas = jsonls_settings.get_default_schemas() -end - -local schemas = { -  { -    description = "TypeScript compiler configuration file", -    fileMatch = { -      "tsconfig.json", -      "tsconfig.*.json", -    }, -    url = "https://json.schemastore.org/tsconfig.json", -  }, -  { -    description = "Lerna config", -    fileMatch = { "lerna.json" }, -    url = "https://json.schemastore.org/lerna.json", -  }, -  { -    description = "Babel configuration", -    fileMatch = { -      ".babelrc.json", -      ".babelrc", -      "babel.config.json", -    }, -    url = "https://json.schemastore.org/babelrc.json", -  }, -  { -    description = "ESLint config", -    fileMatch = { -      ".eslintrc.json", -      ".eslintrc", -    }, -    url = "https://json.schemastore.org/eslintrc.json", -  }, -  { -    description = "Bucklescript config", -    fileMatch = { "bsconfig.json" }, -    url = "https://raw.githubusercontent.com/rescript-lang/rescript-compiler/8.2.0/docs/docson/build-schema.json", -  }, -  { -    description = "Prettier config", -    fileMatch = { -      ".prettierrc", -      ".prettierrc.json", -      "prettier.config.json", -    }, -    url = "https://json.schemastore.org/prettierrc", -  }, -  { -    description = "Vercel Now config", -    fileMatch = { "now.json" }, -    url = "https://json.schemastore.org/now", -  }, -  { -    description = "Stylelint config", -    fileMatch = { -      ".stylelintrc", -      ".stylelintrc.json", -      "stylelint.config.json", -    }, -    url = "https://json.schemastore.org/stylelintrc", -  }, -  { -    description = "A JSON schema for the ASP.NET LaunchSettings.json files", -    fileMatch = { "launchsettings.json" }, -    url = "https://json.schemastore.org/launchsettings.json", -  }, -  { -    description = "Schema for CMake Presets", -    fileMatch = { -      "CMakePresets.json", -      "CMakeUserPresets.json", -    }, -    url = "https://raw.githubusercontent.com/Kitware/CMake/master/Help/manual/presets/schema.json", -  }, -  { -    description = "Configuration file as an alternative for configuring your repository in the settings page.", -    fileMatch = { -      ".codeclimate.json", -    }, -    url = "https://json.schemastore.org/codeclimate.json", -  }, -  { -    description = "LLVM compilation database", -    fileMatch = { -      "compile_commands.json", -    }, -    url = "https://json.schemastore.org/compile-commands.json", -  }, -  { -    description = "Config file for Command Task Runner", -    fileMatch = { -      "commands.json", -    }, -    url = "https://json.schemastore.org/commands.json", -  }, -  { -    description = "AWS CloudFormation provides a common language for you to describe and provision all the infrastructure resources in your cloud environment.", -    fileMatch = { -      "*.cf.json", -      "cloudformation.json", -    }, -    url = "https://raw.githubusercontent.com/awslabs/goformation/v5.2.9/schema/cloudformation.schema.json", -  }, -  { -    description = "The AWS Serverless Application Model (AWS SAM, previously known as Project Flourish) extends AWS CloudFormation to provide a simplified way of defining the Amazon API Gateway APIs, AWS Lambda functions, and Amazon DynamoDB tables needed by your serverless application.", -    fileMatch = { -      "serverless.template", -      "*.sam.json", -      "sam.json", -    }, -    url = "https://raw.githubusercontent.com/awslabs/goformation/v5.2.9/schema/sam.schema.json", -  }, -  { -    description = "Json schema for properties json file for a GitHub Workflow template", -    fileMatch = { -      ".github/workflow-templates/**.properties.json", -    }, -    url = "https://json.schemastore.org/github-workflow-template-properties.json", -  }, -  { -    description = "golangci-lint configuration file", -    fileMatch = { -      ".golangci.toml", -      ".golangci.json", -    }, -    url = "https://json.schemastore.org/golangci-lint.json", -  }, -  { -    description = "JSON schema for the JSON Feed format", -    fileMatch = { -      "feed.json", -    }, -    url = "https://json.schemastore.org/feed.json", -    versions = { -      ["1"] = "https://json.schemastore.org/feed-1.json", -      ["1.1"] = "https://json.schemastore.org/feed.json", -    }, -  }, -  { -    description = "Packer template JSON configuration", -    fileMatch = { -      "packer.json", -    }, -    url = "https://json.schemastore.org/packer.json", -  }, -  { -    description = "NPM configuration file", -    fileMatch = { -      "package.json", -    }, -    url = "https://json.schemastore.org/package.json", -  }, -  { -    description = "JSON schema for Visual Studio component configuration files", -    fileMatch = { -      "*.vsconfig", -    }, -    url = "https://json.schemastore.org/vsconfig.json", -  }, -  { -    description = "Resume json", -    fileMatch = { "resume.json" }, -    url = "https://raw.githubusercontent.com/jsonresume/resume-schema/v1.0.0/schema.json", -  }, -} - -local function extend(tab1, tab2) -  for _, value in ipairs(tab2) do -    table.insert(tab1, value) -  end -  return tab1 -end - -local extended_schemas = extend(schemas, default_schemas) - -local opts = { -  settings = { -    json = { -      schemas = extended_schemas, -    }, -  }, -  setup = { -    commands = { -      Format = { -        function() -          vim.lsp.buf.range_formatting({}, { 0, 0 }, { vim.fn.line "$", 0 }) -        end, -      }, -    }, -  }, -} - -return opts diff --git a/lua/user/plugins.lua b/lua/user/plugins.lua index a1ded05..74d1c55 100644 --- a/lua/user/plugins.lua +++ b/lua/user/plugins.lua @@ -78,11 +78,13 @@ return packer.startup(function(use)    use 'rafamadriz/friendly-snippets'    -- a bunch of snippets to use    -- LSP -  use 'neovim/nvim-lspconfig'           -- enable LSP -  use 'williamboman/nvim-lsp-installer' -- simple to use language server installer -  use 'tamago324/nlsp-settings.nvim'    -- language server settings defined in json for -  use 'jose-elias-alvarez/null-ls.nvim' -- for formatters and linters -  use 'dense-analysis/ale'              -- asynchronous lint engine +  use { +    'williamboman/mason.nvim', +    'williamboman/mason-lspconfig.nvim', +    'neovim/nvim-lspconfig',              -- enable LSP +    'mfussenegger/nvim-dap', +    'jose-elias-alvarez/null-ls.nvim'     -- for formatters and linters +  }    -- Telescope    use 'nvim-telescope/telescope.nvim'   -- highly extendable fuzzy finder | 
