diff options
author | Mathias Fußenegger <mfussenegger@users.noreply.github.com> | 2023-06-20 18:36:18 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-06-20 18:36:18 +0200 |
commit | 64f2691a984a5b1e2958d5656a910054982a6f0e (patch) | |
tree | b02c4e0f3f5beefbe50e7193793e254df3cd9d66 /runtime/lua/vim/lsp/codelens.lua | |
parent | 19eef8156bdd3539f10c9a39494cb64b88d777f5 (diff) | |
download | rneovim-64f2691a984a5b1e2958d5656a910054982a6f0e.tar.gz rneovim-64f2691a984a5b1e2958d5656a910054982a6f0e.tar.bz2 rneovim-64f2691a984a5b1e2958d5656a910054982a6f0e.zip |
refactor(lsp): extract common execute command functionality (#24065)
Diffstat (limited to 'runtime/lua/vim/lsp/codelens.lua')
-rw-r--r-- | runtime/lua/vim/lsp/codelens.lua | 24 |
1 files changed, 3 insertions, 21 deletions
diff --git a/runtime/lua/vim/lsp/codelens.lua b/runtime/lua/vim/lsp/codelens.lua index e26bdcc6d4..5acfe90d5e 100644 --- a/runtime/lua/vim/lsp/codelens.lua +++ b/runtime/lua/vim/lsp/codelens.lua @@ -33,30 +33,12 @@ local function execute_lens(lens, bufnr, client_id) local client = vim.lsp.get_client_by_id(client_id) assert(client, 'Client is required to execute lens, client_id=' .. client_id) - local command = lens.command - local fn = client.commands[command.command] or vim.lsp.commands[command.command] - if fn then - fn(command, { bufnr = bufnr, client_id = client_id }) - return - end - -- Need to use the client that returned the lens → must not use buf_request - local command_provider = client.server_capabilities.executeCommandProvider - local commands = type(command_provider) == 'table' and command_provider.commands or {} - if not vim.list_contains(commands, command.command) then - vim.notify( - string.format( - 'Language server does not support command `%s`. This command may require a client extension.', - command.command - ), - vim.log.levels.WARN - ) - return - end - client.request('workspace/executeCommand', command, function(...) + + client._exec_cmd(lens.command, { bufnr = bufnr }, function(...) local result = vim.lsp.handlers['workspace/executeCommand'](...) M.refresh() return result - end, bufnr) + end) end --- Return all lenses for the given buffer |