|
|
@ -79,7 +79,6 @@ M.__index = function(self, key)
|
|
|
|
return rawget(self, index)
|
|
|
|
return rawget(self, index)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
local function remove(self, index)
|
|
|
|
local function remove(self, index)
|
|
|
|
print('remove', #self, index)
|
|
|
|
|
|
|
|
local oldName = nameAt(self, index)
|
|
|
|
local oldName = nameAt(self, index)
|
|
|
|
if oldName then
|
|
|
|
if oldName then
|
|
|
|
self.__nameIndex[oldName] = nil
|
|
|
|
self.__nameIndex[oldName] = nil
|
|
|
@ -95,7 +94,6 @@ local function remove(self, index)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
rawset(self, #self, nil)
|
|
|
|
rawset(self, #self, nil)
|
|
|
|
print('removed', #self)
|
|
|
|
|
|
|
|
end
|
|
|
|
end
|
|
|
|
local function assign(self, index, value)
|
|
|
|
local function assign(self, index, value)
|
|
|
|
local oldName = nameAt(self, index)
|
|
|
|
local oldName = nameAt(self, index)
|
|
|
@ -108,7 +106,6 @@ local function assign(self, index, value)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
M.__newindex = function(self, key, value)
|
|
|
|
M.__newindex = function(self, key, value)
|
|
|
|
print('__newindex ', key, value)
|
|
|
|
|
|
|
|
local index = getIndexFromKey(self, key)
|
|
|
|
local index = getIndexFromKey(self, key)
|
|
|
|
if value == nil then
|
|
|
|
if value == nil then
|
|
|
|
remove(self, index)
|
|
|
|
remove(self, index)
|
|
|
@ -131,14 +128,5 @@ M.__pairs = function(self)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
M.__ipairs = M.__pairs
|
|
|
|
M.__ipairs = M.__pairs
|
|
|
|
|
|
|
|
|
|
|
|
local test = M.new({})
|
|
|
|
|
|
|
|
test:insert(1, {})
|
|
|
|
|
|
|
|
test[2] = {}
|
|
|
|
|
|
|
|
assert(#test == 2, "Wrong size")
|
|
|
|
|
|
|
|
test:add({ name = 'a' })
|
|
|
|
|
|
|
|
assert(getIndexFromKey(test, 'a') == 3, getIndexFromKey(test, 'a'))
|
|
|
|
|
|
|
|
assert(type(test.a) == 'table', type(test.a))
|
|
|
|
|
|
|
|
assert(test.a.name == 'a', 'wrong table')
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return M
|
|
|
|
return M
|
|
|
|
)"
|
|
|
|
)"
|