Blame doc/examples/tree2.c

Packit Service a31ea6
/* 
Packit Service a31ea6
 * section:  Tree
Packit Service a31ea6
 * synopsis: Creates a tree
Packit Service a31ea6
 * purpose:  Shows how to create document, nodes and dump it to stdout or file.
Packit Service a31ea6
 * usage:    tree2 <filename>  -Default output: stdout
Packit Service a31ea6
 * test:     tree2 > tree2.tmp && diff tree2.tmp $(srcdir)/tree2.res
Packit Service a31ea6
 * author:   Lucas Brasilino <brasilino@recife.pe.gov.br>
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/parser.h>
Packit Service a31ea6
#include <libxml/tree.h>
Packit Service a31ea6
Packit Service a31ea6
#if defined(LIBXML_TREE_ENABLED) && defined(LIBXML_OUTPUT_ENABLED)
Packit Service a31ea6
Packit Service a31ea6
/*
Packit Service a31ea6
 *To compile this file using gcc you can type
Packit Service a31ea6
 *gcc `xml2-config --cflags --libs` -o tree2 tree2.c
Packit Service a31ea6
 */
Packit Service a31ea6
Packit Service a31ea6
/* A simple example how to create DOM. Libxml2 automagically 
Packit Service a31ea6
 * allocates the necessary amount of memory to it.
Packit Service a31ea6
*/
Packit Service a31ea6
int
Packit Service a31ea6
main(int argc, char **argv)
Packit Service a31ea6
{
Packit Service a31ea6
    xmlDocPtr doc = NULL;       /* document pointer */
Packit Service a31ea6
    xmlNodePtr root_node = NULL, node = NULL, node1 = NULL;/* node pointers */
Packit Service a31ea6
    char buff[256];
Packit Service a31ea6
    int i, j;
Packit Service a31ea6
Packit Service a31ea6
    LIBXML_TEST_VERSION;
Packit Service a31ea6
Packit Service a31ea6
    /* 
Packit Service a31ea6
     * Creates a new document, a node and set it as a root node
Packit Service a31ea6
     */
Packit Service a31ea6
    doc = xmlNewDoc(BAD_CAST "1.0");
Packit Service a31ea6
    root_node = xmlNewNode(NULL, BAD_CAST "root");
Packit Service a31ea6
    xmlDocSetRootElement(doc, root_node);
Packit Service a31ea6
Packit Service a31ea6
    /*
Packit Service a31ea6
     * Creates a DTD declaration. Isn't mandatory. 
Packit Service a31ea6
     */
Packit Service a31ea6
    xmlCreateIntSubset(doc, BAD_CAST "root", NULL, BAD_CAST "tree2.dtd");
Packit Service a31ea6
Packit Service a31ea6
    /* 
Packit Service a31ea6
     * xmlNewChild() creates a new node, which is "attached" as child node
Packit Service a31ea6
     * of root_node node. 
Packit Service a31ea6
     */
Packit Service a31ea6
    xmlNewChild(root_node, NULL, BAD_CAST "node1",
Packit Service a31ea6
                BAD_CAST "content of node 1");
Packit Service a31ea6
    /* 
Packit Service a31ea6
     * The same as above, but the new child node doesn't have a content 
Packit Service a31ea6
     */
Packit Service a31ea6
    xmlNewChild(root_node, NULL, BAD_CAST "node2", NULL);
Packit Service a31ea6
Packit Service a31ea6
    /* 
Packit Service a31ea6
     * xmlNewProp() creates attributes, which is "attached" to an node.
Packit Service a31ea6
     * It returns xmlAttrPtr, which isn't used here.
Packit Service a31ea6
     */
Packit Service a31ea6
    node =
Packit Service a31ea6
        xmlNewChild(root_node, NULL, BAD_CAST "node3",
Packit Service a31ea6
                    BAD_CAST "this node has attributes");
Packit Service a31ea6
    xmlNewProp(node, BAD_CAST "attribute", BAD_CAST "yes");
Packit Service a31ea6
    xmlNewProp(node, BAD_CAST "foo", BAD_CAST "bar");
Packit Service a31ea6
Packit Service a31ea6
    /*
Packit Service a31ea6
     * Here goes another way to create nodes. xmlNewNode() and xmlNewText
Packit Service a31ea6
     * creates a node and a text node separately. They are "attached"
Packit Service a31ea6
     * by xmlAddChild() 
Packit Service a31ea6
     */
Packit Service a31ea6
    node = xmlNewNode(NULL, BAD_CAST "node4");
Packit Service a31ea6
    node1 = xmlNewText(BAD_CAST
Packit Service a31ea6
                   "other way to create content (which is also a node)");
Packit Service a31ea6
    xmlAddChild(node, node1);
Packit Service a31ea6
    xmlAddChild(root_node, node);
Packit Service a31ea6
Packit Service a31ea6
    /* 
Packit Service a31ea6
     * A simple loop that "automates" nodes creation 
Packit Service a31ea6
     */
Packit Service a31ea6
    for (i = 5; i < 7; i++) {
Packit Service a31ea6
        sprintf(buff, "node%d", i);
Packit Service a31ea6
        node = xmlNewChild(root_node, NULL, BAD_CAST buff, NULL);
Packit Service a31ea6
        for (j = 1; j < 4; j++) {
Packit Service a31ea6
            sprintf(buff, "node%d%d", i, j);
Packit Service a31ea6
            node1 = xmlNewChild(node, NULL, BAD_CAST buff, NULL);
Packit Service a31ea6
            xmlNewProp(node1, BAD_CAST "odd", BAD_CAST((j % 2) ? "no" : "yes"));
Packit Service a31ea6
        }
Packit Service a31ea6
    }
Packit Service a31ea6
Packit Service a31ea6
    /* 
Packit Service a31ea6
     * Dumping document to stdio or file
Packit Service a31ea6
     */
Packit Service a31ea6
    xmlSaveFormatFileEnc(argc > 1 ? argv[1] : "-", doc, "UTF-8", 1);
Packit Service a31ea6
Packit Service a31ea6
    /*free the document */
Packit Service a31ea6
    xmlFreeDoc(doc);
Packit Service a31ea6
Packit Service a31ea6
    /*
Packit Service a31ea6
     *Free the global variables that may
Packit Service a31ea6
     *have been allocated by the parser.
Packit Service a31ea6
     */
Packit Service a31ea6
    xmlCleanupParser();
Packit Service a31ea6
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
#else
Packit Service a31ea6
int main(void) {
Packit Service a31ea6
    fprintf(stderr, "tree support not compiled in\n");
Packit Service a31ea6
    exit(1);
Packit Service a31ea6
}
Packit Service a31ea6
#endif