mirror of
https://github.com/neovim/neovim.git
synced 2026-04-23 07:45:32 +00:00
fix(lsp): don't treat MarkedString[] with language id as empty #35518
Problem: Hover response of MarkedString[] where the first element contains a language identifier treated as empty. Solution: Fix empty check to handle case of MarkedString[] where the first element is a pair of a language and value.
This commit is contained in:
@@ -7139,5 +7139,33 @@ describe('LSP', function()
|
||||
|
||||
eq('Empty hover response', n.exec_capture('lua vim.lsp.buf.hover()'))
|
||||
end)
|
||||
|
||||
it('treats markedstring array as not empty', function()
|
||||
exec_lua(create_server_definition)
|
||||
exec_lua(function()
|
||||
local server = _G._create_server({
|
||||
capabilities = {
|
||||
hoverProvider = true,
|
||||
},
|
||||
handlers = {
|
||||
['textDocument/hover'] = function(_, _, callback)
|
||||
local res = {
|
||||
contents = {
|
||||
{
|
||||
language = 'java',
|
||||
value = 'Example',
|
||||
},
|
||||
'doc comment',
|
||||
},
|
||||
}
|
||||
callback(nil, res)
|
||||
end,
|
||||
},
|
||||
})
|
||||
vim.lsp.start({ name = 'dummy', cmd = server.cmd })
|
||||
end)
|
||||
|
||||
eq('', n.exec_capture('lua vim.lsp.buf.hover()'))
|
||||
end)
|
||||
end)
|
||||
end)
|
||||
|
||||
Reference in New Issue
Block a user