diff options
Diffstat (limited to 'xmlparser-test/main.cpp')
-rw-r--r-- | xmlparser-test/main.cpp | 210 |
1 files changed, 210 insertions, 0 deletions
diff --git a/xmlparser-test/main.cpp b/xmlparser-test/main.cpp new file mode 100644 index 0000000..a399b9c --- /dev/null +++ b/xmlparser-test/main.cpp @@ -0,0 +1,210 @@ +/* <auto_header> + * <FILENAME> + * + * INTEL CONFIDENTIAL + * Copyright © 2011 Intel + * Corporation All Rights Reserved. + * + * The source code contained or described herein and all documents related to + * the source code ("Material") are owned by Intel Corporation or its suppliers + * or licensors. Title to the Material remains with Intel Corporation or its + * suppliers and licensors. The Material contains trade secrets and proprietary + * and confidential information of Intel or its suppliers and licensors. The + * Material is protected by worldwide copyright and trade secret laws and + * treaty provisions. No part of the Material may be used, copied, reproduced, + * modified, published, uploaded, posted, transmitted, distributed, or + * disclosed in any way without Intel’s prior express written permission. + * + * No license under any patent, copyright, trade secret or other intellectual + * property right is granted to or conferred upon you by disclosure or delivery + * of the Materials, either expressly, by implication, inducement, estoppel or + * otherwise. Any license under such intellectual property rights must be + * express and approved by Intel in writing. + * + * AUTHOR: Patrick Benavoli (patrickx.benavoli@intel.com) + * CREATED: 2011-06-01 + * UPDATED: 2011-07-27 + * + * + * </auto_header> + */ +/** + * section: Tree + * synopsis: Navigates a tree to print element names + * purpose: Parse a file to a tree, use xmlDocGetRootElement() to + * get the root element, then walk the document and print + * all the element name in document order. + * usage: tree1 filename_or_URL + * test: tree1 test2.xml > tree1.tmp ; diff tree1.tmp tree1.res ; rm tree1.tmp + * author: Dodji Seketeli + * copy: see Copyright for the status of this software. + */ +#include <stdio.h> +#include <stdarg.h> +#include <libxml/parser.h> +#include <libxml/tree.h> +#include <libxml/xmlschemas.h> + +/* + *To compile this file using gcc you can type + *gcc `xml2-config --cflags --libs` -o xmlexample libxml2-example.c + */ +static void schemaValidityErrorFunc(void *ctx, const char *msg, ...) +{ + char acBuffer[256]; + va_list listPointer; + + (void)ctx; + + va_start( listPointer, msg ); + //vprintf(msg, listPointer); + + vsnprintf(acBuffer, sizeof(acBuffer), msg, listPointer); + + va_end( listPointer ); + + puts(acBuffer); +} + +static void schemaValidityWarningFunc(void *ctx, const char *msg, ...) +{ + char acBuffer[256]; + va_list listPointer; + + (void)ctx; + + va_start( listPointer, msg ); + + vsnprintf(acBuffer, sizeof(acBuffer), msg, listPointer); + + va_end( listPointer ); + + puts(acBuffer); +} + +static int is_valid(const xmlDocPtr doc, const char *schema_filename) +{ +#ifdef LIBXML_SCHEMAS_ENABLED + xmlDocPtr schema_doc = xmlReadFile(schema_filename, NULL, XML_PARSE_NONET); + if (schema_doc == NULL) { + /* the schema cannot be loaded or is not well-formed */ + return -1; + } + xmlSchemaParserCtxtPtr parser_ctxt = xmlSchemaNewDocParserCtxt(schema_doc); + if (parser_ctxt == NULL) { + /* unable to create a parser context for the schema */ + xmlFreeDoc(schema_doc); + return -2; + } + + xmlSchemaPtr schema = xmlSchemaParse(parser_ctxt); + if (schema == NULL) { + /* the schema itself is not valid */ + xmlSchemaFreeParserCtxt(parser_ctxt); + xmlFreeDoc(schema_doc); + return -3; + } + xmlSchemaValidCtxtPtr valid_ctxt = xmlSchemaNewValidCtxt(schema); + if (valid_ctxt == NULL) { + /* unable to create a validation context for the schema */ + xmlSchemaFree(schema); + xmlSchemaFreeParserCtxt(parser_ctxt); + xmlFreeDoc(schema_doc); + return -4; + } + xmlSchemaSetValidErrors(valid_ctxt, schemaValidityErrorFunc, schemaValidityWarningFunc, NULL); + + int is_valid = (xmlSchemaValidateDoc(valid_ctxt, doc) == 0); + xmlSchemaFreeValidCtxt(valid_ctxt); + xmlSchemaFree(schema); + xmlSchemaFreeParserCtxt(parser_ctxt); + xmlFreeDoc(schema_doc); + + /* force the return value to be non-negative on success */ + return is_valid ? 1 : 0; +#else + return 1; +#endif +} + +/** + * print_element_names: + * @a_node: the initial xml node to consider. + * + * Prints the names of the all the xml elements + * that are siblings or children of a given xml node. + */ +static void +print_element_names(xmlNode * a_node, int iLevel = 0) +{ + xmlNode *cur_node = NULL; + + for (cur_node = a_node; cur_node; cur_node = cur_node->next) { + + int iIndent = iLevel; + + while (iIndent--) { + printf(" "); + } + + if (cur_node->type == XML_ELEMENT_NODE) { + + printf("node type: Element, name: %s\n", cur_node->name); + } + print_element_names(cur_node->children, iLevel + 1); + } +} + + +/** + * Simple example to parse a file called "file.xml", + * walk down the DOM, and print the name of the + * xml elements nodes. + */ +int +main(int argc, char **argv) +{ + xmlDoc *doc = NULL; + xmlNode *root_element = NULL; + + if (argc != 3) + return(1); + + /* + * this initialize the library and check potential ABI mismatches + * between the version it was compiled for and the actual shared + * library used. + */ + LIBXML_TEST_VERSION + + /*parse the file and get the DOM */ + doc = xmlReadFile(argv[1], NULL, 0); + + if (doc == NULL) { + printf("error: could not parse file %s\n", argv[1]); + } + // Validate + if (!is_valid(doc, argv[2])) { + printf("error: doc is not valid\n"); + + return -1; + } + + + /*Get the root element node */ + root_element = xmlDocGetRootElement(doc); + + + print_element_names(root_element); + + /*free the document */ + xmlFreeDoc(doc); + + /* + *Free the global variables that may + *have been allocated by the parser. + */ + xmlCleanupParser(); + + return 0; +} |