mirror of
https://github.com/bjc/prosody.git
synced 2025-04-04 21:57:45 +03:00
tools/migration/migrator/jabberd14: Use util.xml.
This commit is contained in:
parent
997a920d80
commit
20a28d166c
1 changed files with 1 additions and 50 deletions
|
@ -1,7 +1,7 @@
|
||||||
|
|
||||||
local lfs = require "lfs";
|
local lfs = require "lfs";
|
||||||
local lxp = require "lxp";
|
|
||||||
local st = require "util.stanza";
|
local st = require "util.stanza";
|
||||||
|
local parse_xml = require "util.xml".parse;
|
||||||
local os_getenv = os.getenv;
|
local os_getenv = os.getenv;
|
||||||
local io_open = io.open;
|
local io_open = io.open;
|
||||||
local assert = assert;
|
local assert = assert;
|
||||||
|
@ -17,55 +17,6 @@ local function clean_path(path)
|
||||||
return path:gsub("\\", "/"):gsub("//+", "/"):gsub("^~", os_getenv("HOME") or "~");
|
return path:gsub("\\", "/"):gsub("//+", "/"):gsub("^~", os_getenv("HOME") or "~");
|
||||||
end
|
end
|
||||||
|
|
||||||
local parse_xml = (function()
|
|
||||||
local ns_prefixes = {
|
|
||||||
["http://www.w3.org/XML/1998/namespace"] = "xml";
|
|
||||||
};
|
|
||||||
local ns_separator = "\1";
|
|
||||||
local ns_pattern = "^([^"..ns_separator.."]*)"..ns_separator.."?(.*)$";
|
|
||||||
return function(xml)
|
|
||||||
local handler = {};
|
|
||||||
local stanza = st.stanza("root");
|
|
||||||
function handler:StartElement(tagname, attr)
|
|
||||||
local curr_ns,name = tagname:match(ns_pattern);
|
|
||||||
if name == "" then
|
|
||||||
curr_ns, name = "", curr_ns;
|
|
||||||
end
|
|
||||||
if curr_ns ~= "" then
|
|
||||||
attr.xmlns = curr_ns;
|
|
||||||
end
|
|
||||||
for i=1,#attr do
|
|
||||||
local k = attr[i];
|
|
||||||
attr[i] = nil;
|
|
||||||
local ns, nm = k:match(ns_pattern);
|
|
||||||
if nm ~= "" then
|
|
||||||
ns = ns_prefixes[ns];
|
|
||||||
if ns then
|
|
||||||
attr[ns..":"..nm] = attr[k];
|
|
||||||
attr[k] = nil;
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
stanza:tag(name, attr);
|
|
||||||
end
|
|
||||||
function handler:CharacterData(data)
|
|
||||||
stanza:text(data);
|
|
||||||
end
|
|
||||||
function handler:EndElement(tagname)
|
|
||||||
stanza:up();
|
|
||||||
end
|
|
||||||
local parser = lxp.new(handler, "\1");
|
|
||||||
local ok, err, line, col = parser:parse(xml);
|
|
||||||
if ok then ok, err, line, col = parser:parse(); end
|
|
||||||
--parser:close();
|
|
||||||
if ok then
|
|
||||||
return stanza.tags[1];
|
|
||||||
else
|
|
||||||
return ok, err.." (line "..line..", col "..col..")";
|
|
||||||
end
|
|
||||||
end;
|
|
||||||
end)();
|
|
||||||
|
|
||||||
local function load_xml(path)
|
local function load_xml(path)
|
||||||
local f, err = io_open(path);
|
local f, err = io_open(path);
|
||||||
if not f then return f, err; end
|
if not f then return f, err; end
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue