diff options
author | Waqas Hussain <waqas20@gmail.com> | 2012-12-03 06:07:00 +0500 |
---|---|---|
committer | Waqas Hussain <waqas20@gmail.com> | 2012-12-03 06:07:00 +0500 |
commit | 3f690f3c1dcf3d77e2d3ee818ec2b3bd52a47d55 (patch) | |
tree | 32193989f72cd93a36bea4a74cfbfb547277fe8b /tools/openfire2prosody.lua | |
parent | f2f277328207d92db9439ad2a31125dad55cf7ca (diff) | |
parent | b007f899d502fa17cdce27dfcb2a288b44ba1e89 (diff) | |
download | prosody-3f690f3c1dcf3d77e2d3ee818ec2b3bd52a47d55.tar.gz prosody-3f690f3c1dcf3d77e2d3ee818ec2b3bd52a47d55.zip |
Merge 0.9->trunk.
Diffstat (limited to 'tools/openfire2prosody.lua')
-rw-r--r-- | tools/openfire2prosody.lua | 52 |
1 files changed, 1 insertions, 51 deletions
diff --git a/tools/openfire2prosody.lua b/tools/openfire2prosody.lua index 49d0dc5e..bdea9a63 100644 --- a/tools/openfire2prosody.lua +++ b/tools/openfire2prosody.lua @@ -18,57 +18,7 @@ elseif package.config:sub(1,1) == "/" then prosody.platform = "posix"; end -local lxp = require "lxp"; -local st = require "util.stanza"; - -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 parse_xml = require "util.xml".parse; ----------------------------------------------------------------------- |