summaryrefslogtreecommitdiff
path: root/Resources/DefaultContent/Libraries/containers/stack.lua
diff options
context:
space:
mode:
authorchai <chaifix@163.com>2021-10-20 13:50:50 +0800
committerchai <chaifix@163.com>2021-10-20 13:50:50 +0800
commitafdcbfa9c4259fb003fd072ae011836230e7e39b (patch)
tree28687805fa6cd08ea998adffeac7b241af42cfe8 /Resources/DefaultContent/Libraries/containers/stack.lua
parentc795fb754bfd5c84c1bfd7dc793c6519f01109ea (diff)
+containers
Diffstat (limited to 'Resources/DefaultContent/Libraries/containers/stack.lua')
-rw-r--r--Resources/DefaultContent/Libraries/containers/stack.lua67
1 files changed, 67 insertions, 0 deletions
diff --git a/Resources/DefaultContent/Libraries/containers/stack.lua b/Resources/DefaultContent/Libraries/containers/stack.lua
new file mode 100644
index 0000000..d828c81
--- /dev/null
+++ b/Resources/DefaultContent/Libraries/containers/stack.lua
@@ -0,0 +1,67 @@
+--堆栈实现
+stack = stack or {}
+
+function stack.create()
+ local data = {}
+
+ local function push(v)
+ assert(v)
+ table.insert(data, v)
+ end
+
+ local function pop()
+ assert(#data > 0)
+ table.remove(data)
+ end
+
+ local function peek()
+ return #data > 0 and data[#data] or nil
+ end
+
+ local function clear()
+ for i=1,#data do
+ data[i] = nil
+ end
+ end
+
+
+
+ local __tostring = function()
+ local tmp = {}
+ for i,v in ipairs(data) do
+ tmp[#data+1 - i] = v
+ end
+ return table.concat(tmp, ",")
+ end
+
+ local __index = function(i_t, key)
+ error(">> Dee: Limited access")
+ end
+
+ local __len = function()
+ return #data
+ end
+
+ local __newindex = function(i_t, key, v)
+ error(">> Dee: Limited access")
+ end
+
+ local __ipairs = function()
+ error(">> Dee: Limited access")
+ end
+
+ local mt = {__tostring = __tostring, __index = __index, __newindex = __newindex, __ipairs = __ipairs, __pairs = __ipairs, __len = __len}
+
+ local t = {
+ push = push,
+ pop = pop,
+ peek = peek,
+ clear = clear
+ }
+
+ setmetatable(t, mt)
+
+ return t
+end
+
+return stack \ No newline at end of file