XML::Parser (3)
Leading comments
Automatically generated by Pod::Man 4.09 (Pod::Simple 3.35) Standard preamble: ========================================================================
NAME
XML::Parser - A perl module for parsing XML documentsSYNOPSIS
use XML::Parser; $p1 = XML::Parser->new(Style => 'Debug'); $p1->parsefile('REC-xml-19980210.xml'); $p1->parse('<foo id="me">Hello World</foo>'); # Alternative $p2 = XML::Parser->new(Handlers => {Start => \&handle_start, End => \&handle_end, Char => \&handle_char}); $p2->parse($socket); # Another alternative $p3 = XML::Parser->new(ErrorContext => 2); $p3->setHandlers(Char => \&text, Default => \&other); open(FOO, 'xmlgenerator |'); $p3->parse(*FOO, ProtocolEncoding => 'ISO-8859-1'); close(FOO); $p3->parsefile('junk.xml', ErrorContext => 3);
DESCRIPTION
This module provides ways to parseThe behavior of the parser is controlled either by "STYLES" and/or "HANDLERS" options, or by ``setHandlers'' method. These all provide mechanisms for XML::Parser to set the handlers needed by XML::Parser::Expat. If neither "Style" nor "Handlers" are specified, then parsing just checks the document for being well-formed.
When underlying handlers get called, they receive as their first parameter the Expat object, not the Parser object.
METHODS
- new
-
This is a class method, the constructor for XML::Parser. Options are passed
as keyword value pairs. Recognized options are:
-
- *
-
Style
This option provides an easy way to create a given style of parser. The built in styles are: ``Debug'', ``Subs'', ``Tree'', ``Objects'', and ``Stream''. These are all defined in separate packages under "XML::Parser::Style::*", and you can find further documentation for each style both below, and in those packages.
Custom styles can be provided by giving a full package name containing at least one '::'. This package should then have subs defined for each handler it wishes to have installed. See ``
STYLES''below for a discussion of each built in style. - *
-
Handlers
When provided, this option should be an anonymous hash containing as keys the type of handler and as values a sub reference to handle that type of event. All the handlers get passed as their 1st parameter the instance of expat that is parsing the document. Further details on handlers can be found in ``
HANDLERS''. Any handler set here overrides the corresponding handler set with the Style option. - *
-
Pkg
Some styles will refer to subs defined in this package. If not provided, it defaults to the package which called the constructor.
- *
-
ErrorContext
This is an Expat option. When this option is defined, errors are reported in context. The value should be the number of lines to show on either side of the line in which the error occurred.
- *
-
ProtocolEncoding
This is an Expat option. This sets the protocol encoding name. It defaults to none. The built-in encodings are: "UTF-8", "ISO-8859-1", "UTF-16", and "US-ASCII". Other encodings may be used if they have encoding maps in one of the directories in the @Encoding_Path list. Check ``
ENCODINGS''for more information on encoding maps. Setting the protocol encoding overrides any encoding in theXMLdeclaration. - *
-
Namespaces
This is an Expat option. If this is set to a true value, then namespace processing is done during the parse. See ``Namespaces'' in XML::Parser::Expat for further discussion of namespace processing.
- *
-
NoExpand
This is an Expat option. Normally, the parser will try to expand references to entities defined in the internal subset. If this option is set to a true value, and a default handler is also set, then the default handler will be called when an entity reference is seen in text. This has no effect if a default handler has not been registered, and it has no effect on the expansion of entity references inside attribute values.
- *
-
Stream_Delimiter
This is an Expat option. It takes a string value. When this string is found alone on a line while parsing from a stream, then the parse is ended as if it saw an end of file. The intended use is with a stream of xml documents in a
MIMEmultipart format. The string should not contain a trailing newline. - *
-
ParseParamEnt
This is an Expat option. Unless standalone is set to ``yes'' in the
XMLdeclaration, setting this to a true value allows the externalDTDto be read, and parameter entities to be parsed and expanded. - *
-
NoLWP
This option has no effect if the ExternEnt or ExternEntFin handlers are directly set. Otherwise, if true, it forces the use of a file based external entity handler.
- *
-
Non-Expat-Options
If provided, this should be an anonymous hash whose keys are options that shouldn't be passed to Expat. This should only be of concern to those subclassing XML::Parser.
-
- setHandlers(TYPE, HANDLER[,TYPE, HANDLER[...]])
-
This method registers handlers for various parser events. It overrides any
previous handlers registered through the Style or Handler options or through
earlier calls to setHandlers. By providing a false or undefined value as
the handler, the existing handler can be unset.
This method returns a list of type, handler pairs corresponding to the input. The handlers returned are the ones that were in effect prior to the call.
See a description of the handler types in ``
HANDLERS''. - parse(SOURCE[,OPT=>OPT_VALUE[...]])
-
The SOURCEparameter should either be a string containing the wholeXMLdocument, or it should be an open IO::Handle. Constructor options to XML::Parser::Expat given as keyword-value pairs may follow theSOURCEparameter. These override, for this call, any options or attributes passed through from the XML::Parser instance.
A die call is thrown if a parse error occurs. Otherwise it will return 1 or whatever is returned from the Final handler, if one is installed. In other words, what parse may return depends on the style.
- parsestring
- This is just an alias for parse for backwards compatibility.
- parsefile(FILE[,OPT=>OPT_VALUE[...]])
-
Open FILEfor reading, then call parse with the open handle. The file is closed no matter how parse returns. Returns what parse returns.
- parse_start([ OPT=>OPT_VALUE[...]])
-
Create and return a new instance of XML::Parser::ExpatNB. Constructor
options may be provided. If an init handler has been provided, it is
called before returning the ExpatNB object. Documents are parsed by
making incremental calls to the parse_more method of this object, which
takes a string. A single call to the parse_done method of this object,
which takes no arguments, indicates that the document is finished.
If there is a final handler installed, it is executed by the parse_done method before returning and the parse_done method returns whatever is returned by the final handler.
HANDLERS
Expat is an event based parser. As the parser recognizes parts of the document (say the start or end tag for anInit (Expat)
This is called just before the parsing of the document starts.Final (Expat)
This is called just after parsing has finished, but only if no errors occurred during the parse. Parse returns what this returns.Start (Expat, Element [, Attr, Val [,...]])
This event is generated when anEnd (Expat, Element)
This event is generated when anChar (Expat, String)
This event is generated when non-markup is recognized. The non-markup sequence of characters is in String. A single non-markup sequence of characters may generate multiple calls to this handler. Whatever the encoding of the string in the original document, this is given to the handler inProc (Expat, Target, Data)
This event is generated when a processing instruction is recognized.Comment (Expat, Data)
This event is generated when a comment is recognized.CdataStart (Expat)
This is called at the start of aCdataEnd (Expat)
This is called at the end of aDefault (Expat, String)
This is called for any characters that don't have a registered handler. This includes both characters that are part of markup for which no events are generated (markup declarations) and characters that could generate events, but for which no handler has been registered.Whatever the encoding in the original document, the string is returned to the handler in
Unparsed (Expat, Entity, Base, Sysid, Pubid, Notation)
This is called for a declaration of an unparsed entity. Entity is the name of the entity. Base is the base to be used for resolving a relativeNotation (Expat, Notation, Base, Sysid, Pubid)
This is called for a declaration of notation. Notation is the notation name. Base is the base to be used for resolving a relativeExternEnt (Expat, Base, Sysid, Pubid)
This is called when an external entity is referenced. Base is the base to be used for resolving a relativeThis handler should either return a string, which represents the contents of the external entity, or return an open filehandle that can be read to obtain the contents of the external entity, or return undef, which indicates the external entity couldn't be found and will generate a parse error.
If an open filehandle is returned, it must be returned as either a glob (*FOO) or as a reference to a glob (e.g. an instance of IO::Handle).
A default handler is installed for this event. The default handler is XML::Parser::lwp_ext_ent_handler unless the NoLWP option was provided with a true value, otherwise XML::Parser::file_ext_ent_handler is the default handler for external entities. Even without the NoLWP option, if the
The
Please note that the
Also note that the file external entity handler will likely choke on absolute URIs or file names that don't fit the conventions of the local operating system.
The expat base method can be used to set a basename for relative pathnames. If no basename is given, or if the basename is itself a relative name, then it is relative to the current working directory.
ExternEntFin (Expat)
This is called after parsing an external entity. It's not called unless an ExternEnt handler is also set. There is a default handler installed that pairs with the default ExternEnt handler.If you're going to install your own ExternEnt handler, then you should set (or unset) this handler too.
Entity (Expat, Name, Val, Sysid, Pubid, Ndata, IsParam)
This is called when an entity is declared. For internal entities, the Val parameter will contain the value and the remaining three parameters will be undefined. For external entities, the Val parameter will be undefined, the Sysid parameter will have the system id, the Pubid parameter will have the public id if it was provided (it will be undefined otherwise), the Ndata parameter will contain the notation for unparsed entities. If this is a parameter entity declaration, then the IsParam parameter is true.Note that this handler and the Unparsed handler above overlap. If both are set, then this handler will not be called for unparsed entities.
Element (Expat, Name, Model)
The element handler is called when an element declaration is found. Name is the element name, and Model is the content model as an XML::Parser::Content object. See ``XML::Parser::ContentModel Methods'' in XML::Parser::Expat for methods available for this class.Attlist (Expat, Elname, Attname, Type, Default, Fixed)
This handler is called for each attribute in anDoctype (Expat, Name, Sysid, Pubid, Internal)
This handler is called for* DoctypeFin (Parser)
This handler is called after parsing of theXMLDecl (Expat, Version, Encoding, Standalone)
This handler is called for xml declarations. Version is a string containing the version. Encoding is either undefined or contains an encoding string. Standalone will be either true, false, or undefined if the standalone attribute is yes, no, or not made respectively.STYLES
Debug
This just prints out the document in outline form. Nothing special is returned by parse.Subs
Each time an element starts, a sub by that name in the package specified by the Pkg option is called with the same parameters that the Start handler gets called with.Each time an element ends, a sub with that name appended with an underscore (``_''), is called with the same parameters that the End handler gets called with.
Nothing special is returned by parse.
Tree
Parse will return a parse tree for the document. Each node in the tree takes the form of a tag, content pair. Text nodes are represented with a pseudo-tag of ``0'' and the string that is their content. For elements, the content is an array reference. The first item in the array is a (possibly empty) hash reference containing attributes. The remainder of the array is a sequence of tag-content pairs representing the content of the element.So for example the result of parsing:
<foo><head id="a">Hello <em>there</em></head><bar>Howdy<ref/></bar>do</foo>
would be:
Tag Content ================================================================== [foo, [{}, head, [{id => "a"}, 0, "Hello ", em, [{}, 0, "there"]], bar, [ {}, 0, "Howdy", ref, [{}]], 0, "do" ] ]
The root document ``foo'', has 3 children: a ``head'' element, a ``bar'' element and the text ``do''. After the empty attribute hash, these are represented in it's contents by 3 tag-content pairs.
Objects
This is similar to the Tree style, except that a hash object is created for each element. The corresponding object will be in the class whose name is created by appending ``::'' and the element name to the package set with the Pkg option. Non-markup text will be in the ::Characters class. The contents of the corresponding object will be in an anonymous array that is the value of the Kids property for that object.Stream
This style also uses the Pkg package. If none of the subs that this style looks for is there, then the effect of parsing with this style is to print a canonical copy of the document without comments or declarations. All the subs receive as their 1st parameter the Expat instance for the document they're parsing.It looks for the following routines:
- *
-
StartDocument
Called at the start of the parse .
- *
-
StartTag
Called for every start tag with a second parameter of the element type. The $_ variable will contain a copy of the tag and the %_ variable will contain attribute values supplied for that element.
- *
-
EndTag
Called for every end tag with a second parameter of the element type. The $_ variable will contain a copy of the end tag.
- *
-
Text
Called just before start or end tags with accumulated non-markup text in the $_ variable.
- *
-
PI
Called for processing instructions. The $_ variable will contain a copy of the
PIand the target and data are sent as 2nd and 3rd parameters respectively. - *
-
EndDocument
Called at conclusion of the parse.
ENCODINGS
Expat has built-in encodings for: "UTF-8", "ISO-8859-1", "UTF-16", and "US-ASCII". Encodings are set either through the
For encodings other than the built-ins, expat calls the function load_encoding in the Expat package with the encoding name. This function looks for a file in the path list @XML::Parser::Expat::Encoding_Path, that matches the lower-cased name with a '.enc' extension. The first one it finds, it loads.
If you wish to build your own encoding maps, check out the XML::Encoding module from
AUTHORS
Larry Wall <larry@wall.org> wrote version 1.0.Clark Cooper <coopercc@netheaven.com> picked up support, changed the
Matt Sergeant <matt@sergeant.org> is now maintaining XML::Parser