From a22f78ddf561f11f90934ec11ddee5c7ef12436e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=9C=80=E8=90=8C=E5=B0=8F=E6=B1=90?= Date: Fri, 25 Oct 2019 11:08:33 +0800 Subject: =?UTF-8?q?=E6=9B=B4=E6=96=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- server-beta/src/searcher/eachField.lua | 16 ++++- server-beta/src/searcher/eachRef.lua | 104 ++++++++++++++++++++++++--------- server-beta/src/searcher/getField.lua | 13 ++++- server-beta/src/searcher/init.lua | 4 +- 4 files changed, 105 insertions(+), 32 deletions(-) (limited to 'server-beta/src') diff --git a/server-beta/src/searcher/eachField.lua b/server-beta/src/searcher/eachField.lua index c55902ff..c40d78eb 100644 --- a/server-beta/src/searcher/eachField.lua +++ b/server-beta/src/searcher/eachField.lua @@ -1,9 +1,21 @@ local function ofLocal(seacher, source, callback) if source.ref then for _, ref in ipairs(source.ref) do - if ref.type == 'getlocal' then + if ref.type == 'getlocal' then local parent = ref.parent - + local field = seacher:getField(parent) + if field then + callback { + seacher = seacher, + source = field, + } + end + elseif ref.type == 'getglobal' + or ref.type == 'setglobal' then + callback { + seacher = seacher, + source = ref, + } end end end diff --git a/server-beta/src/searcher/eachRef.lua b/server-beta/src/searcher/eachRef.lua index 94419c18..63720ec9 100644 --- a/server-beta/src/searcher/eachRef.lua +++ b/server-beta/src/searcher/eachRef.lua @@ -1,11 +1,23 @@ local guide = require 'parser.guide' +local function ofSelf(searcher, loc, callback) + -- self 的2个特殊引用位置: + -- 1. 当前方法定义时的对象(mt) + local method = loc.method + local node = method.node + searcher:eachRef(node, callback) + -- 2. 调用该方法时传入的对象 +end + local function ofLocal(searcher, loc, callback) - callback { - searcher = searcher, - source = loc, - mode = 'declare', - } + -- 方法中的 self 使用了一个虚拟的定义位置 + if loc.tag ~= 'self' then + callback { + searcher = searcher, + source = loc, + mode = 'declare', + } + end if loc.ref then for _, ref in ipairs(loc.ref) do if ref.type == 'getlocal' then @@ -23,39 +35,77 @@ local function ofLocal(searcher, loc, callback) end end end + if loc.tag == 'self' then + ofSelf(searcher, loc, callback) + end +end + +local function checkField(key, info, callback) + local src = info.source + if key ~= guide.getKeyName(src) then + return + end + local mode + if src.type == 'setglobal' then + mode = 'set' + elseif src.type == 'getglobal' then + mode = 'get' + elseif src.type == 'field' then + local parent = src.parent + if parent.type == 'setfield' then + mode = 'set' + elseif parent.type == 'getfield' then + mode = 'get' + elseif parent.type == 'tablefield' then + mode = 'set' + end + elseif src.type == 'method' then + local parent = src.parent + if parent.type == 'setmethod' then + mode = 'set' + elseif parent.type == 'getmethod' then + mode = 'get' + end + end + if mode then + callback { + searcher = info.searcher, + source = src, + mode = mode, + } + end end local function ofGlobal(searcher, source, callback) local node = source.node local key = guide.getKeyName(source) - searcher.node:eachField(node, function (info) - local src = info.source - if key == guide.getKeyName(src) then - if src.type == 'setglobal' then - callback { - searcher = searcher, - source = src, - mode = 'set', - } - elseif src.type == 'getglobal' then - callback { - searcher = searcher, - source = src, - mode = 'get', - } - end - end + searcher:eachField(node, function (info) + checkField(key, info, callback) + end) +end + +local function ofField(searcher, source, callback) + local parent = source.parent + local node = parent.node + local key = guide.getKeyName(source) + searcher:eachField(node, function (info) + checkField(key, info, callback) end) end return function (searcher, source, callback) - if source.type == 'local' then + local stype = source.type + if stype == 'local' then ofLocal(searcher, source, callback) - elseif source.type == 'getlocal' - or source.type == 'setlocal' then + elseif stype == 'getlocal' + or stype == 'setlocal' then ofLocal(searcher, source.node, callback) - elseif source.type == 'setglobal' - or source.type == 'getglobal' then + elseif stype == 'setglobal' + or stype == 'getglobal' then ofGlobal(searcher, source, callback) + elseif stype == 'field' + or stype == 'method' + or stype == 'index' then + ofField(searcher, source, callback) end end diff --git a/server-beta/src/searcher/getField.lua b/server-beta/src/searcher/getField.lua index 0957a029..59ae462c 100644 --- a/server-beta/src/searcher/getField.lua +++ b/server-beta/src/searcher/getField.lua @@ -1,3 +1,14 @@ return function (searcher, source) - + local stype = source.type + if stype == 'getfield' + or stype == 'setfield' then + return source.field + elseif stype == 'getmethod' + or stype == 'setmethod' then + return source.method + elseif stype == 'getindex' + or stype == 'setindex' then + return source.index + end + return nil end diff --git a/server-beta/src/searcher/init.lua b/server-beta/src/searcher/init.lua index ea9d10ed..d575e65f 100644 --- a/server-beta/src/searcher/init.lua +++ b/server-beta/src/searcher/init.lua @@ -54,7 +54,7 @@ function mt:getField(source) return getField(self, source) end ---- 获取所有的引用(不递归) +--- 获取所有的引用 function mt:eachRef(source, callback) local lock = self:lock('eachRef', source) if not lock then @@ -75,7 +75,7 @@ function mt:eachRef(source, callback) end) end ---- 获取所有的field(不递归) +--- 获取所有的field function mt:eachField(source, callback) local lock = self:lock('eachField', source) if not lock then -- cgit v1.2.3