aboutsummaryrefslogtreecommitdiffstats
path: root/tools/migration/mtools.lua
diff options
context:
space:
mode:
authorWaqas Hussain <waqas20@gmail.com>2011-02-23 02:16:19 +0500
committerWaqas Hussain <waqas20@gmail.com>2011-02-23 02:16:19 +0500
commite5196d43951aa8d0069193bebd201d90a6c1939c (patch)
tree3a6b0fc2e76f53445c84ecae740bf1b727d5163b /tools/migration/mtools.lua
parentbfea56261df0d33fa179a3787adf4d4dcbf24d29 (diff)
downloadprosody-e5196d43951aa8d0069193bebd201d90a6c1939c.tar.gz
prosody-e5196d43951aa8d0069193bebd201d90a6c1939c.zip
tools/migration/*: Initial commit of a new migration tool. Currently supports Prosody files and Prosody SQL as input and output.
Diffstat (limited to 'tools/migration/mtools.lua')
-rw-r--r--tools/migration/mtools.lua56
1 files changed, 56 insertions, 0 deletions
diff --git a/tools/migration/mtools.lua b/tools/migration/mtools.lua
new file mode 100644
index 00000000..d2bd1e7a
--- /dev/null
+++ b/tools/migration/mtools.lua
@@ -0,0 +1,56 @@
+
+
+local print = print;
+local t_insert = table.insert;
+local t_sort = table.sort;
+
+module "mtools"
+
+function sorted(params)
+
+ local reader = params.reader; -- iterator to get items from
+ local sorter = params.sorter; -- sorting function
+ local filter = params.filter; -- filter function
+
+ local cache = {};
+ for item in reader do
+ if filter then item = filter(item); end
+ if item then t_insert(cache, item); end
+ end
+ if sorter then
+ t_sort(cache, sorter);
+ end
+ local i = 0;
+ return function()
+ i = i + 1;
+ return cache[i];
+ end;
+
+end
+
+function merged(reader, merger)
+
+ local item1 = reader();
+ local merged = { item1 };
+ return function()
+ while true do
+ if not item1 then return nil; end
+ local item2 = reader();
+ if not item2 then item1 = nil; return merged; end
+ if merger(item1, item2) then
+ --print("merged")
+ item1 = item2;
+ t_insert(merged, item1);
+ else
+ --print("unmerged", merged)
+ item1 = item2;
+ local tmp = merged;
+ merged = { item1 };
+ return tmp;
+ end
+ end
+ end;
+
+end
+
+return _M;