NAME
RPC::XML::ParserFactory - A factory class for RPC::XML::Parser objects
SYNOPSIS
use RPC::XML::ParserFactory;
...
$P = RPC::XML::ParserFactory->new();
$P->parse($message);
DESCRIPTION
The RPC::XML::ParserFactory class encapsulates the process of creating parser objects that adhere to the interface described in RPC::XML::Parser. Under the hood, the parser object created and returned could be from any of a number of implementation classes.
IMPORT-TIME ARGUMENTS
You can specify a particular underlying parser class to use, if you do not want to allow RPC::XML::Parser to use the default class. This is done with the class
keyword:
use RPC::XML::Parser (class => 'XML::Parser');
The value may be the name for any of the built-in classes, or it may be the name of a class that is a sub-class of this package (and can thus be "manufactured" by the factory). The value is saved and becomes the default class for any calls to new that do not explicitly name a class to use.
Note that if the specified class is not valid, this is not tested until the first call to new, at which point an invalid class will cause an exception (error) to occur. The constructor will return undef
and the $RPC::XML::ERROR variable will contain the error message.
Names of Built-In Parsers
The following names are valid when specified as the value of the class
argument described above:
- XML::Parser
- xml::parser
- xmlparser
-
All of these specify the parser implementation based on the XML::Parser module. This is the default parser if the user does not specify any alternative.
- XML::LibXML
- xml::libxml
- xmllibxml
-
These specify a parser implementation based on the XML::LibXML module. This is a new parser and not as well-vetted as the previous one, hence it must be explicitly requested.
METHODS
The methods are:
- new([ARGS])
-
Create a new instance of the class. Any extra data passed to the constructor is taken as key/value pairs (not a hash reference) and attached to the object.
This method passes all arguments on to the new() method of the chosen implementation class, except for the following:
DIAGNOSTICS
The constructor returns undef
upon failure, with the error message available in the global variable $RPC::XML::ERROR
.
BUGS
Please report any bugs or feature requests to bug-rpc-xml at rt.cpan.org
, or through the web interface at http://rt.cpan.org/NoAuth/ReportBug.html?Queue=RPC-XML. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.
SUPPORT
RT: CPAN's request tracker
AnnoCPAN: Annotated CPAN documentation
CPAN Ratings
Search CPAN
Source code on GitHub
COPYRIGHT & LICENSE
This file and the code within are copyright (c) 2009 by Randy J. Ray.
Copying and distribution are permitted under the terms of the Artistic License 2.0 (http://www.opensource.org/licenses/artistic-license-2.0.php) or the GNU LGPL 2.1 (http://www.opensource.org/licenses/lgpl-2.1.php).
CREDITS
The XML-RPC standard is Copyright (c) 1998-2001, UserLand Software, Inc. See <http://www.xmlrpc.com> for more information about the XML-RPC specification.
SEE ALSO
RPC::XML, RPC::XML::Client, RPC::XML::Server, XML::Parser
AUTHOR
Randy J. Ray <rjray@blackperl.com>