summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author最萌小汐 <sumneko@hotmail.com>2020-10-27 11:14:12 +0800
committer最萌小汐 <sumneko@hotmail.com>2020-10-27 11:14:12 +0800
commit03e3cd15f9673e13537eee9d6b71bb45c22318eb (patch)
treeba7fcdab17f2c55c213de51247dfe11bdcf62404
parent10ed5c9e5946b36b7d75afb3855afa0cacc42543 (diff)
downloadlua-language-server-03e3cd15f9673e13537eee9d6b71bb45c22318eb.zip
doc.type.function 视为一种定义
-rw-r--r--script-beta/parser/guide.lua64
-rw-r--r--test-beta/definition/luadoc.lua5
2 files changed, 48 insertions, 21 deletions
diff --git a/script-beta/parser/guide.lua b/script-beta/parser/guide.lua
index cc0bcdfe..a1b73306 100644
--- a/script-beta/parser/guide.lua
+++ b/script-beta/parser/guide.lua
@@ -960,21 +960,28 @@ end
local function stepRefOfDocType(status, obj, mode)
local results = {}
- local name = obj[1]
- if not name or not status.interface.docType then
- return results
- end
- local docs = status.interface.docType(name)
- for i = 1, #docs do
- local doc = docs[i]
- if mode == 'def' then
- if doc.type == 'doc.class.name'
- or doc.type == 'doc.alias.name' then
+ if obj.type == 'doc.class.name'
+ or obj.type == 'doc.type.name'
+ or obj.type == 'doc.alias.name'
+ or obj.type == 'doc.extends.name' then
+ local name = obj[1]
+ if not name or not status.interface.docType then
+ return results
+ end
+ local docs = status.interface.docType(name)
+ for i = 1, #docs do
+ local doc = docs[i]
+ if mode == 'def' then
+ if doc.type == 'doc.class.name'
+ or doc.type == 'doc.alias.name' then
+ results[#results+1] = doc
+ end
+ else
results[#results+1] = doc
end
- else
- results[#results+1] = doc
end
+ else
+ results[#results+1] = obj
end
return results
end
@@ -1456,12 +1463,21 @@ function m.checkSameSimpleByBindDocs(status, obj, start, queue, mode)
newStatus.cache.searchingBindedDoc = true
for _, res in ipairs(results) do
local doc = m.getDocState(res)
- local refs = doc.bindSources
- for _, ref in ipairs(refs) do
- if not mark[ref] then
- mark[ref] = true
- m.searchRefs(newStatus, ref, mode)
+ if doc.type == 'doc.class'
+ or doc.type == 'doc.type' then
+ local refs = doc.bindSources
+ for _, ref in ipairs(refs) do
+ if not mark[ref] then
+ mark[ref] = true
+ m.searchRefs(newStatus, ref, mode)
+ end
end
+ else
+ queue[#queue+1] = {
+ obj = res,
+ start = start,
+ force = true,
+ }
end
end
for _, res in ipairs(newStatus.results) do
@@ -1853,6 +1869,8 @@ function m.pushResult(status, mode, ref, simple)
results[#results+1] = ref
elseif ref.type == 'library' then
results[#results+1] = ref
+ elseif ref.type == 'doc.type.function' then
+ results[#results+1] = ref
end
if ref.parent and ref.parent.type == 'return' then
if m.getParentFunction(ref) ~= m.getParentFunction(simple.first) then
@@ -1888,6 +1906,8 @@ function m.pushResult(status, mode, ref, simple)
end
elseif ref.type == 'library' then
results[#results+1] = ref
+ elseif ref.type == 'doc.type.function' then
+ results[#results+1] = ref
end
if ref.parent and ref.parent.type == 'return' then
results[#results+1] = ref
@@ -1918,6 +1938,8 @@ function m.pushResult(status, mode, ref, simple)
end
elseif ref.type == 'library' then
results[#results+1] = ref
+ elseif ref.type == 'doc.type.function' then
+ results[#results+1] = ref
end
end
end
@@ -2672,10 +2694,10 @@ function m.inferCheckUpDoc(status, source)
if source.parent.type == 'funcargs'
or source.parent.type == 'in'
or source.parent.type == 'loop' then
- status.results[#status.results+1] = {
- type = m.viewInferType(m.getDocTypeNames(doc.extends)),
- source = doc,
- }
+ local results = m.getDocTypeNames(doc.extends)
+ for _, res in ipairs(results) do
+ status.results[#status.results+1] = res
+ end
return true
end
end
diff --git a/test-beta/definition/luadoc.lua b/test-beta/definition/luadoc.lua
index f6b22cce..d91c3dfe 100644
--- a/test-beta/definition/luadoc.lua
+++ b/test-beta/definition/luadoc.lua
@@ -86,6 +86,11 @@ TEST [[
---@param a <?Class?>
]]
+TEST [[
+---@param f <!fun():void!>
+function t(<?<!f!>?>) end
+]]
+
-- TODO
do return end
TEST [[