X7ROOT File Manager
Current Path:
/usr/share/doc/libxml2-devel-2.9.1/examples
usr
/
share
/
doc
/
libxml2-devel-2.9.1
/
examples
/
📁
..
📄
Makefile.am
(3.97 KB)
📄
Makefile.in
(30.58 KB)
📄
examples.xml
(31.41 KB)
📄
examples.xsl
(7.06 KB)
📄
index.html
(32.15 KB)
📄
index.py
(8.95 KB)
📄
io1.c
(3.67 KB)
📄
io1.res
(206 B)
📄
io2.c
(1.15 KB)
📄
io2.res
(43 B)
📄
parse1.c
(1.27 KB)
📄
parse2.c
(1.92 KB)
📄
parse3.c
(1.47 KB)
📄
parse4.c
(3.46 KB)
📄
reader1.c
(2.47 KB)
📄
reader1.res
(149 B)
📄
reader2.c
(3.06 KB)
📄
reader3.c
(2.88 KB)
📄
reader3.res
(360 B)
📄
reader4.c
(3.05 KB)
📄
reader4.res
(72 B)
📄
test1.xml
(7 B)
📄
test2.xml
(227 B)
📄
test3.xml
(833 B)
📄
testWriter.c
(37.51 KB)
📄
tree1.c
(2.19 KB)
📄
tree1.res
(121 B)
📄
tree2.c
(3.39 KB)
📄
tree2.res
(453 B)
📄
tst.xml
(91 B)
📄
writer.xml
(544 B)
📄
xpath1.c
(6.47 KB)
📄
xpath1.res
(114 B)
📄
xpath2.c
(5.21 KB)
📄
xpath2.res
(757 B)
Editing: reader4.c
/** * section: xmlReader * synopsis: Parse multiple XML files reusing an xmlReader * purpose: Demonstrate the use of xmlReaderForFile() and * xmlReaderNewFile to parse XML files while reusing the reader object * and parser context. (Note that the XMLReader functions require * libxml2 version later than 2.6.) * usage: reader4 <filename> [ filename ... ] * test: reader4 test1.xml test2.xml test3.xml > reader4.tmp && diff reader4.tmp $(srcdir)/reader4.res * author: Graham Bennett * copy: see Copyright for the status of this software. */ #include <stdio.h> #include <libxml/xmlreader.h> #ifdef LIBXML_READER_ENABLED static void processDoc(xmlTextReaderPtr readerPtr) { int ret; xmlDocPtr docPtr; const xmlChar *URL; ret = xmlTextReaderRead(readerPtr); while (ret == 1) { ret = xmlTextReaderRead(readerPtr); } /* * One can obtain the document pointer to get insteresting * information about the document like the URL, but one must also * be sure to clean it up at the end (see below). */ docPtr = xmlTextReaderCurrentDoc(readerPtr); if (NULL == docPtr) { fprintf(stderr, "failed to obtain document\n"); return; } URL = docPtr->URL; if (NULL == URL) { fprintf(stderr, "Failed to obtain URL\n"); } if (ret != 0) { fprintf(stderr, "%s: Failed to parse\n", URL); return; } printf("%s: Processed ok\n", (const char *)URL); } int main(int argc, char **argv) { xmlTextReaderPtr readerPtr; int i; xmlDocPtr docPtr; if (argc < 2) return(1); /* * this initialises the library and check potential ABI mismatches * between the version it was compiled for and the actual shared * library used. */ LIBXML_TEST_VERSION /* * Create a new reader for the first file and process the * document. */ readerPtr = xmlReaderForFile(argv[1], NULL, 0); if (NULL == readerPtr) { fprintf(stderr, "%s: failed to create reader\n", argv[1]); return(1); } processDoc(readerPtr); /* * The reader can be reused for subsequent files. */ for (i=2; i < argc; ++i) { xmlReaderNewFile(readerPtr, argv[i], NULL, 0); if (NULL == readerPtr) { fprintf(stderr, "%s: failed to create reader\n", argv[i]); return(1); } processDoc(readerPtr); } /* * Since we've called xmlTextReaderCurrentDoc, we now have to * clean up after ourselves. We only have to do this the last * time, because xmlReaderNewFile calls xmlCtxtReset which takes * care of it. */ docPtr = xmlTextReaderCurrentDoc(readerPtr); if (docPtr != NULL) xmlFreeDoc(docPtr); /* * Clean up the reader. */ xmlFreeTextReader(readerPtr); /* * Cleanup function for the XML library. */ xmlCleanupParser(); /* * this is to debug memory for regression tests */ xmlMemoryDump(); return(0); } #else int main(void) { fprintf(stderr, "xmlReader support not compiled in\n"); exit(1); } #endif
Upload File
Create Folder