mirror of
https://github.com/bjc/prosody.git
synced 2025-04-04 21:57:45 +03:00
util.xmppstream: Optimized stanza building by bypassing the stanza API.
This commit is contained in:
parent
027cb33f09
commit
fb331b2a58
1 changed files with 16 additions and 7 deletions
|
@ -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)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue