Blame doc/examples/reader4.c

Packit Service a31ea6
/**
Packit Service a31ea6
 * section: xmlReader
Packit Service a31ea6
 * synopsis: Parse multiple XML files reusing an xmlReader
Packit Service a31ea6
 * purpose: Demonstrate the use of xmlReaderForFile() and
Packit Service a31ea6
 * xmlReaderNewFile to parse XML files while reusing the reader object
Packit Service a31ea6
 * and parser context.  (Note that the XMLReader functions require
Packit Service a31ea6
 * libxml2 version later than 2.6.)
Packit Service a31ea6
 * usage: reader4 <filename> [ filename ... ]
Packit Service a31ea6
 * test: reader4 test1.xml test2.xml test3.xml > reader4.tmp && diff reader4.tmp $(srcdir)/reader4.res
Packit Service a31ea6
 * author: Graham Bennett
Packit Service a31ea6
 * copy: see Copyright for the status of this software.
Packit Service a31ea6
 */
Packit Service a31ea6
Packit Service a31ea6
#include <stdio.h>
Packit Service a31ea6
#include <libxml/xmlreader.h>
Packit Service a31ea6
Packit Service a31ea6
#ifdef LIBXML_READER_ENABLED
Packit Service a31ea6
Packit Service a31ea6
static void processDoc(xmlTextReaderPtr readerPtr) {
Packit Service a31ea6
    int ret;
Packit Service a31ea6
    xmlDocPtr docPtr;
Packit Service a31ea6
    const xmlChar *URL;
Packit Service a31ea6
Packit Service a31ea6
    ret = xmlTextReaderRead(readerPtr);
Packit Service a31ea6
    while (ret == 1) {
Packit Service a31ea6
      ret = xmlTextReaderRead(readerPtr);
Packit Service a31ea6
    }
Packit Service a31ea6
Packit Service a31ea6
    /*
Packit Service a31ea6
     * One can obtain the document pointer to get insteresting
Packit Service a31ea6
     * information about the document like the URL, but one must also
Packit Service a31ea6
     * be sure to clean it up at the end (see below).
Packit Service a31ea6
     */
Packit Service a31ea6
    docPtr = xmlTextReaderCurrentDoc(readerPtr);
Packit Service a31ea6
    if (NULL == docPtr) {
Packit Service a31ea6
      fprintf(stderr, "failed to obtain document\n");      
Packit Service a31ea6
      return;
Packit Service a31ea6
    }
Packit Service a31ea6
      
Packit Service a31ea6
    URL = docPtr->URL;
Packit Service a31ea6
    if (NULL == URL) {
Packit Service a31ea6
      fprintf(stderr, "Failed to obtain URL\n");      
Packit Service a31ea6
    }
Packit Service a31ea6
Packit Service a31ea6
    if (ret != 0) {
Packit Service a31ea6
      fprintf(stderr, "%s: Failed to parse\n", URL);
Packit Service a31ea6
      return;
Packit Service a31ea6
    }
Packit Service a31ea6
Packit Service a31ea6
    printf("%s: Processed ok\n", (const char *)URL);
Packit Service a31ea6
}
Packit Service a31ea6
Packit Service a31ea6
int main(int argc, char **argv) {
Packit Service a31ea6
    xmlTextReaderPtr readerPtr;
Packit Service a31ea6
    int i;
Packit Service a31ea6
    xmlDocPtr docPtr;
Packit Service a31ea6
Packit Service a31ea6
    if (argc < 2)
Packit Service a31ea6
        return(1);
Packit Service a31ea6
Packit Service a31ea6
    /*
Packit Service a31ea6
     * this initialises the library and check potential ABI mismatches
Packit Service a31ea6
     * between the version it was compiled for and the actual shared
Packit Service a31ea6
     * library used.
Packit Service a31ea6
     */
Packit Service a31ea6
    LIBXML_TEST_VERSION
Packit Service a31ea6
Packit Service a31ea6
    /*
Packit Service a31ea6
     * Create a new reader for the first file and process the
Packit Service a31ea6
     * document.
Packit Service a31ea6
     */
Packit Service a31ea6
    readerPtr = xmlReaderForFile(argv[1], NULL, 0);
Packit Service a31ea6
    if (NULL == readerPtr) {
Packit Service a31ea6
      fprintf(stderr, "%s: failed to create reader\n", argv[1]);      
Packit Service a31ea6
      return(1);
Packit Service a31ea6
    }
Packit Service a31ea6
    processDoc(readerPtr);
Packit Service a31ea6
Packit Service a31ea6
    /*
Packit Service a31ea6
     * The reader can be reused for subsequent files.
Packit Service a31ea6
     */
Packit Service a31ea6
    for (i=2; i < argc; ++i) {
Packit Service a31ea6
      	xmlReaderNewFile(readerPtr, argv[i], NULL, 0);
Packit Service a31ea6
	if (NULL == readerPtr) {
Packit Service a31ea6
	  fprintf(stderr, "%s: failed to create reader\n", argv[i]);      
Packit Service a31ea6
	  return(1);
Packit Service a31ea6
	}
Packit Service a31ea6
        processDoc(readerPtr);
Packit Service a31ea6
    }
Packit Service a31ea6
Packit Service a31ea6
    /*
Packit Service a31ea6
     * Since we've called xmlTextReaderCurrentDoc, we now have to
Packit Service a31ea6
     * clean up after ourselves.  We only have to do this the last
Packit Service a31ea6
     * time, because xmlReaderNewFile calls xmlCtxtReset which takes
Packit Service a31ea6
     * care of it.
Packit Service a31ea6
     */
Packit Service a31ea6
    docPtr = xmlTextReaderCurrentDoc(readerPtr);
Packit Service a31ea6
    if (docPtr != NULL)
Packit Service a31ea6
      xmlFreeDoc(docPtr);
Packit Service a31ea6
Packit Service a31ea6
    /*
Packit Service a31ea6
     * Clean up the reader.
Packit Service a31ea6
     */
Packit Service a31ea6
    xmlFreeTextReader(readerPtr);
Packit Service a31ea6
Packit Service a31ea6
    /*
Packit Service a31ea6
     * Cleanup function for the XML library.
Packit Service a31ea6
     */
Packit Service a31ea6
    xmlCleanupParser();
Packit Service a31ea6
    /*
Packit Service a31ea6
     * this is to debug memory for regression tests
Packit Service a31ea6
     */
Packit Service a31ea6
    xmlMemoryDump();
Packit Service a31ea6
    return(0);
Packit Service a31ea6
}
Packit Service a31ea6
Packit Service a31ea6
#else
Packit Service a31ea6
int main(void) {
Packit Service a31ea6
    fprintf(stderr, "xmlReader support not compiled in\n");
Packit Service a31ea6
    exit(1);
Packit Service a31ea6
}
Packit Service a31ea6
#endif