IO::Async::XMLStream::SAXReader - Dispatch SAX events from an XML stream.
version 0.001003
use IO::Async::XMLStream::SAXReader;
use IO::Async::Loop;
my $loop = IO::Async::Loop->new();
my $sax = IO::Async::XMLStream::SAXReader->new(
handle => $SOME_IO_HANDLE,
on_start_document => sub {
my ( $saxreader, @args ) = @_;
...
},
on_start_element => sub {
my ( $saxreader, @args ) = @_;
...
},
on_end_document => sub {
$loop->stop;
},
);
$loop->add($sax);
$loop->run();
This sub-classes IO::Async::Stream
to provide a streaming SAX parser.
For the individual SAX
events that can be listened for, see XML::SAX::Base
.
All are prefixed with the on_
prefix as constructor arguments.
Alternatively, if you already have an XML::SAX
handler class you wish to reuse:
use IO::Async::XMLStream::SAXReader;
use IO::Async::Loop;
my $loop = IO::Async::Loop->new();
my $sax = IO::Async::XMLStream::SAXReader->new(
handle => $SOME_IO_HANDLE,
sax_handler => YourClass->new();
on_read_eof => sub {
$loop->stop;
},
);
$loop->add($sax);
$loop->run();
Kent Fredric kentnl@cpan.org
This software is copyright (c) 2017 by Kent Fredric kentfredric@gmail.com.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.