| |
| |
| |
| |
| |
| |
| |
| |
| #include "libxml.h" |
| |
| #ifdef HAVE_SYS_TIME_H |
| #include <sys/time.h> |
| #endif |
| #ifdef HAVE_SYS_TIMEB_H |
| #include <sys/timeb.h> |
| #endif |
| #ifdef HAVE_TIME_H |
| #include <time.h> |
| #endif |
| |
| #ifdef LIBXML_SAX1_ENABLED |
| #include <string.h> |
| #include <stdarg.h> |
| |
| #ifdef HAVE_SYS_TYPES_H |
| #include <sys/types.h> |
| #endif |
| #ifdef HAVE_SYS_STAT_H |
| #include <sys/stat.h> |
| #endif |
| #ifdef HAVE_FCNTL_H |
| #include <fcntl.h> |
| #endif |
| #ifdef HAVE_UNISTD_H |
| #include <unistd.h> |
| #endif |
| #ifdef HAVE_STDLIB_H |
| #include <stdlib.h> |
| #endif |
| #ifdef HAVE_STRING_H |
| #include <string.h> |
| #endif |
| |
| |
| #include <libxml/globals.h> |
| #include <libxml/xmlerror.h> |
| #include <libxml/parser.h> |
| #include <libxml/parserInternals.h> /* only for xmlNewInputFromFile() */ |
| #include <libxml/tree.h> |
| #include <libxml/debugXML.h> |
| #include <libxml/xmlmemory.h> |
| |
| static int debug = 0; |
| static int copy = 0; |
| static int recovery = 0; |
| static int push = 0; |
| static int speed = 0; |
| static int noent = 0; |
| static int quiet = 0; |
| static int nonull = 0; |
| static int sax2 = 0; |
| static int repeat = 0; |
| static int callbacks = 0; |
| static int timing = 0; |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| #ifndef HAVE_GETTIMEOFDAY |
| #ifdef HAVE_SYS_TIMEB_H |
| #ifdef HAVE_SYS_TIME_H |
| #ifdef HAVE_FTIME |
| |
| static int |
| my_gettimeofday(struct timeval *tvp, void *tzp) |
| { |
| struct timeb timebuffer; |
| |
| ftime(&timebuffer); |
| if (tvp) { |
| tvp->tv_sec = timebuffer.time; |
| tvp->tv_usec = timebuffer.millitm * 1000L; |
| } |
| return (0); |
| } |
| #define HAVE_GETTIMEOFDAY 1 |
| #define gettimeofday my_gettimeofday |
| |
| #endif |
| #endif |
| #endif |
| #endif |
| |
| #if defined(HAVE_GETTIMEOFDAY) |
| static struct timeval begin, end; |
| |
| |
| |
| |
| static void |
| startTimer(void) |
| { |
| gettimeofday(&begin, NULL); |
| } |
| |
| |
| |
| |
| |
| |
| static void XMLCDECL |
| endTimer(const char *fmt, ...) |
| { |
| long msec; |
| va_list ap; |
| |
| gettimeofday(&end, NULL); |
| msec = end.tv_sec - begin.tv_sec; |
| msec *= 1000; |
| msec += (end.tv_usec - begin.tv_usec) / 1000; |
| |
| #ifndef HAVE_STDARG_H |
| #error "endTimer required stdarg functions" |
| #endif |
| va_start(ap, fmt); |
| vfprintf(stderr, fmt, ap); |
| va_end(ap); |
| |
| fprintf(stderr, " took %ld ms\n", msec); |
| } |
| #elif defined(HAVE_TIME_H) |
| |
| |
| |
| |
| |
| #ifndef CLOCKS_PER_SEC |
| #define CLOCKS_PER_SEC 100 |
| #endif |
| |
| static clock_t begin, end; |
| static void |
| startTimer(void) |
| { |
| begin = clock(); |
| } |
| static void XMLCDECL |
| endTimer(const char *fmt, ...) |
| { |
| long msec; |
| va_list ap; |
| |
| end = clock(); |
| msec = ((end - begin) * 1000) / CLOCKS_PER_SEC; |
| |
| #ifndef HAVE_STDARG_H |
| #error "endTimer required stdarg functions" |
| #endif |
| va_start(ap, fmt); |
| vfprintf(stderr, fmt, ap); |
| va_end(ap); |
| fprintf(stderr, " took %ld ms\n", msec); |
| } |
| #else |
| |
| |
| |
| |
| static void |
| startTimer(void) |
| { |
| |
| |
| |
| } |
| static void XMLCDECL |
| endTimer(char *format, ...) |
| { |
| |
| |
| |
| #ifdef HAVE_STDARG_H |
| va_start(ap, format); |
| vfprintf(stderr, format, ap); |
| va_end(ap); |
| fprintf(stderr, " was not timed\n", msec); |
| #else |
| |
| |
| |
| #endif |
| } |
| #endif |
| |
| |
| |
| |
| static xmlSAXHandler emptySAXHandlerStruct = { |
| NULL, |
| NULL, |
| NULL, |
| NULL, |
| NULL, |
| NULL, |
| NULL, |
| NULL, |
| NULL, |
| NULL, |
| NULL, |
| NULL, |
| NULL, |
| NULL, |
| NULL, |
| NULL, |
| NULL, |
| NULL, |
| NULL, |
| NULL, |
| NULL, |
| NULL, |
| NULL, |
| NULL, |
| NULL, |
| NULL, |
| NULL, |
| 1, |
| NULL, |
| NULL, |
| NULL, |
| NULL |
| }; |
| |
| static xmlSAXHandlerPtr emptySAXHandler = &emptySAXHandlerStruct; |
| extern xmlSAXHandlerPtr debugSAXHandler; |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| static int |
| isStandaloneDebug(void *ctx ATTRIBUTE_UNUSED) |
| { |
| callbacks++; |
| if (quiet) |
| return(0); |
| fprintf(stdout, "SAX.isStandalone()\n"); |
| return(0); |
| } |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| static int |
| hasInternalSubsetDebug(void *ctx ATTRIBUTE_UNUSED) |
| { |
| callbacks++; |
| if (quiet) |
| return(0); |
| fprintf(stdout, "SAX.hasInternalSubset()\n"); |
| return(0); |
| } |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| static int |
| hasExternalSubsetDebug(void *ctx ATTRIBUTE_UNUSED) |
| { |
| callbacks++; |
| if (quiet) |
| return(0); |
| fprintf(stdout, "SAX.hasExternalSubset()\n"); |
| return(0); |
| } |
| |
| |
| |
| |
| |
| |
| |
| static void |
| internalSubsetDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *name, |
| const xmlChar *ExternalID, const xmlChar *SystemID) |
| { |
| callbacks++; |
| if (quiet) |
| return; |
| fprintf(stdout, "SAX.internalSubset(%s,", name); |
| if (ExternalID == NULL) |
| fprintf(stdout, " ,"); |
| else |
| fprintf(stdout, " %s,", ExternalID); |
| if (SystemID == NULL) |
| fprintf(stdout, " )\n"); |
| else |
| fprintf(stdout, " %s)\n", SystemID); |
| } |
| |
| |
| |
| |
| |
| |
| |
| static void |
| externalSubsetDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *name, |
| const xmlChar *ExternalID, const xmlChar *SystemID) |
| { |
| callbacks++; |
| if (quiet) |
| return; |
| fprintf(stdout, "SAX.externalSubset(%s,", name); |
| if (ExternalID == NULL) |
| fprintf(stdout, " ,"); |
| else |
| fprintf(stdout, " %s,", ExternalID); |
| if (SystemID == NULL) |
| fprintf(stdout, " )\n"); |
| else |
| fprintf(stdout, " %s)\n", SystemID); |
| } |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| static xmlParserInputPtr |
| resolveEntityDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *publicId, const xmlChar *systemId) |
| { |
| callbacks++; |
| if (quiet) |
| return(NULL); |
| |
| |
| |
| fprintf(stdout, "SAX.resolveEntity("); |
| if (publicId != NULL) |
| fprintf(stdout, "%s", (char *)publicId); |
| else |
| fprintf(stdout, " "); |
| if (systemId != NULL) |
| fprintf(stdout, ", %s)\n", (char *)systemId); |
| else |
| fprintf(stdout, ", )\n"); |
| |
| |
| |
| |
| |
| return(NULL); |
| } |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| static xmlEntityPtr |
| getEntityDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *name) |
| { |
| callbacks++; |
| if (quiet) |
| return(NULL); |
| fprintf(stdout, "SAX.getEntity(%s)\n", name); |
| return(NULL); |
| } |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| static xmlEntityPtr |
| getParameterEntityDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *name) |
| { |
| callbacks++; |
| if (quiet) |
| return(NULL); |
| fprintf(stdout, "SAX.getParameterEntity(%s)\n", name); |
| return(NULL); |
| } |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| static void |
| entityDeclDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *name, int type, |
| const xmlChar *publicId, const xmlChar *systemId, xmlChar *content) |
| { |
| const xmlChar *nullstr = BAD_CAST "(null)"; |
| |
| if (publicId == NULL) |
| publicId = nullstr; |
| if (systemId == NULL) |
| systemId = nullstr; |
| if (content == NULL) |
| content = (xmlChar *)nullstr; |
| callbacks++; |
| if (quiet) |
| return; |
| fprintf(stdout, "SAX.entityDecl(%s, %d, %s, %s, %s)\n", |
| name, type, publicId, systemId, content); |
| } |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| static void |
| attributeDeclDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar * elem, |
| const xmlChar * name, int type, int def, |
| const xmlChar * defaultValue, xmlEnumerationPtr tree) |
| { |
| callbacks++; |
| if (quiet) |
| return; |
| if (defaultValue == NULL) |
| fprintf(stdout, "SAX.attributeDecl(%s, %s, %d, %d, NULL, ...)\n", |
| elem, name, type, def); |
| else |
| fprintf(stdout, "SAX.attributeDecl(%s, %s, %d, %d, %s, ...)\n", |
| elem, name, type, def, defaultValue); |
| xmlFreeEnumeration(tree); |
| } |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| static void |
| elementDeclDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *name, int type, |
| xmlElementContentPtr content ATTRIBUTE_UNUSED) |
| { |
| callbacks++; |
| if (quiet) |
| return; |
| fprintf(stdout, "SAX.elementDecl(%s, %d, ...)\n", |
| name, type); |
| } |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| static void |
| notationDeclDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *name, |
| const xmlChar *publicId, const xmlChar *systemId) |
| { |
| callbacks++; |
| if (quiet) |
| return; |
| fprintf(stdout, "SAX.notationDecl(%s, %s, %s)\n", |
| (char *) name, (char *) publicId, (char *) systemId); |
| } |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| static void |
| unparsedEntityDeclDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *name, |
| const xmlChar *publicId, const xmlChar *systemId, |
| const xmlChar *notationName) |
| { |
| const xmlChar *nullstr = BAD_CAST "(null)"; |
| |
| if (publicId == NULL) |
| publicId = nullstr; |
| if (systemId == NULL) |
| systemId = nullstr; |
| if (notationName == NULL) |
| notationName = nullstr; |
| callbacks++; |
| if (quiet) |
| return; |
| fprintf(stdout, "SAX.unparsedEntityDecl(%s, %s, %s, %s)\n", |
| (char *) name, (char *) publicId, (char *) systemId, |
| (char *) notationName); |
| } |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| static void |
| setDocumentLocatorDebug(void *ctx ATTRIBUTE_UNUSED, xmlSAXLocatorPtr loc ATTRIBUTE_UNUSED) |
| { |
| callbacks++; |
| if (quiet) |
| return; |
| fprintf(stdout, "SAX.setDocumentLocator()\n"); |
| } |
| |
| |
| |
| |
| |
| |
| |
| static void |
| startDocumentDebug(void *ctx ATTRIBUTE_UNUSED) |
| { |
| callbacks++; |
| if (quiet) |
| return; |
| fprintf(stdout, "SAX.startDocument()\n"); |
| } |
| |
| |
| |
| |
| |
| |
| |
| static void |
| endDocumentDebug(void *ctx ATTRIBUTE_UNUSED) |
| { |
| callbacks++; |
| if (quiet) |
| return; |
| fprintf(stdout, "SAX.endDocument()\n"); |
| } |
| |
| |
| |
| |
| |
| |
| |
| |
| static void |
| startElementDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *name, const xmlChar **atts) |
| { |
| int i; |
| |
| callbacks++; |
| if (quiet) |
| return; |
| fprintf(stdout, "SAX.startElement(%s", (char *) name); |
| if (atts != NULL) { |
| for (i = 0;(atts[i] != NULL);i++) { |
| fprintf(stdout, ", %s='", atts[i++]); |
| if (atts[i] != NULL) |
| fprintf(stdout, "%s'", atts[i]); |
| } |
| } |
| fprintf(stdout, ")\n"); |
| } |
| |
| |
| |
| |
| |
| |
| |
| |
| static void |
| endElementDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *name) |
| { |
| callbacks++; |
| if (quiet) |
| return; |
| fprintf(stdout, "SAX.endElement(%s)\n", (char *) name); |
| } |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| static void |
| charactersDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *ch, int len) |
| { |
| char output[40]; |
| int i; |
| |
| callbacks++; |
| if (quiet) |
| return; |
| for (i = 0;(i<len) && (i < 30);i++) |
| output[i] = ch[i]; |
| output[i] = 0; |
| |
| fprintf(stdout, "SAX.characters(%s, %d)\n", output, len); |
| } |
| |
| |
| |
| |
| |
| |
| |
| |
| static void |
| referenceDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *name) |
| { |
| callbacks++; |
| if (quiet) |
| return; |
| fprintf(stdout, "SAX.reference(%s)\n", name); |
| } |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| static void |
| ignorableWhitespaceDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *ch, int len) |
| { |
| char output[40]; |
| int i; |
| |
| callbacks++; |
| if (quiet) |
| return; |
| for (i = 0;(i<len) && (i < 30);i++) |
| output[i] = ch[i]; |
| output[i] = 0; |
| fprintf(stdout, "SAX.ignorableWhitespace(%s, %d)\n", output, len); |
| } |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| static void |
| processingInstructionDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *target, |
| const xmlChar *data) |
| { |
| callbacks++; |
| if (quiet) |
| return; |
| if (data != NULL) |
| fprintf(stdout, "SAX.processingInstruction(%s, %s)\n", |
| (char *) target, (char *) data); |
| else |
| fprintf(stdout, "SAX.processingInstruction(%s, NULL)\n", |
| (char *) target); |
| } |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| static void |
| cdataBlockDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *value, int len) |
| { |
| callbacks++; |
| if (quiet) |
| return; |
| fprintf(stdout, "SAX.pcdata(%.20s, %d)\n", |
| (char *) value, len); |
| } |
| |
| |
| |
| |
| |
| |
| |
| |
| static void |
| commentDebug(void *ctx ATTRIBUTE_UNUSED, const xmlChar *value) |
| { |
| callbacks++; |
| if (quiet) |
| return; |
| fprintf(stdout, "SAX.comment(%s)\n", value); |
| } |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| static void XMLCDECL |
| warningDebug(void *ctx ATTRIBUTE_UNUSED, const char *msg, ...) |
| { |
| va_list args; |
| |
| callbacks++; |
| if (quiet) |
| return; |
| va_start(args, msg); |
| fprintf(stdout, "SAX.warning: "); |
| vfprintf(stdout, msg, args); |
| va_end(args); |
| } |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| static void XMLCDECL |
| errorDebug(void *ctx ATTRIBUTE_UNUSED, const char *msg, ...) |
| { |
| va_list args; |
| |
| callbacks++; |
| if (quiet) |
| return; |
| va_start(args, msg); |
| fprintf(stdout, "SAX.error: "); |
| vfprintf(stdout, msg, args); |
| va_end(args); |
| } |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| static void XMLCDECL |
| fatalErrorDebug(void *ctx ATTRIBUTE_UNUSED, const char *msg, ...) |
| { |
| va_list args; |
| |
| callbacks++; |
| if (quiet) |
| return; |
| va_start(args, msg); |
| fprintf(stdout, "SAX.fatalError: "); |
| vfprintf(stdout, msg, args); |
| va_end(args); |
| } |
| |
| static xmlSAXHandler debugSAXHandlerStruct = { |
| internalSubsetDebug, |
| isStandaloneDebug, |
| hasInternalSubsetDebug, |
| hasExternalSubsetDebug, |
| resolveEntityDebug, |
| getEntityDebug, |
| entityDeclDebug, |
| notationDeclDebug, |
| attributeDeclDebug, |
| elementDeclDebug, |
| unparsedEntityDeclDebug, |
| setDocumentLocatorDebug, |
| startDocumentDebug, |
| endDocumentDebug, |
| startElementDebug, |
| endElementDebug, |
| referenceDebug, |
| charactersDebug, |
| ignorableWhitespaceDebug, |
| processingInstructionDebug, |
| commentDebug, |
| warningDebug, |
| errorDebug, |
| fatalErrorDebug, |
| getParameterEntityDebug, |
| cdataBlockDebug, |
| externalSubsetDebug, |
| 1, |
| NULL, |
| NULL, |
| NULL, |
| NULL |
| }; |
| |
| xmlSAXHandlerPtr debugSAXHandler = &debugSAXHandlerStruct; |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| static void |
| startElementNsDebug(void *ctx ATTRIBUTE_UNUSED, |
| 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 i; |
| |
| callbacks++; |
| if (quiet) |
| return; |
| fprintf(stdout, "SAX.startElementNs(%s", (char *) localname); |
| if (prefix == NULL) |
| fprintf(stdout, ", NULL"); |
| else |
| fprintf(stdout, ", %s", (char *) prefix); |
| if (URI == NULL) |
| fprintf(stdout, ", NULL"); |
| else |
| fprintf(stdout, ", '%s'", (char *) URI); |
| fprintf(stdout, ", %d", nb_namespaces); |
| |
| if (namespaces != NULL) { |
| for (i = 0;i < nb_namespaces * 2;i++) { |
| fprintf(stdout, ", xmlns"); |
| if (namespaces[i] != NULL) |
| fprintf(stdout, ":%s", namespaces[i]); |
| i++; |
| fprintf(stdout, "='%s'", namespaces[i]); |
| } |
| } |
| fprintf(stdout, ", %d, %d", nb_attributes, nb_defaulted); |
| if (attributes != NULL) { |
| for (i = 0;i < nb_attributes * 5;i += 5) { |
| if (attributes[i + 1] != NULL) |
| fprintf(stdout, ", %s:%s='", attributes[i + 1], attributes[i]); |
| else |
| fprintf(stdout, ", %s='", attributes[i]); |
| fprintf(stdout, "%.4s...', %d", attributes[i + 3], |
| (int)(attributes[i + 4] - attributes[i + 3])); |
| } |
| } |
| fprintf(stdout, ")\n"); |
| } |
| |
| |
| |
| |
| |
| |
| |
| |
| static void |
| endElementNsDebug(void *ctx ATTRIBUTE_UNUSED, |
| const xmlChar *localname, |
| const xmlChar *prefix, |
| const xmlChar *URI) |
| { |
| callbacks++; |
| if (quiet) |
| return; |
| fprintf(stdout, "SAX.endElementNs(%s", (char *) localname); |
| if (prefix == NULL) |
| fprintf(stdout, ", NULL"); |
| else |
| fprintf(stdout, ", %s", (char *) prefix); |
| if (URI == NULL) |
| fprintf(stdout, ", NULL)\n"); |
| else |
| fprintf(stdout, ", '%s')\n", (char *) URI); |
| } |
| |
| static xmlSAXHandler debugSAX2HandlerStruct = { |
| internalSubsetDebug, |
| isStandaloneDebug, |
| hasInternalSubsetDebug, |
| hasExternalSubsetDebug, |
| resolveEntityDebug, |
| getEntityDebug, |
| entityDeclDebug, |
| notationDeclDebug, |
| attributeDeclDebug, |
| elementDeclDebug, |
| unparsedEntityDeclDebug, |
| setDocumentLocatorDebug, |
| startDocumentDebug, |
| endDocumentDebug, |
| NULL, |
| NULL, |
| referenceDebug, |
| charactersDebug, |
| ignorableWhitespaceDebug, |
| processingInstructionDebug, |
| commentDebug, |
| warningDebug, |
| errorDebug, |
| fatalErrorDebug, |
| getParameterEntityDebug, |
| cdataBlockDebug, |
| externalSubsetDebug, |
| XML_SAX2_MAGIC, |
| NULL, |
| startElementNsDebug, |
| endElementNsDebug, |
| NULL |
| }; |
| |
| static xmlSAXHandlerPtr debugSAX2Handler = &debugSAX2HandlerStruct; |
| |
| |
| |
| |
| |
| |
| |
| static void |
| parseAndPrintFile(char *filename) { |
| int res; |
| |
| #ifdef LIBXML_PUSH_ENABLED |
| if (push) { |
| FILE *f; |
| |
| if ((!quiet) && (!nonull)) { |
| |
| |
| |
| #if defined(_WIN32) || defined (__DJGPP__) && !defined (__CYGWIN__) |
| f = fopen(filename, "rb"); |
| #else |
| f = fopen(filename, "r"); |
| #endif |
| if (f != NULL) { |
| int ret; |
| char chars[10]; |
| xmlParserCtxtPtr ctxt; |
| |
| ret = fread(chars, 1, 4, f); |
| if (ret > 0) { |
| ctxt = xmlCreatePushParserCtxt(emptySAXHandler, NULL, |
| chars, ret, filename); |
| while ((ret = fread(chars, 1, 3, f)) > 0) { |
| xmlParseChunk(ctxt, chars, ret, 0); |
| } |
| xmlParseChunk(ctxt, chars, 0, 1); |
| xmlFreeParserCtxt(ctxt); |
| } |
| fclose(f); |
| } else { |
| xmlGenericError(xmlGenericErrorContext, |
| "Cannot read file %s\n", filename); |
| } |
| } |
| |
| |
| |
| #if defined(_WIN32) || defined (__DJGPP__) && !defined (__CYGWIN__) |
| f = fopen(filename, "rb"); |
| #else |
| f = fopen(filename, "r"); |
| #endif |
| if (f != NULL) { |
| int ret; |
| char chars[10]; |
| xmlParserCtxtPtr ctxt; |
| |
| ret = fread(chars, 1, 4, f); |
| if (ret > 0) { |
| if (sax2) |
| ctxt = xmlCreatePushParserCtxt(debugSAX2Handler, NULL, |
| chars, ret, filename); |
| else |
| ctxt = xmlCreatePushParserCtxt(debugSAXHandler, NULL, |
| chars, ret, filename); |
| while ((ret = fread(chars, 1, 3, f)) > 0) { |
| xmlParseChunk(ctxt, chars, ret, 0); |
| } |
| ret = xmlParseChunk(ctxt, chars, 0, 1); |
| xmlFreeParserCtxt(ctxt); |
| if (ret != 0) { |
| fprintf(stdout, |
| "xmlSAXUserParseFile returned error %d\n", ret); |
| } |
| } |
| fclose(f); |
| } |
| } else { |
| #endif |
| if (!speed) { |
| |
| |
| |
| if ((!quiet) && (!nonull)) { |
| res = xmlSAXUserParseFile(emptySAXHandler, NULL, filename); |
| if (res != 0) { |
| fprintf(stdout, "xmlSAXUserParseFile returned error %d\n", res); |
| } |
| } |
| |
| |
| |
| |
| callbacks = 0; |
| if (repeat) { |
| int i; |
| for (i = 0;i < 99;i++) { |
| if (sax2) |
| res = xmlSAXUserParseFile(debugSAX2Handler, NULL, |
| filename); |
| else |
| res = xmlSAXUserParseFile(debugSAXHandler, NULL, |
| filename); |
| } |
| } |
| if (sax2) |
| res = xmlSAXUserParseFile(debugSAX2Handler, NULL, filename); |
| else |
| res = xmlSAXUserParseFile(debugSAXHandler, NULL, filename); |
| if (res != 0) { |
| fprintf(stdout, "xmlSAXUserParseFile returned error %d\n", res); |
| } |
| if (quiet) |
| fprintf(stdout, "%d callbacks generated\n", callbacks); |
| } else { |
| |
| |
| |
| int i; |
| |
| for (i = 0; i<100;i++) |
| res = xmlSAXUserParseFile(emptySAXHandler, NULL, filename); |
| if (res != 0) { |
| fprintf(stdout, "xmlSAXUserParseFile returned error %d\n", res); |
| } |
| } |
| #ifdef LIBXML_PUSH_ENABLED |
| } |
| #endif |
| } |
| |
| |
| int main(int argc, char **argv) { |
| int i; |
| int files = 0; |
| |
| LIBXML_TEST_VERSION |
| |
| for (i = 1; i < argc ; i++) { |
| if ((!strcmp(argv[i], "-debug")) || (!strcmp(argv[i], "--debug"))) |
| debug++; |
| else if ((!strcmp(argv[i], "-copy")) || (!strcmp(argv[i], "--copy"))) |
| copy++; |
| else if ((!strcmp(argv[i], "-recover")) || |
| (!strcmp(argv[i], "--recover"))) |
| recovery++; |
| else if ((!strcmp(argv[i], "-push")) || |
| (!strcmp(argv[i], "--push"))) |
| #ifdef LIBXML_PUSH_ENABLED |
| push++; |
| #else |
| fprintf(stderr,"'push' not enabled in library - ignoring\n"); |
| #endif |
| else if ((!strcmp(argv[i], "-speed")) || |
| (!strcmp(argv[i], "--speed"))) |
| speed++; |
| else if ((!strcmp(argv[i], "-timing")) || |
| (!strcmp(argv[i], "--timing"))) { |
| nonull++; |
| timing++; |
| quiet++; |
| } else if ((!strcmp(argv[i], "-repeat")) || |
| (!strcmp(argv[i], "--repeat"))) { |
| repeat++; |
| quiet++; |
| } else if ((!strcmp(argv[i], "-noent")) || |
| (!strcmp(argv[i], "--noent"))) |
| noent++; |
| else if ((!strcmp(argv[i], "-quiet")) || |
| (!strcmp(argv[i], "--quiet"))) |
| quiet++; |
| else if ((!strcmp(argv[i], "-sax2")) || |
| (!strcmp(argv[i], "--sax2"))) |
| sax2++; |
| else if ((!strcmp(argv[i], "-nonull")) || |
| (!strcmp(argv[i], "--nonull"))) |
| nonull++; |
| } |
| if (noent != 0) xmlSubstituteEntitiesDefault(1); |
| for (i = 1; i < argc ; i++) { |
| if (argv[i][0] != '-') { |
| if (timing) { |
| startTimer(); |
| } |
| parseAndPrintFile(argv[i]); |
| if (timing) { |
| endTimer("Parsing"); |
| } |
| files ++; |
| } |
| } |
| xmlCleanupParser(); |
| xmlMemoryDump(); |
| |
| return(0); |
| } |
| #else |
| int main(int argc ATTRIBUTE_UNUSED, char **argv ATTRIBUTE_UNUSED) { |
| printf("%s : SAX1 parsing support not compiled in\n", argv[0]); |
| return(0); |
| } |
| #endif |