mod_http: Import portmanager
[prosody.git] / util / set.lua
index 892f1c9d3f70e14bc75a3d36df9ebdcd98531078..7f45526eb41f97741cfdabd8abc15f114442a0f1 100644 (file)
@@ -1,4 +1,12 @@
-local ipairs, pairs, setmetatable, next, tostring = 
+-- Prosody IM
+-- Copyright (C) 2008-2010 Matthew Wild
+-- Copyright (C) 2008-2010 Waqas Hussain
+-- 
+-- This project is MIT/X11 licensed. Please see the
+-- COPYING file in the source package for more information.
+--
+
+local ipairs, pairs, setmetatable, next, tostring =
       ipairs, pairs, setmetatable, next, tostring;
 local t_concat = table.concat;
 
@@ -18,8 +26,9 @@ function set_mt.__div(set, func)
        local new_set, new_items = _M.new();
        local items, new_items = set._items, new_set._items;
        for item in pairs(items) do
-               if func(item) then
-                       new_items[item] = true;
+               local new_item = func(item);
+               if new_item ~= nil then
+                       new_items[new_item] = true;
                end
        end
        return new_set;
@@ -74,8 +83,10 @@ function new(list)
        end
        
        function set:add_list(list)
-               for _, item in ipairs(list) do
-                       items[item] = true;
+               if list then
+                       for _, item in ipairs(list) do
+                               items[item] = true;
+                       end
                end
        end
        
@@ -91,6 +102,10 @@ function new(list)
                end
        end
        
+       function set:empty()
+               return not next(items);
+       end
+       
        if list then
                set:add_list(list);
        end
@@ -137,4 +152,8 @@ function intersection(set1, set2)
        return set;
 end
 
+function xor(set1, set2)
+       return union(set1, set2) - intersection(set1, set2);
+end
+
 return _M;