From 7356238ee3b8ab4a37bcc623167dee67865076ff Mon Sep 17 00:00:00 2001 From: Mathias Fussenegger Date: Wed, 1 Nov 2023 08:27:10 +0100 Subject: [PATCH 1/2] Don't drop argument if type uses generics in signature refactor --- lua/jdtls.lua | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lua/jdtls.lua b/lua/jdtls.lua index d6bc67c..67134ed 100644 --- a/lua/jdtls.lua +++ b/lua/jdtls.lua @@ -483,7 +483,7 @@ local function change_signature(bufnr, command, code_action_params) if vim.startswith(line, "---") then break elseif expect_param_next and vim.startswith(line, "- ") then - local matches = { line:match("%- ((%d+):) (%w+) (%w+)") } + local matches = { line:match("%- ((%d+):) ([^ ]+) (%w+)") } if next(matches) then table.insert(parameters, { name = matches[4], @@ -491,7 +491,7 @@ local function change_signature(bufnr, command, code_action_params) type = matches[3], }) else - matches = { line:match("%- (%w+) (%w+) ?(%w*)") } + matches = { line:match("%- (%w+) ([^ ]+) ?(%w*)") } if next(matches) then table.insert(parameters, { type = matches[1], From 503a399e0d0b5d432068ab5ae24b9848891b0d53 Mon Sep 17 00:00:00 2001 From: Mathias Fussenegger Date: Wed, 1 Nov 2023 08:37:45 +0100 Subject: [PATCH 2/2] Add start_opts arg to start_or_attach Alternative to https://github.com/mfussenegger/nvim-jdtls/pull/556 --- doc/jdtls.txt | 11 ++++++++--- lua/jdtls.lua | 10 ++++++---- lua/jdtls/setup.lua | 8 ++++++-- 3 files changed, 20 insertions(+), 9 deletions(-) diff --git a/doc/jdtls.txt b/doc/jdtls.txt index 9f82576..d41ac79 100644 --- a/doc/jdtls.txt +++ b/doc/jdtls.txt @@ -1,13 +1,18 @@ ============================================================================== LSP extensions for Neovim and eclipse.jdt.ls *jdtls* -M.start_or_attach({config}) *jdtls.start_or_attach* + *jdtls.start_or_attach* +M.start_or_attach({config}, {opts?}, {start_opts?}) Start the language server (if not started), and attach the current buffer. Parameters: ~ - {config} (table) configuration. See |vim.lsp.start_client| - @return integer? client_id + {config} (table) configuration. See |vim.lsp.start_client| + {opts?} (jdtls.start.opts) + {start_opts?} (lsp.StartOpts) options passed to vim.lsp.start + + Returns: ~ + (integer|nil) client_id M.organize_imports() *jdtls.organize_imports* diff --git a/lua/jdtls.lua b/lua/jdtls.lua index 67134ed..d81e7b9 100644 --- a/lua/jdtls.lua +++ b/lua/jdtls.lua @@ -33,10 +33,12 @@ local M = { --- Start the language server (if not started), and attach the current buffer. --- ----@param config table configuration. See |vim.lsp.start_client| ----@return integer? client_id -function M.start_or_attach(config) - return setup.start_or_attach(config) +---@param config table configuration. See |vim.lsp.start_client| +---@param opts? jdtls.start.opts +---@param start_opts? lsp.StartOpts options passed to vim.lsp.start +---@return integer|nil client_id +function M.start_or_attach(config, opts, start_opts) + return setup.start_or_attach(config, opts, start_opts) end diff --git a/lua/jdtls/setup.lua b/lua/jdtls/setup.lua index 9b7bb02..9e4f50c 100644 --- a/lua/jdtls/setup.lua +++ b/lua/jdtls/setup.lua @@ -251,9 +251,13 @@ end ---@field dap? JdtSetupDapOpts +--- Start the language server (if not started), and attach the current buffer. +--- +---@param config table configuration. See |vim.lsp.start_client| ---@param opts? jdtls.start.opts +---@param start_opts? lsp.StartOpts options passed to vim.lsp.start ---@return integer? client_id -function M.start_or_attach(config, opts) +function M.start_or_attach(config, opts, start_opts) opts = opts or {} assert(config, 'config is required') assert( @@ -316,7 +320,7 @@ function M.start_or_attach(config, opts) } }) maybe_implicit_save() - return vim.lsp.start(config) + return vim.lsp.start(config, start_opts) end