38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * testSAX.c : a small tester program for parsing using the SAX API.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * See Copyright for the status of this software.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * daniel@veillard.com
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync#include <libxml/parserInternals.h> /* only for xmlNewInputFromFile() */
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Timing routines.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Internal timing routines to remove the necessity to have unix-specific
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * function calls
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync return (0);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync#endif /* HAVE_FTIME */
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync#endif /* HAVE_SYS_TIME_H */
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync#endif /* HAVE_SYS_TIMEB_H */
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync#endif /* !HAVE_GETTIMEOFDAY */
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * startTimer: call where you want to start timing
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * endTimer: call where you want to stop timing and to print out a
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * message about the timing performed; format is a printf
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * type argument
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * No gettimeofday function, so we have to make do with calling clock.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * This is obviously less accurate, but there's little we can do about
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * We don't have a gettimeofday or time.h, so we just don't do timing
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Do nothing
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * We cannot do anything because we don't have a timing function
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync /* We don't have gettimeofday, time or stdarg.h, what crazy world is
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * empty SAX block
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncstatic xmlSAXHandlerPtr emptySAXHandler = &emptySAXHandlerStruct;
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync/************************************************************************
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Debug Handlers *
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync ************************************************************************/
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * isStandaloneDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: An XML parser context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Is this document tagged standalone ?
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Returns 1 if true
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * hasInternalSubsetDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: An XML parser context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Does this document has an internal subset
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Returns 1 if true
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * hasExternalSubsetDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: An XML parser context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Does this document has an external subset
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Returns 1 if true
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * internalSubsetDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: An XML parser context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Does this document has an internal subset
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncinternalSubsetDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *name,
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync const xmlChar *ExternalID, const xmlChar *SystemID)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * externalSubsetDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: An XML parser context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Does this document has an external subset
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncexternalSubsetDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *name,
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync const xmlChar *ExternalID, const xmlChar *SystemID)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * resolveEntityDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: An XML parser context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @publicId: The public ID of the entity
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @systemId: The system ID of the entity
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Special entity resolver, better left to the parser, it has
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * more context than the application layer.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * The default behaviour is to NOT resolve the entities, in that case
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * the ENTITY_REF nodes are built in the structure (and the parameter
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Returns the xmlParserInputPtr if inlined or NULL for DOM behaviour.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncresolveEntityDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *publicId, const xmlChar *systemId)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync /* xmlParserCtxtPtr ctxt = (xmlParserCtxtPtr) ctx; */
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if (systemId != NULL) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync return(xmlNewInputFromFile(ctxt, (char *) systemId));
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * getEntityDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: An XML parser context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @name: The entity name
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Get an entity by name
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Returns the xmlParserInputPtr if inlined or NULL for DOM behaviour.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncgetEntityDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *name)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * getParameterEntityDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: An XML parser context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @name: The entity name
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Get a parameter entity by name
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Returns the xmlParserInputPtr
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncgetParameterEntityDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *name)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync fprintf(stdout, "SAX.getParameterEntity(%s)\n", name);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * entityDeclDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: An XML parser context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @name: the entity name
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @type: the entity type
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @publicId: The public ID of the entity
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @systemId: The system ID of the entity
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @content: the entity value (without processing).
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * An entity definition has been parsed
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncentityDeclDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *name, int type,
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync const xmlChar *publicId, const xmlChar *systemId, xmlChar *content)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync /* not all libraries handle printing null pointers nicely */
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync fprintf(stdout, "SAX.entityDecl(%s, %d, %s, %s, %s)\n",
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * attributeDeclDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: An XML parser context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @name: the attribute name
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @type: the attribute type
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * An attribute definition has been parsed
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncattributeDeclDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar * elem,
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync const xmlChar * defaultValue, xmlEnumerationPtr tree)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync fprintf(stdout, "SAX.attributeDecl(%s, %s, %d, %d, NULL, ...)\n",
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync fprintf(stdout, "SAX.attributeDecl(%s, %s, %d, %d, %s, ...)\n",
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * elementDeclDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: An XML parser context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @name: the element name
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @type: the element type
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @content: the element value (without processing).
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * An element definition has been parsed
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncelementDeclDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *name, int type,
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * notationDeclDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: An XML parser context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @name: The name of the notation
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @publicId: The public ID of the entity
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @systemId: The system ID of the entity
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * What to do when a notation declaration has been parsed.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncnotationDeclDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *name,
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync (char *) name, (char *) publicId, (char *) systemId);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * unparsedEntityDeclDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: An XML parser context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @name: The name of the entity
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @publicId: The public ID of the entity
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @systemId: The system ID of the entity
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @notationName: the name of the notation
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * What to do when an unparsed entity declaration is parsed
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncunparsedEntityDeclDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *name,
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync fprintf(stdout, "SAX.unparsedEntityDecl(%s, %s, %s, %s)\n",
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync (char *) name, (char *) publicId, (char *) systemId,
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * setDocumentLocatorDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: An XML parser context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @loc: A SAX Locator
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Receive the document locator at startup, actually xmlDefaultSAXLocator
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Everything is available on the context, so this is useless in our case.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncsetDocumentLocatorDebug(void *ctx ATTRIBUTE_UNUSED, xmlSAXLocatorPtr loc ATTRIBUTE_UNUSED)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * startDocumentDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: An XML parser context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * called when the document start being processed.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * endDocumentDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: An XML parser context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * called when the document end has been detected.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * startElementDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: An XML parser context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @name: The element name
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * called when an opening tag has been processed.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncstartElementDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *name, const xmlChar **atts)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync fprintf(stdout, "SAX.startElement(%s", (char *) name);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * endElementDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: An XML parser context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @name: The element name
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * called when the end of an element has been detected.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncendElementDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *name)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync fprintf(stdout, "SAX.endElement(%s)\n", (char *) name);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * charactersDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: An XML parser context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ch: a xmlChar string
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @len: the number of xmlChar
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * receiving some chars from the parser.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Question: how much at a time ???
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsynccharactersDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *ch, int len)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync fprintf(stdout, "SAX.characters(%s, %d)\n", output, len);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * referenceDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: An XML parser context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @name: The entity name
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * called when an entity reference is detected.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncreferenceDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *name)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * ignorableWhitespaceDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: An XML parser context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ch: a xmlChar string
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @start: the first char in the string
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @len: the number of xmlChar
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * receiving some ignorable whitespaces from the parser.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Question: how much at a time ???
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncignorableWhitespaceDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *ch, int len)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync fprintf(stdout, "SAX.ignorableWhitespace(%s, %d)\n", output, len);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * processingInstructionDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: An XML parser context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @target: the target name
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @data: the PI data's
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @len: the number of xmlChar
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * A processing instruction has been parsed.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncprocessingInstructionDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *target,
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync fprintf(stdout, "SAX.processingInstruction(%s, %s)\n",
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync fprintf(stdout, "SAX.processingInstruction(%s, NULL)\n",
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * cdataBlockDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctx: the user data (XML parser context)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @value: The pcdata content
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @len: the block length
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * called when a pcdata block has been parsed
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsynccdataBlockDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *value, int len)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * commentDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: An XML parser context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @value: the comment content
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * A comment has been parsed.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsynccommentDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *value)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * warningDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: An XML parser context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @msg: the message to display/transmit
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @...: extra parameters for the message display
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Display and format a warning messages, gives file, line, position and
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * extra parameters.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncwarningDebug(void *ctx ATTRIBUTE_UNUSED, const char *msg, ...)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * errorDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: An XML parser context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @msg: the message to display/transmit
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @...: extra parameters for the message display
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Display and format a error messages, gives file, line, position and
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * extra parameters.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncerrorDebug(void *ctx ATTRIBUTE_UNUSED, const char *msg, ...)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * fatalErrorDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: An XML parser context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @msg: the message to display/transmit
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @...: extra parameters for the message display
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Display and format a fatalError messages, gives file, line, position and
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * extra parameters.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncfatalErrorDebug(void *ctx ATTRIBUTE_UNUSED, const char *msg, ...)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncxmlSAXHandlerPtr debugSAXHandler = &debugSAXHandlerStruct;
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * SAX2 specific callbacks
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * startElementNsDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: An XML parser context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @name: The element name
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * called when an opening tag has been processed.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync fprintf(stdout, "SAX.startElementNs(%s", (char *) localname);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync fprintf(stdout, ", %d, %d", nb_attributes, nb_defaulted);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync fprintf(stdout, ", %s:%s='", attributes[i + 1], attributes[i]);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * endElementDebug:
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @ctxt: An XML parser context
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * @name: The element name
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * called when the end of an element has been detected.
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync fprintf(stdout, "SAX.endElementNs(%s", (char *) localname);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncstatic xmlSAXHandlerPtr debugSAX2Handler = &debugSAX2HandlerStruct;
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync/************************************************************************
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync ************************************************************************/
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Empty callbacks for checking
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync#if defined(_WIN32) || defined (__DJGPP__) && !defined (__CYGWIN__)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if (f != NULL) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync ctxt = xmlCreatePushParserCtxt(emptySAXHandler, NULL,
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Debug callback
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync#if defined(_WIN32) || defined (__DJGPP__) && !defined (__CYGWIN__)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if (f != NULL) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync ctxt = xmlCreatePushParserCtxt(debugSAX2Handler, NULL,
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync ctxt = xmlCreatePushParserCtxt(debugSAXHandler, NULL,
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if (ret != 0) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync#endif /* LIBXML_PUSH_ENABLED */
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Empty callbacks for checking
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync res = xmlSAXUserParseFile(emptySAXHandler, NULL, filename);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if (res != 0) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync fprintf(stdout, "xmlSAXUserParseFile returned error %d\n", res);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * Debug callback
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync for (i = 0;i < 99;i++) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync res = xmlSAXUserParseFile(debugSAX2Handler, NULL, filename);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync res = xmlSAXUserParseFile(debugSAXHandler, NULL, filename);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if (res != 0) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync fprintf(stdout, "xmlSAXUserParseFile returned error %d\n", res);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync fprintf(stdout, "%d callbacks generated\n", callbacks);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync * test 100x the SAX parse
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync for (i = 0; i<100;i++)
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync res = xmlSAXUserParseFile(emptySAXHandler, NULL, filename);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if (res != 0) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync fprintf(stdout, "xmlSAXUserParseFile returned error %d\n", res);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync LIBXML_TEST_VERSION /* be safe, plus calls xmlInitParser */
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync if ((!strcmp(argv[i], "-debug")) || (!strcmp(argv[i], "--debug")))
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync else if ((!strcmp(argv[i], "-copy")) || (!strcmp(argv[i], "--copy")))
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync fprintf(stderr,"'push' not enabled in library - ignoring\n");
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync#endif /* LIBXML_PUSH_ENABLED */
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsyncint main(int argc ATTRIBUTE_UNUSED, char **argv ATTRIBUTE_UNUSED) {
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync printf("%s : SAX1 parsing support not compiled in\n", argv[0]);
38ae7e4efe803ea78b6499cd05a394db32623e41vboxsync#endif /* LIBXML_SAX1_ENABLED */