|   |   |   |   | libxml2 Reference Manual | 
|---|
SAX2 - SAX2 parser interface used to build the DOM tree
those are the default SAX2 interfaces used by the library when building DOM tree.
Author(s): Daniel Veillard
void xmlSAX2EndElementNs (void * ctx,
const xmlChar * localname,
const xmlChar * prefix,
const xmlChar * URI); void xmlSAX2Reference (void * ctx,
const xmlChar * name); void xmlSAX2ElementDecl (void * ctx,
const xmlChar * name,
int type,
xmlElementContentPtr content); void xmlSAX2AttributeDecl (void * ctx,
const xmlChar * elem,
const xmlChar * fullname,
int type,
int def,
const xmlChar * defaultValue,
xmlEnumerationPtr tree); void xmlSAX2Comment (void * ctx,
const xmlChar * value); int xmlSAX2GetColumnNumber (void * ctx); xmlEntityPtr xmlSAX2GetEntity (void * ctx,
const xmlChar * name); void xmlSAX2UnparsedEntityDecl (void * ctx,
const xmlChar * name,
const xmlChar * publicId,
const xmlChar * systemId,
const xmlChar * notationName); void xmlSAX2InitDocbDefaultSAXHandler (xmlSAXHandler * hdlr); int xmlSAXVersion (xmlSAXHandler * hdlr,
int version); void xmlSAX2IgnorableWhitespace (void * ctx,
const xmlChar * ch,
int len); void xmlSAX2NotationDecl (void * ctx,
const xmlChar * name,
const xmlChar * publicId,
const xmlChar * systemId); void xmlSAX2StartDocument (void * ctx); void xmlSAX2EndElement (void * ctx,
const xmlChar * name); xmlParserInputPtr xmlSAX2ResolveEntity (void * ctx,
const xmlChar * publicId,
const xmlChar * systemId); void xmlSAX2ExternalSubset (void * ctx,
const xmlChar * name,
const xmlChar * ExternalID,
const xmlChar * SystemID); const xmlChar * xmlSAX2GetPublicId (void * ctx); int xmlSAX2IsStandalone (void * ctx); void xmlSAX2EndDocument (void * ctx); void xmlSAX2ProcessingInstruction (void * ctx,
const xmlChar * target,
const xmlChar * data); void xmlSAX2InternalSubset (void * ctx,
const xmlChar * name,
const xmlChar * ExternalID,
const xmlChar * SystemID); void xmlSAX2Characters (void * ctx,
const xmlChar * ch,
int len); int xmlSAXDefaultVersion (int version); void xmlSAX2StartElement (void * ctx,
const xmlChar * fullname,
const xmlChar ** atts); void xmlSAX2SetDocumentLocator (void * ctx,
xmlSAXLocatorPtr loc); void xmlSAX2CDataBlock (void * ctx,
const xmlChar * value,
int len); void xmlSAX2StartElementNs (void * ctx,
const xmlChar * localname,
const xmlChar * prefix,
const xmlChar * URI,
int nb_namespaces,
const xmlChar ** namespaces,
int nb_attributes,
int nb_defaulted,
const xmlChar ** attributes); int xmlSAX2HasExternalSubset (void * ctx); void htmlDefaultSAXHandlerInit (void); int xmlSAX2GetLineNumber (void * ctx); int xmlSAX2HasInternalSubset (void * ctx); void xmlSAX2InitHtmlDefaultSAXHandler (xmlSAXHandler * hdlr); void docbDefaultSAXHandlerInit (void); void xmlDefaultSAXHandlerInit (void); void xmlSAX2InitDefaultSAXHandler (xmlSAXHandler * hdlr,
int warning); xmlEntityPtr xmlSAX2GetParameterEntity (void * ctx,
const xmlChar * name); const xmlChar * xmlSAX2GetSystemId (void * ctx); void xmlSAX2EntityDecl (void * ctx,
const xmlChar * name,
int type,
const xmlChar * publicId,
const xmlChar * systemId,
xmlChar * content);
void docbDefaultSAXHandlerInit (void)
Initialize the default SAX handler
void htmlDefaultSAXHandlerInit (void)
Initialize the default SAX handler
void xmlSAX2AttributeDecl (void * ctx,
const xmlChar * elem,
const xmlChar * fullname,
int type,
int def,
const xmlChar * defaultValue,
xmlEnumerationPtr tree)
An attribute definition has been parsed
void xmlSAX2CDataBlock (void * ctx,
const xmlChar * value,
int len)
called when a pcdata block has been parsed
| ctx: | the user data (XML parser context) | 
| value: | The pcdata content | 
| len: | the block length | 
void xmlSAX2Characters (void * ctx,
const xmlChar * ch,
int len)
receiving some chars from the parser.
void xmlSAX2Comment (void * ctx,
const xmlChar * value)
A xmlSAX2Comment has been parsed.
| ctx: | the user data (XML parser context) | 
| value: | the xmlSAX2Comment content | 
void xmlSAX2ElementDecl (void * ctx,
const xmlChar * name,
int type,
xmlElementContentPtr content)
An element definition has been parsed
| ctx: | the user data (XML parser context) | 
| name: | the element name | 
| type: | the element type | 
| content: | the element value tree | 
void xmlSAX2EndDocument (void * ctx)
called when the document end has been detected.
| ctx: | the user data (XML parser context) | 
void xmlSAX2EndElement (void * ctx,
const xmlChar * name)
called when the end of an element has been detected.
| ctx: | the user data (XML parser context) | 
| name: | The element name | 
void xmlSAX2EndElementNs (void * ctx,
const xmlChar * localname,
const xmlChar * prefix,
const xmlChar * URI)
SAX2 callback when an element end has been detected by the parser. It provides the namespace information for the element.
| ctx: | the user data (XML parser context) | 
| localname: | the local name of the element | 
| prefix: | the element namespace prefix if available | 
| URI: | the element namespace name if available | 
void xmlSAX2EntityDecl (void * ctx,
const xmlChar * name,
int type,
const xmlChar * publicId,
const xmlChar * systemId,
xmlChar * content)
An entity definition has been parsed
| ctx: | the user data (XML parser context) | 
| name: | the entity name | 
| type: | the entity type | 
| publicId: | The public ID of the entity | 
| systemId: | The system ID of the entity | 
| content: | the entity value (without processing). | 
void xmlSAX2ExternalSubset (void * ctx,
const xmlChar * name,
const xmlChar * ExternalID,
const xmlChar * SystemID)
Callback on external subset declaration.
| ctx: | the user data (XML parser context) | 
| name: | the root element name | 
| ExternalID: | the external ID | 
| SystemID: | the SYSTEM ID (e.g. filename or URL) | 
int xmlSAX2GetColumnNumber (void * ctx)
Provide the column number of the current parsing point.
| ctx: | the user data (XML parser context) | 
| Returns: | an int | 
xmlEntityPtr xmlSAX2GetEntity (void * ctx,
const xmlChar * name)
Get an entity by name
| ctx: | the user data (XML parser context) | 
| name: | The entity name | 
| Returns: | the xmlEntityPtr if found. | 
int xmlSAX2GetLineNumber (void * ctx)
Provide the line number of the current parsing point.
| ctx: | the user data (XML parser context) | 
| Returns: | an int | 
xmlEntityPtr xmlSAX2GetParameterEntity (void * ctx,
const xmlChar * name)
Get a parameter entity by name
| ctx: | the user data (XML parser context) | 
| name: | The entity name | 
| Returns: | the xmlEntityPtr if found. | 
const xmlChar * xmlSAX2GetPublicId (void * ctx)
Provides the public ID e.g. "-//SGMLSOURCE//DTD DEMO//EN"
| ctx: | the user data (XML parser context) | 
| Returns: | a xmlChar * | 
const xmlChar * xmlSAX2GetSystemId (void * ctx)
Provides the system ID, basically URL or filename e.g. http://www.sgmlsource.com/dtds/memo.dtd
| ctx: | the user data (XML parser context) | 
| Returns: | a xmlChar * | 
int xmlSAX2HasExternalSubset (void * ctx)
Does this document has an external subset
| ctx: | the user data (XML parser context) | 
| Returns: | 1 if true | 
int xmlSAX2HasInternalSubset (void * ctx)
Does this document has an internal subset
| ctx: | the user data (XML parser context) | 
| Returns: | 1 if true | 
void xmlSAX2IgnorableWhitespace (void * ctx,
const xmlChar * ch,
int len)
receiving some ignorable whitespaces from the parser. UNUSED: by default the DOM building will use xmlSAX2Characters
void xmlSAX2InitDefaultSAXHandler (xmlSAXHandler * hdlr,
int warning)
Initialize the default XML SAX2 handler
| hdlr: | the SAX handler | 
| warning: | flag if non-zero sets the handler warning procedure | 
void xmlSAX2InitDocbDefaultSAXHandler (xmlSAXHandler * hdlr)
Initialize the default DocBook SAX2 handler
| hdlr: | the SAX handler | 
void xmlSAX2InitHtmlDefaultSAXHandler (xmlSAXHandler * hdlr)
Initialize the default HTML SAX2 handler
| hdlr: | the SAX handler | 
void xmlSAX2InternalSubset (void * ctx,
const xmlChar * name,
const xmlChar * ExternalID,
const xmlChar * SystemID)
Callback on internal subset declaration.
| ctx: | the user data (XML parser context) | 
| name: | the root element name | 
| ExternalID: | the external ID | 
| SystemID: | the SYSTEM ID (e.g. filename or URL) | 
int xmlSAX2IsStandalone (void * ctx)
Is this document tagged standalone ?
| ctx: | the user data (XML parser context) | 
| Returns: | 1 if true | 
void xmlSAX2NotationDecl (void * ctx,
const xmlChar * name,
const xmlChar * publicId,
const xmlChar * systemId)
What to do when a notation declaration has been parsed.
| ctx: | the user data (XML parser context) | 
| name: | The name of the notation | 
| publicId: | The public ID of the entity | 
| systemId: | The system ID of the entity | 
void xmlSAX2ProcessingInstruction (void * ctx,
const xmlChar * target,
const xmlChar * data)
A processing instruction has been parsed.
| ctx: | the user data (XML parser context) | 
| target: | the target name | 
| data: | the PI data's | 
void xmlSAX2Reference (void * ctx,
const xmlChar * name)
called when an entity xmlSAX2Reference is detected.
| ctx: | the user data (XML parser context) | 
| name: | The entity name | 
xmlParserInputPtr xmlSAX2ResolveEntity (void * ctx,
const xmlChar * publicId,
const xmlChar * systemId)
The entity loader, to control the loading of external entities, the application can either: - override this xmlSAX2ResolveEntity() callback in the SAX block - or better use the xmlSetExternalEntityLoader() function to set up it's own entity resolution routine
| ctx: | the user data (XML parser context) | 
| publicId: | The public ID of the entity | 
| systemId: | The system ID of the entity | 
| Returns: | the xmlParserInputPtr if inlined or NULL for DOM behaviour. | 
void xmlSAX2SetDocumentLocator (void * ctx,
xmlSAXLocatorPtr loc)
Receive the document locator at startup, actually xmlDefaultSAXLocator Everything is available on the context, so this is useless in our case.
| ctx: | the user data (XML parser context) | 
| loc: | A SAX Locator | 
void xmlSAX2StartDocument (void * ctx)
called when the document start being processed.
| ctx: | the user data (XML parser context) | 
void xmlSAX2StartElement (void * ctx,
const xmlChar * fullname,
const xmlChar ** atts)
called when an opening tag has been processed.
| ctx: | the user data (XML parser context) | 
| fullname: | The element name, including namespace prefix | 
| atts: | An array of name/value attributes pairs, NULL terminated | 
void xmlSAX2StartElementNs (void * ctx,
const xmlChar * localname,
const xmlChar * prefix,
const xmlChar * URI,
int nb_namespaces,
const xmlChar ** namespaces,
int nb_attributes,
int nb_defaulted,
const xmlChar ** attributes)
SAX2 callback when an element start has been detected by the parser. It provides the namespace information for the element, as well as the new namespace declarations on the element.
| ctx: | the user data (XML parser context) | 
| localname: | the local name of the element | 
| prefix: | the element namespace prefix if available | 
| URI: | the element namespace name if available | 
| nb_namespaces: | number of namespace definitions on that node | 
| namespaces: | pointer to the array of prefix/URI pairs namespace definitions | 
| nb_attributes: | the number of attributes on that node | 
| nb_defaulted: | the number of defaulted attributes. | 
| attributes: | pointer to the array of (localname/prefix/URI/value/end) attribute values. | 
void xmlSAX2UnparsedEntityDecl (void * ctx,
const xmlChar * name,
const xmlChar * publicId,
const xmlChar * systemId,
const xmlChar * notationName)
What to do when an unparsed entity declaration is parsed
| ctx: | the user data (XML parser context) | 
| name: | The name of the entity | 
| publicId: | The public ID of the entity | 
| systemId: | The system ID of the entity | 
| notationName: | the name of the notation | 
int xmlSAXDefaultVersion (int version)
Set the default version of SAX used globally by the library. By default, during initialization the default is set to 2. Note that it is generally a better coding style to use xmlSAXVersion() to set up the version explicitly for a given parsing context.
| version: | the version, 1 or 2 | 
| Returns: | the previous value in case of success and -1 in case of error. | 
int xmlSAXVersion (xmlSAXHandler * hdlr,
int version)
Initialize the default XML SAX handler according to the version
| hdlr: | the SAX handler | 
| version: | the version, 1 or 2 | 
| Returns: | 0 in case of success and -1 in case of error. |