diff options
Diffstat (limited to 'server/src/vm')
-rw-r--r-- | server/src/vm/function.lua | 10 | ||||
-rw-r--r-- | server/src/vm/global.lua | 1 | ||||
-rw-r--r-- | server/src/vm/library.lua | 26 | ||||
-rw-r--r-- | server/src/vm/local.lua | 9 | ||||
-rw-r--r-- | server/src/vm/multi.lua | 3 | ||||
-rw-r--r-- | server/src/vm/value.lua | 7 | ||||
-rw-r--r-- | server/src/vm/vm.lua | 24 |
7 files changed, 44 insertions, 36 deletions
diff --git a/server/src/vm/function.lua b/server/src/vm/function.lua index 973f984e..2ca12e2b 100644 --- a/server/src/vm/function.lua +++ b/server/src/vm/function.lua @@ -1,6 +1,6 @@ local createMulti = require 'vm.multi' -local createValue = require 'vm.value' -local createLocal = require 'vm.local' +local valueMgr = require 'vm.value' +local localMgr = require 'vm.local' local sourceMgr = require 'vm.source' local mt = {} @@ -156,7 +156,7 @@ function mt:run(vm) if self._runed == 1 then -- 如果是面向对象形式的函数,创建隐藏的参数self if self._objectSource then - local loc = createLocal('self', self._objectSource, self._objectValue) + local loc = localMgr.create('self', self._objectSource, self._objectValue) loc:set('hide', true) self:saveLocal('self', loc) self.args[#self.args+1] = loc @@ -195,7 +195,7 @@ function mt:createArg(vm, arg) vm:instantSource(arg) arg:set('arg', true) if arg.type == 'name' then - local loc = createLocal(arg[1], arg, createValue('nil', arg)) + local loc = localMgr.create(arg[1], arg, valueMgr.create('nil', arg)) self:saveLocal(arg[1], loc) self.args[#self.args+1] = loc elseif arg.type == '...' then @@ -208,7 +208,7 @@ function mt:createLibArg(arg, source) self._dots = createMulti() else local name = arg.name or '_' - local loc = createLocal(name, source, createValue('any', source)) + local loc = localMgr.create(name, source, valueMgr.create('any', source)) self:saveLocal(name, loc) self.args[#self.args+1] = loc end diff --git a/server/src/vm/global.lua b/server/src/vm/global.lua index 63db8487..54680fd3 100644 --- a/server/src/vm/global.lua +++ b/server/src/vm/global.lua @@ -1,4 +1,3 @@ -local createValue = require 'vm.value' local library = require 'core.library' local libraryBuilder = require 'vm.library' local sourceMgr = require 'vm.source' diff --git a/server/src/vm/library.lua b/server/src/vm/library.lua index 60f56368..54dca81f 100644 --- a/server/src/vm/library.lua +++ b/server/src/vm/library.lua @@ -1,6 +1,6 @@ local sourceMgr = require 'vm.source' -local createValue +local valueMgr local createFunction local CHILD_CACHE = {} @@ -13,16 +13,16 @@ function buildLibValue(lib) if VALUE_CACHE[lib] then return VALUE_CACHE[lib] end - if not createValue then - createValue = require 'vm.value' + if not valueMgr then + valueMgr = require 'vm.value' createFunction = require 'vm.function' end local tp = lib.type local value if tp == 'table' then - value = createValue('table', sourceMgr.dummy()) + value = valueMgr.create('table', sourceMgr.dummy()) elseif tp == 'function' then - value = createValue('function', sourceMgr.dummy()) + value = valueMgr.create('function', sourceMgr.dummy()) local func = createFunction() value:setFunction(func) if lib.args then @@ -40,17 +40,17 @@ function buildLibValue(lib) end end elseif tp == 'string' then - value = createValue('string', sourceMgr.dummy()) + value = valueMgr.create('string', sourceMgr.dummy()) elseif tp == 'boolean' then - value = createValue('boolean', sourceMgr.dummy()) + value = valueMgr.create('boolean', sourceMgr.dummy()) elseif tp == 'number' then - value = createValue('number', sourceMgr.dummy()) + value = valueMgr.create('number', sourceMgr.dummy()) elseif tp == 'integer' then - value = createValue('integer', sourceMgr.dummy()) + value = valueMgr.create('integer', sourceMgr.dummy()) elseif tp == 'nil' then - value = createValue('nil', sourceMgr.dummy()) + value = valueMgr.create('nil', sourceMgr.dummy()) else - value = createValue(tp or 'any', sourceMgr.dummy()) + value = valueMgr.create(tp or 'any', sourceMgr.dummy()) end value:setLib(lib) VALUE_CACHE[lib] = value @@ -67,8 +67,8 @@ function buildLibValue(lib) end function buildLibChild(lib) - if not createValue then - createValue = require 'vm.value' + if not valueMgr then + valueMgr = require 'vm.value' createFunction = require 'vm.function' end if CHILD_CACHE[lib] then diff --git a/server/src/vm/local.lua b/server/src/vm/local.lua index f5e65e83..106606ea 100644 --- a/server/src/vm/local.lua +++ b/server/src/vm/local.lua @@ -1,6 +1,7 @@ local sourceMgr = require 'vm.source' local Sort = 0 +local Watch = setmetatable({}, {__mode = 'kv'}) local mt = {} mt.__index = mt @@ -137,7 +138,7 @@ function mt:getSource() return sourceMgr.list[self.source] end -return function (name, source, value) +local function create(name, source, value) if not value then error('Local must has a value') end @@ -154,5 +155,11 @@ return function (name, source, value) value = value, _info = {}, }, mt) + Watch[self] = true return self end + +return { + create = create, + watch = Watch, +} diff --git a/server/src/vm/multi.lua b/server/src/vm/multi.lua index bf797f3f..5079468e 100644 --- a/server/src/vm/multi.lua +++ b/server/src/vm/multi.lua @@ -1,6 +1,3 @@ -local createValue = require 'vm.value' -local sourceMgr = require 'vm.source' - local mt = {} mt.__index = mt mt.type = 'multi' diff --git a/server/src/vm/value.lua b/server/src/vm/value.lua index c0f55b9d..11cb9ae1 100644 --- a/server/src/vm/value.lua +++ b/server/src/vm/value.lua @@ -3,6 +3,7 @@ local library = require 'core.library' local sourceMgr = require 'vm.source' local Sort = 0 +local Watch = setmetatable({}, {__mode = 'kv'}) local mt = {} mt.__index = mt @@ -36,6 +37,7 @@ local function create (tp, source, literal) else self:setType(tp, 1.0) end + Watch[self] = true return self end @@ -426,4 +428,7 @@ function mt:isGlobal() return self._global end -return create +return { + create = create, + watch = Watch, +} diff --git a/server/src/vm/vm.lua b/server/src/vm/vm.lua index b5ffa459..c519ad72 100644 --- a/server/src/vm/vm.lua +++ b/server/src/vm/vm.lua @@ -1,6 +1,6 @@ local library = require 'core.library' -local createValue = require 'vm.value' -local createLocal = require 'vm.local' +local valueMgr = require 'vm.value' +local localMgr = require 'vm.local' local createLabel = require 'vm.label' local createFunction = require 'vm.function' local sourceMgr = require 'vm.source' @@ -338,7 +338,7 @@ function mt:call(value, values, source) end function mt:createValue(tp, source, literal) - local value = createValue(tp, source, literal) + local value = valueMgr.create(tp, source, literal) value.uri = self:getUri() return value end @@ -476,7 +476,7 @@ function mt:getSimple(simple, max) local first = simple[1] self:instantSource(first) local value = self:getExp(first) - value = self:getFirstInMulti(value) or createValue('nil', self:getDefaultSource()) + value = self:getFirstInMulti(value) or valueMgr.create('nil', self:getDefaultSource()) first:bindValue(value, 'get') if not max then max = #simple @@ -488,7 +488,7 @@ function mt:getSimple(simple, max) local source = simple[i] self:instantSource(source) source:set('simple', simple) - value = self:getFirstInMulti(value) or createValue('nil', self:getDefaultSource()) + value = self:getFirstInMulti(value) or valueMgr.create('nil', self:getDefaultSource()) if source.type == 'call' then local values, args = self:unpackList(source) @@ -499,7 +499,7 @@ function mt:getSimple(simple, max) end object = nil source:bindCall(func, args) - value = self:call(func, values, source) or createValue('any', self:getDefaultSource()) + value = self:call(func, values, source) or valueMgr.create('any', self:getDefaultSource()) elseif source.type == 'index' then local child = source[1] local index = self:getIndex(source) @@ -538,8 +538,8 @@ function mt:getBinary(exp) self:instantSource(exp) local v1 = self:getExp(exp[1]) local v2 = self:getExp(exp[2]) - v1 = self:getFirstInMulti(v1) or createValue('nil', exp[1]) - v2 = self:getFirstInMulti(v2) or createValue('nil', exp[2]) + v1 = self:getFirstInMulti(v1) or valueMgr.create('nil', exp[1]) + v2 = self:getFirstInMulti(v2) or valueMgr.create('nil', exp[2]) local op = exp.op -- TODO 搜索元方法 if op == 'or' then @@ -778,7 +778,7 @@ end function mt:setOne(var, value) if not value then - value = createValue('nil', self:getDefaultSource()) + value = valueMgr.create('nil', self:getDefaultSource()) end self:instantSource(var) if var.type == 'name' then @@ -882,7 +882,7 @@ function mt:doIn(action) local args = self:unpackList(action.exp) self:scopePush(action) - local func = table.remove(args, 1) or createValue('any', self:getDefaultSource()) + local func = table.remove(args, 1) or valueMgr.create('any', self:getDefaultSource()) local values = self:call(func, args, action) or createMulti() self:forList(action.arg, function (arg) local value = table.remove(values, 1) @@ -1133,10 +1133,10 @@ function mt:createLocal(key, source, value) end if not value then - value = createValue('nil', self:getDefaultSource()) + value = valueMgr.create('nil', self:getDefaultSource()) end - loc = createLocal(key, source, value) + loc = localMgr.create(key, source, value) self:saveLocal(key, loc) self:bindLocal(source, loc, 'local') value:addInfo('local', source or self:getDefaultSource()) |