summaryrefslogtreecommitdiff
path: root/script
diff options
context:
space:
mode:
author最萌小汐 <sumneko@hotmail.com>2021-11-16 15:51:00 +0800
committer最萌小汐 <sumneko@hotmail.com>2021-11-16 15:51:00 +0800
commitbb22719db1a29096a58fb7ea1a1db00a5ccfce2a (patch)
treeb047fa4915644601bec5d9991e5b5fd522c296c2 /script
parent0db905ab64b8e6486f04f5a48d4871eb14141379 (diff)
downloadlua-language-server-bb22719db1a29096a58fb7ea1a1db00a5ccfce2a.zip
`Lua.IntelliSense.traceReturn`
Diffstat (limited to 'script')
-rw-r--r--script/config/config.lua1
-rw-r--r--script/core/noder.lua4
-rw-r--r--script/core/searcher.lua17
3 files changed, 21 insertions, 1 deletions
diff --git a/script/config/config.lua b/script/config/config.lua
index 07b8b77c..c118e6f2 100644
--- a/script/config/config.lua
+++ b/script/config/config.lua
@@ -203,6 +203,7 @@ local Template = {
['Lua.window.statusBar'] = Type.Boolean >> true,
['Lua.window.progressBar'] = Type.Boolean >> true,
['Lua.IntelliSense.localSet'] = Type.Boolean >> false,
+ ['Lua.IntelliSense.traceReturn'] = Type.Boolean >> false,
['Lua.telemetry.enable'] = Type.Or(Type.Boolean >> false, Type.Nil),
['files.associations'] = Type.Hash(Type.String, Type.String),
['files.exclude'] = Type.Hash(Type.String, Type.Boolean),
diff --git a/script/core/noder.lua b/script/core/noder.lua
index 999b797e..81a5b8b1 100644
--- a/script/core/noder.lua
+++ b/script/core/noder.lua
@@ -1280,7 +1280,9 @@ compileNodeMap = util.switch()
, index
)
pushForward(noders, returnID, getID(rtnObj))
- pushBackward(noders, getID(rtnObj), returnID, INFO_DEEP_AND_DONT_CROSS)
+ if config.get 'Lua.IntelliSense.traceReturn' then
+ pushBackward(noders, getID(rtnObj), returnID, INFO_DEEP_AND_DONT_CROSS)
+ end
end
end
end
diff --git a/script/core/searcher.lua b/script/core/searcher.lua
index 3c210b1b..f2b9b291 100644
--- a/script/core/searcher.lua
+++ b/script/core/searcher.lua
@@ -17,6 +17,7 @@ local next = next
local error = error
local type = type
local setmetatable = setmetatable
+local ipairs = ipairs
local tconcat = table.concat
local ssub = string.sub
local sfind = string.find
@@ -975,6 +976,22 @@ local function prepareSearch(source)
end
local uri = getUri(source)
local id = getID(source)
+ -- return function
+ if source.type == 'function' and source.parent.type == 'return' then
+ local func = guide.getParentFunction(source)
+ if func.type == 'function' then
+ for index, rtn in ipairs(source.parent) do
+ if rtn == source then
+ id = sformat('%s%s%s'
+ , getID(func)
+ , RETURN_INDEX
+ , index
+ )
+ break
+ end
+ end
+ end
+ end
return uri, id
end