util.xmppstream: Optimized stanza building by bypassing the stanza API.

This commit is contained in:
Waqas Hussain 2010-12-29 18:49:59 +05:00
parent 027cb33f09
commit fb331b2a58

View file

@ -9,10 +9,13 @@
local lxp = require "lxp"; local lxp = require "lxp";
local st = require "util.stanza"; local st = require "util.stanza";
local stanza_mt = st.stanza_mt;
local tostring = tostring; local tostring = tostring;
local t_insert = table.insert; local t_insert = table.insert;
local t_concat = table.concat; local t_concat = table.concat;
local t_remove = table.remove;
local setmetatable = setmetatable;
local default_log = require "util.logger".init("xmppstream"); local default_log = require "util.logger".init("xmppstream");
@ -53,12 +56,13 @@ function new_sax_handlers(session, stream_callbacks)
local stream_default_ns = stream_callbacks.default_ns; local stream_default_ns = stream_callbacks.default_ns;
local stack = {};
local chardata, stanza = {}; local chardata, stanza = {};
local non_streamns_depth = 0; local non_streamns_depth = 0;
function xml_handlers:StartElement(tagname, attr) function xml_handlers:StartElement(tagname, attr)
if stanza and #chardata > 0 then if stanza and #chardata > 0 then
-- We have some character data in the buffer -- We have some character data in the buffer
stanza:text(t_concat(chardata)); t_insert(stanza, t_concat(chardata));
chardata = {}; chardata = {};
end end
local curr_ns,name = tagname:match(ns_pattern); local curr_ns,name = tagname:match(ns_pattern);
@ -102,9 +106,13 @@ function new_sax_handlers(session, stream_callbacks)
cb_error(session, "invalid-top-level-element"); cb_error(session, "invalid-top-level-element");
end end
stanza = st.stanza(name, attr); stanza = setmetatable({ name = name, attr = attr, tags = {} }, stanza_mt);
else -- we are inside a stanza, so add a tag else -- we are inside a stanza, so add a tag
stanza:tag(name, attr); t_insert(stack, stanza);
local oldstanza = stanza;
stanza = setmetatable({ name = name, attr = attr, tags = {} }, stanza_mt);
t_insert(oldstanza, stanza);
t_insert(oldstanza.tags, stanza);
end end
end end
function xml_handlers:CharacterData(data) function xml_handlers:CharacterData(data)
@ -119,12 +127,11 @@ function new_sax_handlers(session, stream_callbacks)
if stanza then if stanza then
if #chardata > 0 then if #chardata > 0 then
-- We have some character data in the buffer -- We have some character data in the buffer
stanza:text(t_concat(chardata)); t_insert(stanza, t_concat(chardata));
chardata = {}; chardata = {};
end end
-- Complete stanza -- Complete stanza
local last_add = stanza.last_add; if #stack == 0 then
if not last_add or #last_add == 0 then
if tagname ~= stream_error_tag then if tagname ~= stream_error_tag then
cb_handlestanza(session, stanza); cb_handlestanza(session, stanza);
else else
@ -132,7 +139,7 @@ function new_sax_handlers(session, stream_callbacks)
end end
stanza = nil; stanza = nil;
else else
stanza:up(); stanza = t_remove(stack);
end end
else else
if tagname == stream_tag then if tagname == stream_tag then
@ -147,11 +154,13 @@ function new_sax_handlers(session, stream_callbacks)
cb_error(session, "parse-error", "unexpected-element-close", name); cb_error(session, "parse-error", "unexpected-element-close", name);
end end
stanza, chardata = nil, {}; stanza, chardata = nil, {};
stack = {};
end end
end end
local function reset() local function reset()
stanza, chardata = nil, {}; stanza, chardata = nil, {};
stack = {};
end end
local function set_session(stream, new_session) local function set_session(stream, new_session)