diff options
author | 最萌小汐 <sumneko@hotmail.com> | 2019-10-22 19:09:12 +0800 |
---|---|---|
committer | 最萌小汐 <sumneko@hotmail.com> | 2019-10-22 19:09:12 +0800 |
commit | 1f0a645cddeae4caba21c655651d97b5313d2302 (patch) | |
tree | b540e020d8cec343905857ee09af77c6545c65a3 /server-beta/src/core | |
parent | e92ea4b611e8291a2b6ae6904147917179140fae (diff) | |
download | lua-language-server-1f0a645cddeae4caba21c655651d97b5313d2302.zip |
改成用uri来获取定义
Diffstat (limited to 'server-beta/src/core')
-rw-r--r-- | server-beta/src/core/definition.lua | 23 | ||||
-rw-r--r-- | server-beta/src/core/engineer.lua | 3 |
2 files changed, 16 insertions, 10 deletions
diff --git a/server-beta/src/core/definition.lua b/server-beta/src/core/definition.lua index 2fe726e0..039effd5 100644 --- a/server-beta/src/core/definition.lua +++ b/server-beta/src/core/definition.lua @@ -1,22 +1,23 @@ local guide = require 'parser.guide' local engineer = require 'core.engineer' local workspace = require 'workspace' +local files = require 'files' local function findDef(searcher, source, callback) - searcher:eachDef(source, function (src) + searcher:eachDef(source, function (src, uri) if src.type == 'setfield' or src.type == 'getfield' or src.type == 'tablefield' then - callback(src.field) + callback(src.field, uri) elseif src.type == 'setindex' or src.type == 'getindex' or src.type == 'tableindex' then - callback(src.index) + callback(src.index, uri) elseif src.type == 'getmethod' or src.type == 'setmethod' then - callback(src.method) + callback(src.method, uri) else - callback(src) + callback(src, uri) end end) end @@ -53,9 +54,13 @@ local function checkRequire(searcher, source, offset, callback) end end -return function (ast, offset) +return function (uri, offset) local results = {} - local searcher = engineer(ast) + local ast = files.getAst(uri) + if not ast then + return nil + end + local searcher = engineer(ast, uri) guide.eachSourceContain(ast.ast, offset, function (source) checkRequire(searcher, source, offset, function (uri) results[#results+1] = { @@ -67,9 +72,9 @@ return function (ast, offset) } } end) - findDef(searcher, source, function (src) + findDef(searcher, source, function (src, uri) results[#results+1] = { - uri = ast.uri, + uri = uri, source = source, target = src, } diff --git a/server-beta/src/core/engineer.lua b/server-beta/src/core/engineer.lua index a52bddc2..8404bee5 100644 --- a/server-beta/src/core/engineer.lua +++ b/server-beta/src/core/engineer.lua @@ -313,10 +313,11 @@ function mt:childMode(source) return nil, nil end -return function (ast) +return function (ast, uri) local self = setmetatable({ step = 0, ast = ast.ast, + uri = uri, cache = { def = {}, ref = {}, |