refactor(lsp): avoid redundant function wrapping

Leftover from #21026.
This commit is contained in:
Nicolas Hillegeer 2024-11-12 10:51:42 +01:00 committed by Lewis Russell
parent 295f98c8e0
commit 9aab98a275

View File

@ -1,7 +1,7 @@
local uv = vim.uv
local log = require('vim.lsp.log')
local protocol = require('vim.lsp.protocol')
local validate, schedule, schedule_wrap = vim.validate, vim.schedule, vim.schedule_wrap
local validate, schedule_wrap = vim.validate, vim.schedule_wrap
local is_win = vim.fn.has('win32') == 1
@ -409,8 +409,7 @@ function Client:handle_body(body)
local err --- @type lsp.ResponseError|nil
-- Schedule here so that the users functions don't trigger an error and
-- we can still use the result.
schedule(function()
coroutine.wrap(function()
vim.schedule(coroutine.wrap(function()
local status, result
status, result, err = self:try_call(
M.client_errors.SERVER_REQUEST_HANDLER_ERROR,
@ -418,10 +417,7 @@ function Client:handle_body(body)
decoded.method,
decoded.params
)
log.debug(
'server_request: callback result',
{ status = status, result = result, err = err }
)
log.debug('server_request: callback result', { status = status, result = result, err = err })
if status then
if result == nil and err == nil then
error(
@ -450,8 +446,7 @@ function Client:handle_body(body)
result = nil
end
self:send_response(decoded.id, err, result)
end)()
end)
end))
-- This works because we are expecting vim.NIL here
elseif decoded.id and (decoded.result ~= vim.NIL or decoded.error ~= vim.NIL) then
-- We sent a number, so we expect a number.