summaryrefslogtreecommitdiff
path: root/server
diff options
context:
space:
mode:
author最萌小汐 <sumneko@hotmail.com>2019-03-12 17:41:00 +0800
committer最萌小汐 <sumneko@hotmail.com>2019-03-12 17:41:00 +0800
commit55dc0cc8a8d6fe6893aac8ab0a150a1fd6001aba (patch)
tree3ae749678d6ccf0fd33c892122a8b7621e9ea4b1 /server
parent894db9dc2125acdfe9ef69759bf7709d25552eef (diff)
downloadlua-language-server-55dc0cc8a8d6fe6893aac8ab0a150a1fd6001aba.zip
整理代码
Diffstat (limited to 'server')
-rw-r--r--server/src/core/definition.lua5
-rw-r--r--server/src/core/find_lib.lua5
-rw-r--r--server/src/vm/value.lua19
-rw-r--r--server/src/vm/vm.lua36
4 files changed, 50 insertions, 15 deletions
diff --git a/server/src/core/definition.lua b/server/src/core/definition.lua
index 35dfc03b..1ae6b97e 100644
--- a/server/src/core/definition.lua
+++ b/server/src/core/definition.lua
@@ -171,4 +171,9 @@ return function (vm, source, lsp)
if source:get 'target uri' then
return jumpUri(vm, source, lsp)
end
+ if source:get 'in index' then
+ source = source:get 'in index'
+ return parseValue(vm, source, lsp)
+ or parseValueSimily(vm, source, lsp)
+ end
end
diff --git a/server/src/core/find_lib.lua b/server/src/core/find_lib.lua
index 60a2a75e..3ba7865f 100644
--- a/server/src/core/find_lib.lua
+++ b/server/src/core/find_lib.lua
@@ -47,5 +47,10 @@ return function (source)
local lib, fullKey = findLib(source)
return lib, fullKey
end
+ if source:get 'in index' then
+ source = source:get 'in index'
+ local lib, fullKey = findLib(source)
+ return lib, fullKey
+ end
return nil
end
diff --git a/server/src/vm/value.lua b/server/src/vm/value.lua
index f41d30e0..3cbccdd0 100644
--- a/server/src/vm/value.lua
+++ b/server/src/vm/value.lua
@@ -23,6 +23,7 @@ local function create (tp, source, literal)
_type = {},
_literal = literal,
_info = {},
+ _infoCheck = 10,
}, mt)
if type(tp) == 'table' then
for i = 1, #tp do
@@ -246,7 +247,7 @@ function mt:addInfo(tp, source, ...)
if self._info[source] then
return
end
- if not source then
+ if not source or not source.isRemoved then
return
end
local info = {
@@ -256,6 +257,22 @@ function mt:addInfo(tp, source, ...)
}
self._info[#self._info+1] = info
self._info[info.source] = true
+
+ -- 清除无效的info
+ --if #self._info > self._infoCheck then
+ -- for i = #self._info, 1, -1 do
+ -- local info = self._info[i]
+ -- local src = info.source
+ -- if src:isRemoved() then
+ -- table.remove(self._info, i)
+ -- self._info[src] = nil
+ -- end
+ -- end
+ -- self._infoCheck = #self._info * 2
+ -- if self._infoCheck < 10 then
+ -- self._infoCheck = 10
+ -- end
+ --end
end
function mt:eachInfo(callback)
diff --git a/server/src/vm/vm.lua b/server/src/vm/vm.lua
index d6524958..e6343b4b 100644
--- a/server/src/vm/vm.lua
+++ b/server/src/vm/vm.lua
@@ -40,7 +40,7 @@ function mt:buildTable(source)
self:instantSource(key)
key:bindValue(value, 'set')
if key.index then
- local index = self:getIndex(key)
+ local index = self:getIndex(obj)
key:set('parent', tbl)
tbl:addInfo('set child', key, index)
tbl:setChild(index, value)
@@ -387,14 +387,17 @@ function mt:setName(name, source, value)
end
function mt:getIndex(source)
- if source.type == 'name' then
- local value = self:getName(source[1], source)
- source:set('in index', true)
+ local child = source[1]
+ if child.type == 'name' then
+ local value = self:getName(child[1], child)
+ child:set('in index', source)
return value
- elseif source.type == 'string' or source.type == 'number' or source.type == 'boolean' then
- return source[1]
+ elseif child.type == 'string' or child.type == 'number' or child.type == 'boolean' then
+ self:instantSource(child)
+ child:set('in index', source)
+ return child[1]
else
- return self:getExp(source)
+ return self:getExp(child)
end
end
@@ -485,9 +488,9 @@ function mt:getSimple(simple, max)
source:bindCall(func, args)
value = self:call(func, values, source) or createValue('any')
elseif source.type == 'index' then
- source:set('parent', value)
local child = source[1]
- local index = self:getIndex(child)
+ local index = self:getIndex(source)
+ child:set('parent', value)
value:addInfo('get child', source, index)
value = value:getChild(index, source)
source:bindValue(value, 'get')
@@ -710,7 +713,11 @@ function mt:doReturn(action)
values:eachValue(function (n, value)
value.uri = self:getUri()
func:setReturn(n, value)
- value:addInfo('return', action[n] or value.source)
+ local source = action[n] or value.source
+ if source.start == 0 then
+ source = self:getDefaultSource()
+ end
+ value:addInfo('return', source)
end)
end
@@ -759,13 +766,14 @@ function mt:setOne(var, value)
local key = var[#var]
self:instantSource(key)
key:set('simple', var)
- key:set('parent', parent)
if key.type == 'index' then
- local index = self:getIndex(key[1])
+ local index = self:getIndex(key)
+ key[1]:set('parent', parent)
parent:addInfo('set child', key[1], index)
parent:setChild(index, value)
elseif key.type == 'name' then
local index = key[1]
+ key:set('parent', parent)
parent:addInfo('set child', key, index)
parent:setChild(index, value)
end
@@ -892,7 +900,7 @@ function mt:doFunction(action)
self:instantSource(source)
source:set('object', parent)
if source.type == 'index' then
- local index = self:getIndex(source[1])
+ local index = self:getIndex(source)
parent:addInfo('set child', source[1], index)
parent:setChild(index, value)
elseif source.type == 'name' then
@@ -919,7 +927,7 @@ function mt:doFunction(action)
local source = name[#name]
self:instantSource(source)
if source.type == 'index' then
- local index = self:getIndex(source[1])
+ local index = self:getIndex(source)
parent:addInfo('set child', source[1], index)
parent:setChild(index, value)
elseif source.type == 'name' then