diff options
author | 最萌小汐 <sumneko@hotmail.com> | 2020-10-27 11:14:12 +0800 |
---|---|---|
committer | 最萌小汐 <sumneko@hotmail.com> | 2020-10-27 11:14:12 +0800 |
commit | 03e3cd15f9673e13537eee9d6b71bb45c22318eb (patch) | |
tree | ba7fcdab17f2c55c213de51247dfe11bdcf62404 | |
parent | 10ed5c9e5946b36b7d75afb3855afa0cacc42543 (diff) | |
download | lua-language-server-03e3cd15f9673e13537eee9d6b71bb45c22318eb.zip |
doc.type.function 视为一种定义
-rw-r--r-- | script-beta/parser/guide.lua | 64 | ||||
-rw-r--r-- | test-beta/definition/luadoc.lua | 5 |
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 [[ |