Data::Transform::SAXBuilder - A filter for parsing XML with XML::LibXML
use Data::Transform::SAXBuilder; my $filter = Data::Transform::SAXBuilder->new(); my $wheel = POE::Wheel:ReadWrite->new( Filter => $filter, InputEvent => 'input_event', );
Data::Transform::SAXBuilder is used to turn an XML file or stream into a (series of) DOM tree (fragments). It uses the XML::LibXML modules to do the parsing and for the building of the DOM tree. This gives you very good support for most(all?) XML features, and allows you to use a host of extra modules available for use with XML::LibXML.
To make the potentially time-consuming parsing process not interfere with event-driven environments (like POE), SAXBuolder will return a series of document fragments instead of the entire DOM tree.
There are two modes:
You can control how often you get events by specifying till how deep into the tree you want to receive notifications. This also controls the size of the document fragments you'll receive when you're using the second, 'detached' mode.
Data::Transform::SAXBuilder follows the Data::Transform API. This documentation only covers things that are special to Data::Transform::SAXBuilder.
The constructor accepts two arguments which are both optional:
A string that is XML waiting to be parsed
A SAX Handler that builds your data structures from SAX events. The default is XML::SAX::IncrementalBuilder::LibXML, which creates DOM tree fragments. But you could create any sort of object/structure you like.
Resets the filter so it is ready to parse a new document from the beginning.
Martijn van Beers <firstname.lastname@example.org>
Copyright (c) 2006-2008 Martijn van Beers.
Based on POE::Filter::XML, which is Copyright (c) 2003 Nicholas Perez.
Released and distributed under the GPL.