diff options
author | 最萌小汐 <sumneko@hotmail.com> | 2019-09-30 16:09:02 +0800 |
---|---|---|
committer | 最萌小汐 <sumneko@hotmail.com> | 2019-09-30 16:09:02 +0800 |
commit | 225e1aaeda6f956cc63f689df3a03b31e5804d44 (patch) | |
tree | 7cb6fc4e8d513217b0ff79672ea1e6a91cbe26b7 /server-beta/src/core | |
parent | 212b100f3e49107eac588cb97e8fca46218b033b (diff) | |
download | lua-language-server-225e1aaeda6f956cc63f689df3a03b31e5804d44.zip |
换成搜索
Diffstat (limited to 'server-beta/src/core')
-rw-r--r-- | server-beta/src/core/definition.lua | 16 | ||||
-rw-r--r-- | server-beta/src/core/engineer.lua | 62 |
2 files changed, 42 insertions, 36 deletions
diff --git a/server-beta/src/core/definition.lua b/server-beta/src/core/definition.lua index 2f4a2da3..bd8124d2 100644 --- a/server-beta/src/core/definition.lua +++ b/server-beta/src/core/definition.lua @@ -3,16 +3,14 @@ local engineer = require 'core.engineer' return function (ast, text, offset) local results = {} - local searcher = engineer(ast) guide.eachSource(ast.ast, offset, function (source) - searcher:eachRef(source, function (src, mode) - if mode == 'set' or mode == 'local' then - results[#results+1] = { - uri = ast.uri, - source = source, - target = src, - } - end + local searcher = engineer(ast) + searcher:eachRef(source, 'def', function (src, mode) + results[#results+1] = { + uri = ast.uri, + source = source, + target = src, + } end) end) if #results == 0 then diff --git a/server-beta/src/core/engineer.lua b/server-beta/src/core/engineer.lua index a9251996..74c6ca33 100644 --- a/server-beta/src/core/engineer.lua +++ b/server-beta/src/core/engineer.lua @@ -12,41 +12,49 @@ local mt = {} mt.__index = mt mt.type = 'engineer' ---- 查找所有局部变量引用 -function mt:eachRefAsLocal(obj, callback) - callback(obj, 'local') - if obj.ref then - for _, ref in ipairs(obj.ref) do - if ref.type == 'setlocal' then - callback(ref, 'set') - elseif ref.type == 'getlocal' then - callback(ref, 'get') +mt['local'] = function (self, source, mode, callback) + if mode == 'def' then + callback(source, 'local') + if source.ref then + for _, ref in ipairs(source.ref) do + if ref.type == 'setlocal' then + callback(ref, 'set') + end end end end end - ---- 查找所有域的引用 -function mt:eachRefAsField(obj, callback) - local node = obj.node - guide.eachChildRef(node, function (ref) - if ref.type == 'setglobal' or ref.type == 'setfield' then - callback(ref, 'set') - elseif ref.type == 'getglobal' or ref.type == 'getfield' then - callback(ref, 'get') +mt['getlocal'] = function (self, source, mode, callback) + self:search(source.loc, 'local', mode, callback) +end +mt['setlocal'] = mt['getlocal'] +mt['_ENV'] = function (self, source, mode, callback) + if mode == 'def' then + if source.ref then + for _, ref in ipairs(source.ref) do + if ref.type == 'setglobal' then + callback(ref, 'set') + end + end end - end) + end end +mt['getglobal'] = function (self, source, mode, callback) + self:search(source.node, '_ENV', mode, callback) +end +mt['setglobal'] = mt['getglobal'] ---- 查找所有引用 -function mt:eachRef(obj, callback) - if obj.type == 'local' then - self:eachRefAsLocal(obj, callback) - elseif obj.type == 'getlocal' or obj.type == 'setlocal' then - self:eachRefAsLocal(obj.loc, callback) - elseif obj.type == 'setglobal' or obj.type == 'getglobal' then - self:eachRefAsField(obj, callback) +function mt:search(source, method, mode, callback) + local f = mt[method] + if not f then + return end + f(self, source, mode, callback) +end + +function mt:eachRef(source, mode, callback) + local tp = source.type + self:search(source, tp, mode, callback) end return function (ast) |