summaryrefslogtreecommitdiff
path: root/script
diff options
context:
space:
mode:
author最萌小汐 <sumneko@hotmail.com>2021-04-28 21:04:18 +0800
committer最萌小汐 <sumneko@hotmail.com>2021-04-28 21:04:18 +0800
commit5e0c1dfa6beaf4431d7fae3e392aab7e7da34213 (patch)
tree3cd78b1da58bd6f366de57b0845a4363a7ce3b5c /script
parent6aa90f4667b8470fe80889e5fe0f9ab4f96ae86b (diff)
downloadlua-language-server-5e0c1dfa6beaf4431d7fae3e392aab7e7da34213.zip
stash
Diffstat (limited to 'script')
-rw-r--r--script/core/searcher.lua67
1 files changed, 46 insertions, 21 deletions
diff --git a/script/core/searcher.lua b/script/core/searcher.lua
index 7f17088b..3a4e5d76 100644
--- a/script/core/searcher.lua
+++ b/script/core/searcher.lua
@@ -245,8 +245,39 @@ function m.searchRefsByID(status, uri, expect, mode)
search(parentID, linker.SPLIT_CHAR .. linker.RETURN_INDEX_CHAR .. returnIndex)
end
- local function genericStash(source, call)
- if not call or not call.args then
+ local callStash = {}
+
+ local function genericStashParam(docType, call, index)
+ for _, typeUnit in ipairs(docType.types) do
+ if typeUnit.typeGeneric then
+ local key = typeUnit[1]
+ local generics = typeUnit.typeGeneric[key]
+ local callParam = call.args[index]
+ if callParam then
+ if typeUnit.literal then
+ if callParam.type == 'string' then
+ genericStashMap[generics] = ('dn:%s'):format(callParam[1] or '')
+ end
+ else
+ genericStashMap[generics] = linker.getID(callParam)
+ end
+ end
+ end
+ end
+ end
+
+ local function genericStash(source)
+ if source.type ~= 'function'
+ and source.type ~= 'doc.type.function' then
+ return
+ end
+ local top = #callStash
+ if top == 0 then
+ return
+ end
+ local call = callStash[top]
+ callStash[top] = nil
+ if not call.args then
return
end
if source.type == 'function' then
@@ -256,25 +287,15 @@ function m.searchRefsByID(status, uri, expect, mode)
for index, param in ipairs(source.args) do
local docParam = param.docParam
if docParam then
- for _, typeUnit in ipairs(docParam.extends.types) do
- if typeUnit.typeGeneric then
- local key = typeUnit[1]
- local generics = typeUnit.typeGeneric[key]
- local callParam = call.args[index]
- if callParam then
- if typeUnit.literal then
- if callParam.type == 'string' then
- genericStashMap[generics] = ('dn:%s'):format(callParam[1] or '')
- end
- else
- genericStashMap[generics] = linker.getID(callParam)
- end
- end
- end
- end
+ genericStashParam(docParam.extends, call, index)
end
end
end
+ if source.type == 'doc.type.function' then
+ for index, param in ipairs(source.args) do
+ genericStashParam(param.extends, call, index)
+ end
+ end
end
local function genericResolve(source, field)
@@ -303,6 +324,10 @@ function m.searchRefsByID(status, uri, expect, mode)
local link = linker.getLinkByID(root, id)
if link then
+ if link.call then
+ callStash[#callStash+1] = link.call
+ end
+ call = link.call or call
if field == nil and link.sources then
for _, source in ipairs(link.sources) do
m.pushResult(status, mode, source)
@@ -310,17 +335,17 @@ function m.searchRefsByID(status, uri, expect, mode)
end
if link.forward then
for _, forwardID in ipairs(link.forward) do
- searchID(forwardID, field, link.call or call)
+ searchID(forwardID, field, call)
end
end
if link.backward and (mode == 'ref' or field) then
for _, backwardID in ipairs(link.backward) do
- searchID(backwardID, field, link.call or call)
+ searchID(backwardID, field, call)
end
end
if link.sources then
- genericStash(link.sources[1], call)
+ genericStash(link.sources[1])
genericResolve(link.sources[1], field)
end
end