Add copyright header to those files missing one
[prosody.git] / util / array.lua
1 -- Prosody IM
2 -- Copyright (C) 2008-2009 Matthew Wild
3 -- Copyright (C) 2008-2009 Waqas Hussain
4 -- 
5 -- This project is MIT/X11 licensed. Please see the
6 -- COPYING file in the source package for more information.
7 --
8
9 local array = {};
10
11 local array_mt = { __index = array, __tostring = function (array) return array:concat(", "); end };
12 local function new_array(_, t)
13         return setmetatable(t or {}, array_mt);
14 end
15
16 function array_mt.__add(a1, a2)
17         local res = new_array();
18         return res:append(a1):append(a2);
19 end
20
21 setmetatable(array, { __call = new_array });
22
23 function array:map(func, t2)
24         local t2 = t2 or array{};
25         for k,v in ipairs(self) do
26                 t2[k] = func(v);
27         end
28         return t2;
29 end
30
31 function array:filter(func, t2)
32         local t2 = t2 or array{};
33         for k,v in ipairs(self) do
34                 if func(v) then
35                         t2:push(v);
36                 end
37         end
38         return t2;
39 end
40
41
42 array.push = table.insert;
43 array.pop = table.remove;
44 array.sort = table.sort;
45 array.concat = table.concat;
46 array.length = function (t) return #t; end
47
48 function array:random()
49         return self[math.random(1,#self)];
50 end
51
52 function array:shuffle()
53         local len = #self;
54         for i=1,#self do
55                 local r = math.random(i,len);
56                 self[i], self[r] = self[r], self[i];
57         end
58         return self;
59 end
60
61 function array:reverse()
62         local len = #self-1;
63         for i=len,1,-1 do
64                 self:push(self[i]);
65                 self:pop(i);
66         end
67         return self;
68 end
69
70 function array:append(array)
71         local len,len2  = #self, #array;
72         for i=1,len2 do
73                 self[len+i] = array[i];
74         end
75         return self;
76 end
77
78 function array.collect(f, s, var)
79         local t, var = {};
80         while true do
81                 var = f(s, var);
82                 if var == nil then break; end
83                 table.insert(t, var);
84         end
85         return setmetatable(t, array_mt);
86 end
87
88 _G.array = array;
89 module("array");
90
91 return array;