summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author最萌小汐 <sumneko@hotmail.com>2020-10-27 14:12:15 +0800
committer最萌小汐 <sumneko@hotmail.com>2020-10-27 14:12:15 +0800
commit6269a0c2d108e288bb5c637d86cb0cd62396209b (patch)
tree872d69974852daa49c448ab4e6b5c0ef7f2d4fc4
parent03e3cd15f9673e13537eee9d6b71bb45c22318eb (diff)
downloadlua-language-server-6269a0c2d108e288bb5c637d86cb0cd62396209b.zip
过基础的 hover
-rw-r--r--script-beta/parser/guide.lua33
-rw-r--r--script-beta/parser/luadoc.lua3
-rw-r--r--test-beta/hover/init.lua11
3 files changed, 30 insertions, 17 deletions
diff --git a/script-beta/parser/guide.lua b/script-beta/parser/guide.lua
index a1b73306..0760c441 100644
--- a/script-beta/parser/guide.lua
+++ b/script-beta/parser/guide.lua
@@ -3268,6 +3268,9 @@ local function mergeLibraryFunctionReturns(status, source, index)
end
local function mergeFunctionReturnsByDoc(status, source, index, call)
+ if not source or source.type ~= 'function' then
+ return
+ end
if not source.bindDocs then
return
end
@@ -3308,15 +3311,16 @@ local function mergeFunctionReturnsByDoc(status, source, index, call)
end
end
end)
+ if #results == 0 then
+ return
+ end
for _, res in ipairs(results) do
status.results[#status.results+1] = res
end
+ return true
end
local function mergeFunctionReturns(status, source, index, call)
- if mergeFunctionReturnsByDoc(status, source, index, call) then
- return
- end
local returns = source.returns
if not returns then
return
@@ -3372,17 +3376,26 @@ function m.inferByCallReturnAndIndex(status, call, index)
local node = call.node
local newStatus = m.status(nil, status.interface)
m.searchRefs(newStatus, node, 'def')
+ local hasDocReturn
for _, src in ipairs(newStatus.results) do
- if src.value and src.value.type == 'function' then
- if src.type == 'library' then
- mergeLibraryFunctionReturns(status, src.value, index)
- else
- if not m.checkReturnMark(status, src.value, true) then
- mergeFunctionReturns(status, src.value, index, call)
+ if mergeDocTypeFunctionReturns(status, src, index) then
+ hasDocReturn = true
+ elseif mergeFunctionReturnsByDoc(status, src.value, index, call) then
+ hasDocReturn = true
+ end
+ end
+ if not hasDocReturn then
+ for _, src in ipairs(newStatus.results) do
+ if src.value and src.value.type == 'function' then
+ if src.type == 'library' then
+ mergeLibraryFunctionReturns(status, src.value, index)
+ else
+ if not m.checkReturnMark(status, src.value, true) then
+ mergeFunctionReturns(status, src.value, index, call)
+ end
end
end
end
- mergeDocTypeFunctionReturns(status, src, index)
end
end
diff --git a/script-beta/parser/luadoc.lua b/script-beta/parser/luadoc.lua
index 72974d28..ad2dea14 100644
--- a/script-beta/parser/luadoc.lua
+++ b/script-beta/parser/luadoc.lua
@@ -720,6 +720,9 @@ local function bindDoc(state, lns, binded)
return
end
guide.eachSourceBetween(state.ast, start, finish, function (src)
+ if src.start and src.start < start then
+ return
+ end
if src.type == 'local'
or src.type == 'setlocal'
or src.type == 'setglobal'
diff --git a/test-beta/hover/init.lua b/test-beta/hover/init.lua
index 645b9131..fa1edfa3 100644
--- a/test-beta/hover/init.lua
+++ b/test-beta/hover/init.lua
@@ -1159,8 +1159,7 @@ local t = {f = f}
t:<?f?>()
]]
[[
-function f(b: any)
- -> any
+function (a: any, b: any)
]]
TEST [[
@@ -1169,9 +1168,7 @@ local function f(<?names?>)
end
]]
[[
-local names: {
- [*integer]: string,
-}
+local names: string[]
]]
TEST [[
@@ -1198,10 +1195,10 @@ end
local <?x?> = f()
]]
[[
-local x: any
+local x: integer
]]
-
+do return end
TEST [[
---@param x number {optional = 'after'}
---@param y boolean {optional = 'self'}