Provided by: libxml-sax-perl_1.02+dfsg-3_all bug

NAME

       XML::SAX::ParserFactory - Obtain a SAX parser

SYNOPSIS

         use XML::SAX::ParserFactory;
         use XML::SAX::XYZHandler;
         my $handler = XML::SAX::XYZHandler->new();
         my $p = XML::SAX::ParserFactory->parser(Handler => $handler);
         $p->parse_uri("foo.xml");
         # or $p->parse_string("<foo/>") or $p->parse_file($fh);

DESCRIPTION

       XML::SAX::ParserFactory is a factory class for providing an application with a Perl SAX2
       XML parser. It is akin to DBI - a front end for other parser classes. Each new SAX2 parser
       installed will register itself with XML::SAX, and then it will become available to all
       applications that use XML::SAX::ParserFactory to obtain a SAX parser.

       Unlike DBI however, XML/SAX parsers almost all work alike (especially if they subclass
       XML::SAX::Base, as they should), so rather than specifying the parser you want in the call
       to "parser()", XML::SAX has several ways to automatically choose which parser to use:

       •   $XML::SAX::ParserPackage

           If this package variable is set, then this package is "require()"d and an instance of
           this package is returned by calling the "new()" class method in that package. If it
           cannot be loaded or there is an error, an exception will be thrown. The variable can
           also contain a version number:

             $XML::SAX::ParserPackage = "XML::SAX::Expat (0.72)";

           And the number will be treated as a minimum version number.

       •   Required features

           It is possible to require features from the parsers. For example, you may wish for a
           parser that supports validation via a DTD. To do that, use the following code:

             use XML::SAX::ParserFactory;
             my $factory = XML::SAX::ParserFactory->new();
             $factory->require_feature('http://xml.org/sax/features/validation');
             my $parser = $factory->parser(...);

           Alternatively, specify the required features in the call to the ParserFactory
           constructor:

             my $factory = XML::SAX::ParserFactory->new(
                     RequiredFeatures => {
                          'http://xml.org/sax/features/validation' => 1,
                          }
                     );

           If the features you have asked for are unavailable (for example the user might not
           have a validating parser installed), then an exception will be thrown.

           The list of known parsers is searched in reverse order, so it will always return the
           last installed parser that supports all of your requested features (Note: this is
           subject to change if someone comes up with a better way of making this work).

       •   SAX.ini

           ParserFactory will search @INC for a file called SAX.ini, which is in a simple format:

             # a comment looks like this,
             ; or like this, and are stripped anywhere in the file
             key = value # SAX.in contains key/value pairs.

           All whitespace is non-significant.

           This file can contain either a line:

             ParserPackage = MyParserModule (1.02)

           Where MyParserModule is the module to load and use for the parser, and the number in
           brackets is a minimum version to load.

           Or you can list required features:

             http://xml.org/sax/features/validation = 1

           And each feature with a true value will be required.

       •   Fallback

           If none of the above works, the last parser installed on the user's system will be
           used. The XML::SAX package ships with a pure perl XML parser, XML::SAX::PurePerl, so
           that there will always be a fallback parser.

AUTHOR

       Matt Sergeant, matt@sergeant.org

LICENSE

       This is free software, you may use it and distribute it under the same terms as Perl
       itself.