NAME

AnyEvent::XMPP::Parser - Parser for XML streams (helper for AnyEvent::XMPP)

SYNOPSIS

use AnyEvent::XMPP::Parser;
...

DESCRIPTION

This is a XMPP XML parser helper class, which helps me to cope with the XMPP XML.

See also AnyEvent::XMPP::Writer for a discussion of the issues with XML in XMPP.

METHODS

new

This creates a new AnyEvent::XMPP::Parser and calls init.

set_stanza_cb ($cb)

Sets the 'XML stanza' callback.

$cb must be a code reference. The first argument to the callback will be this AnyEvent::XMPP::Parser instance and the second will be the stanzas root AnyEvent::XMPP::Node as first argument.

If the second argument is undefined the end of the stream has been found.

set_error_cb ($cb)

This sets the error callback that will be called when the parser encounters an syntax error. The first argument is the exception and the second is the data which caused the error.

set_stream_cb ($cb)

This method sets the stream tag callback. It is called when the <stream> tag from the server has been encountered. The first argument to the callback is the AnyEvent::XMPP::Node of the opening stream tag.

init

This methods (re)initializes the parser.

cleanup

This methods removes all handlers. Use it to avoid circular references.

nseq ($namespace, $tagname, $cmptag)

This method checks whether the $cmptag matches the $tagname in the $namespace.

$cmptag needs to come from the XML::Parser::Expat as it has some magic attached that stores the namespace.

feed ($data)

This method feeds a chunk of unparsed data to the parser.

AUTHOR

Robin Redeker, <elmex at ta-sa.org>, JID: <elmex at jabber.org>

COPYRIGHT & LICENSE

Copyright 2007, 2008 Robin Redeker, all rights reserved.

This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.