diff options
author | 最萌小汐 <sumneko@hotmail.com> | 2019-03-29 13:46:28 +0800 |
---|---|---|
committer | 最萌小汐 <sumneko@hotmail.com> | 2019-03-29 13:46:28 +0800 |
commit | cc33507654fa35640118b13bdd3f19696631980a (patch) | |
tree | 636cad7ea765a4439d9655dcf9cba39f3f68e17c | |
parent | 9c2843279fb04b75169057c3d81a93ce87ebcf34 (diff) | |
download | lua-language-server-cc33507654fa35640118b13bdd3f19696631980a.zip |
尽量不合并value
-rw-r--r-- | server/src/core/definition.lua | 2 | ||||
-rw-r--r-- | server/src/vm/local.lua | 8 | ||||
-rw-r--r-- | server/src/vm/value.lua | 20 | ||||
-rw-r--r-- | server/src/vm/vm.lua | 5 | ||||
-rw-r--r-- | server/test/diagnostics/init.lua | 8 |
5 files changed, 37 insertions, 6 deletions
diff --git a/server/src/core/definition.lua b/server/src/core/definition.lua index b348a386..e41c6727 100644 --- a/server/src/core/definition.lua +++ b/server/src/core/definition.lua @@ -105,7 +105,7 @@ local function parseLocal(vm, source, lsp) return positions end local value = source:bindValue() - if value.uri ~= '' and value.uri ~= vm.uri then + if value and value.uri ~= '' and value.uri ~= vm.uri then return parseValueCrossFile(vm, source, lsp) end positions[#positions+1] = { diff --git a/server/src/vm/local.lua b/server/src/vm/local.lua index b8a387fe..0da5112f 100644 --- a/server/src/vm/local.lua +++ b/server/src/vm/local.lua @@ -9,11 +9,17 @@ mt.type = 'local' mt._close = math.maxinteger function mt:setValue(value) + if not value then + return + end if self.value then - self.value:mergeValue(value) + --self.value:mergeValue(value) + self.value:mergeType(value) + self.value = value else self.value = value end + return value end function mt:getValue() diff --git a/server/src/vm/value.lua b/server/src/vm/value.lua index 35f92b5d..872e96b6 100644 --- a/server/src/vm/value.lua +++ b/server/src/vm/value.lua @@ -96,8 +96,9 @@ function mt:rawSet(index, value, source) self._child = {} end if self._child[index] then - self._child[index]:mergeValue(value) - --self._child[index] = value + --self._child[index]:mergeValue(value) + self._child[index]:mergeType(value) + self._child[index] = value else self._child[index] = value end @@ -262,6 +263,21 @@ function mt:eachChild(callback, mark, foundIndex) return method:eachChild(callback, mark, foundIndex) end +function mt:mergeType(value) + if self == value then + return + end + if not value then + return + end + if value._type then + for tp, rate in pairs(value._type) do + self:setType(tp, rate) + end + end + value._type = self._type +end + function mt:mergeValue(value) if self == value then return diff --git a/server/src/vm/vm.lua b/server/src/vm/vm.lua index 3b52e1f0..5d6b024f 100644 --- a/server/src/vm/vm.lua +++ b/server/src/vm/vm.lua @@ -941,6 +941,7 @@ function mt:doLocalFunction(action) local func = self:buildFunction(action) func:addInfo('local', name) loc:setValue(func) + name:bindValue(func, 'local') end end end @@ -1098,13 +1099,13 @@ function mt:createLocal(key, source, value) end if not value then - value = valueMgr.create('nil', self:getDefaultSource()) + value = self:createValue('nil', source) end loc = localMgr.create(key, source, value) self:saveLocal(key, loc) self:bindLocal(source, loc, 'local') - value:addInfo('local', source or self:getDefaultSource()) + value:addInfo('local', source) return loc end diff --git a/server/test/diagnostics/init.lua b/server/test/diagnostics/init.lua index 4af8f975..c9a8a95d 100644 --- a/server/test/diagnostics/init.lua +++ b/server/test/diagnostics/init.lua @@ -222,3 +222,11 @@ TEST [[ next({}, 1, <!2!>) print(1, 2, 3, 4, 5) ]] + +TEST [[ +local realTostring = tostring +tostring = function () end +tostring(<!1!>) +tostring = realTostring +tostring(1) +]] |