diff options
author | Kim Alvefur <zash@zash.se> | 2013-10-06 23:53:15 +0200 |
---|---|---|
committer | Kim Alvefur <zash@zash.se> | 2013-10-06 23:53:15 +0200 |
commit | 8463f5b4978d92484f85cb3f3c3f08b4f7bb310e (patch) | |
tree | 1ccbde825f880f744b016ca177445a7de83a00e5 /util/array.lua | |
parent | 8754e4be8504fbdbdd796818d2ce68bb02e104e5 (diff) | |
parent | 04699a3aa4f2f86e841941ad49a02d2f5f21f8fc (diff) | |
download | prosody-8463f5b4978d92484f85cb3f3c3f08b4f7bb310e.tar.gz prosody-8463f5b4978d92484f85cb3f3c3f08b4f7bb310e.zip |
Merge 0.10->trunk
Diffstat (limited to 'util/array.lua')
-rw-r--r-- | util/array.lua | 29 |
1 files changed, 20 insertions, 9 deletions
diff --git a/util/array.lua b/util/array.lua index 9bf215af..6f2abe04 100644 --- a/util/array.lua +++ b/util/array.lua @@ -11,6 +11,7 @@ local t_insert, t_sort, t_remove, t_concat local setmetatable = setmetatable; local math_random = math.random; +local math_floor = math.floor; local pairs, ipairs = pairs, ipairs; local tostring = tostring; @@ -84,6 +85,25 @@ function array_base.pluck(outa, ina, key) return outa; end +function array_base.reverse(outa, ina) + local len = #ina; + if ina == outa then + local middle = math_floor(len/2); + len = len + 1; + local o; -- opposite + for i = 1, middle do + o = len - i; + outa[i], outa[o] = outa[o], outa[i]; + end + else + local off = len + 1; + for i = 1, len do + outa[i] = ina[off - i]; + end + end + return outa; +end + --- These methods only mutate the array function array_methods:shuffle(outa, ina) local len = #self; @@ -94,15 +114,6 @@ function array_methods:shuffle(outa, ina) return self; end -function array_methods:reverse() - local len = #self-1; - for i=len,1,-1 do - self:push(self[i]); - self:pop(i); - end - return self; -end - function array_methods:append(array) local len,len2 = #self, #array; for i=1,len2 do |