diff options
author | 最萌小汐 <sumneko@hotmail.com> | 2019-10-08 17:34:50 +0800 |
---|---|---|
committer | 最萌小汐 <sumneko@hotmail.com> | 2019-10-08 17:34:50 +0800 |
commit | e8058b91113196218d13befcbc529ddc2b621a3f (patch) | |
tree | 26a15d29c2ebbebed65b66f0e7272f5fd06bc14b /server-beta/src/core | |
parent | 5c47b0112b8103ac42e37352410e518cee6b5c71 (diff) | |
download | lua-language-server-e8058b91113196218d13befcbc529ddc2b621a3f.zip |
method
Diffstat (limited to 'server-beta/src/core')
-rw-r--r-- | server-beta/src/core/engineer.lua | 44 |
1 files changed, 25 insertions, 19 deletions
diff --git a/server-beta/src/core/engineer.lua b/server-beta/src/core/engineer.lua index 5fc92e7e..97101235 100644 --- a/server-beta/src/core/engineer.lua +++ b/server-beta/src/core/engineer.lua @@ -55,6 +55,8 @@ mt['local'] = function (self, source, mode, callback) local tp = parent.type if tp == 'setfield' or tp == 'getfield' + or tp == 'setmethod' + or tp == 'getmethod' or tp == 'setindex' or tp == 'getindex' then callback(parent) @@ -77,7 +79,8 @@ mt['_G'] = function (self, source, mode, callback) if mode == 'def' then local parent = source.parent if parent.type == 'setfield' - or parent.type == 'setindex' then + or parent.type == 'setindex' + or parent.type == 'setmethod' then callback(parent, 'set') elseif parent.type == 'getfield' or parent.type == 'getindex' then @@ -88,10 +91,12 @@ mt['_G'] = function (self, source, mode, callback) elseif mode == 'ref' then local parent = source.parent if parent.type == 'setfield' - or parent.type == 'setindex' then + or parent.type == 'setindex' + or parent.type == 'setmethod' then callback(parent, 'set') elseif parent.type == 'getfield' - or parent.type == 'getindex' then + or parent.type == 'getindex' + or parent.type == 'getmethod' then callback(parent, 'get') elseif parent.type == 'getfield' then self:search(parent, 'special', mode, callback) @@ -133,6 +138,8 @@ mt['getglobal'] = function (self, source, mode, callback) local tp = parent.type if tp == 'setfield' or tp == 'getfield' + or tp == 'setmethod' + or tp == 'getmethod' or tp == 'setindex' or tp == 'getindex' then callback(parent) @@ -141,24 +148,33 @@ mt['getglobal'] = function (self, source, mode, callback) end end mt['setglobal'] = mt['getglobal'] -mt['field'] = function (self, source, mode, callback) - local node = source.parent.node - local key = guide.getKeyName(source) +mt['eachfield'] = function (self, node, key, mode, callback) self:eachRef(node, 'field', function (src) if key == guide.getKeyName(src) then if mode == 'def' then if src.type == 'setfield' - or src.type == 'tablefield' - then + or src.type == 'tablefield' then callback(src.field, 'set') elseif src.type == 'setindex' or src.type == 'tableindex' then callback(src.index, 'set') + elseif src.type == 'setmethod' then + callback(src.method, 'set') end end end end) end +mt['field'] = function (self, source, mode, callback) + local node = source.parent.node + local key = guide.getKeyName(source) + mt['eachfield'](self, node, key, mode, callback) +end +mt['method'] = function (self, source, mode, callback) + local node = source.parent.node + local key = guide.getKeyName(source) + mt['eachfield'](self, node, key, mode, callback) +end mt['special'] = function (self, source, mode, callback) local name = self:getSpecial(source) if not name then @@ -182,17 +198,7 @@ mt['asindex'] = function (self, source, mode, callback) end local node = parent.node local key = guide.getKeyName(source) - self:eachRef(node, 'field', function (src) - if key == guide.getKeyName(src) then - if mode == 'def' then - if src.type == 'setfield' then - callback(src.field, 'set') - elseif src.type == 'setindex' then - callback(src.index, 'set') - end - end - end - end) + mt['eachfield'](self, node, key, mode, callback) end mt['number'] = mt['asindex'] mt['boolean'] = mt['asindex'] |