diff options
author | 最萌小汐 <sumneko@hotmail.com> | 2019-10-19 15:18:43 +0800 |
---|---|---|
committer | 最萌小汐 <sumneko@hotmail.com> | 2019-10-19 15:18:43 +0800 |
commit | 696fae86c9175cfc1b210c964b8efda85ed6421f (patch) | |
tree | dd79a633233ff409ef5f54195e4c29fb60246c78 | |
parent | 5bcb7bdf0ae97c59172289b1919e0a5451fba03e (diff) | |
download | lua-language-server-696fae86c9175cfc1b210c964b8efda85ed6421f.zip |
整理代码
-rw-r--r-- | server-beta/src/core/definition.lua | 10 | ||||
-rw-r--r-- | server-beta/test/definition/init.lua | 7 |
2 files changed, 10 insertions, 7 deletions
diff --git a/server-beta/src/core/definition.lua b/server-beta/src/core/definition.lua index c6596268..0647572e 100644 --- a/server-beta/src/core/definition.lua +++ b/server-beta/src/core/definition.lua @@ -1,11 +1,9 @@ local guide = require 'parser.guide' -local engineer = require 'core.engineer' -return function (ast, text, offset) +return function (file, offset) local results = {} - guide.eachSourceContain(ast.ast, offset, function (source) - local searcher = engineer(ast) - searcher:eachDef(source, function (src) + guide.eachSourceContain(file.ast.ast, offset, function (source) + file.searcher:eachDef(source, function (src) if src.type == 'setfield' or src.type == 'getfield' or src.type == 'tablefield' then @@ -19,7 +17,7 @@ return function (ast, text, offset) src = src.method end results[#results+1] = { - uri = ast.uri, + uri = file.uri, source = source, target = src, } diff --git a/server-beta/test/definition/init.lua b/server-beta/test/definition/init.lua index cc8c584b..f5a663cf 100644 --- a/server-beta/test/definition/init.lua +++ b/server-beta/test/definition/init.lua @@ -1,4 +1,5 @@ local core = require 'core.definition' +local engineer = require 'core.engineer' local parser = require 'parser' rawset(_G, 'TEST', true) @@ -41,8 +42,12 @@ function TEST(script) local new_script = script:gsub('<[!?]', ' '):gsub('[!?]>', ' ') local ast = parser:compile(new_script, 'lua', 'Lua 5.3') assert(ast) + local file = { + ast = ast, + searcher = engineer(ast), + } - local results = core(ast, new_script, pos) + local results = core(file, pos) if results then local positions = {} for i, result in ipairs(results) do |