| Viewing file:  tree.h (37.21 KB)      -rw-r--r-- Select action/file-type:
 
  (+) |  (+) |  (+) | Code (+) | Session (+) |  (+) | SDB (+) |  (+) |  (+) |  (+) |  (+) |  (+) | 
 
/** Summary: interfaces for tree manipulation
 * Description: this module describes the structures found in an tree resulting
 *              from an XML or HTML parsing, as well as the API provided for
 *              various processing on that tree
 *
 * Copy: See Copyright for the status of this software.
 *
 * Author: Daniel Veillard
 */
 
 #ifndef __XML_TREE_H__
 #define __XML_TREE_H__
 
 #include <stdio.h>
 #include <limits.h>
 #include <libxml/xmlversion.h>
 #include <libxml/xmlstring.h>
 
 #ifdef __cplusplus
 extern "C" {
 #endif
 
 /*
 * Some of the basic types pointer to structures:
 */
 /* xmlIO.h */
 typedef struct _xmlParserInputBuffer xmlParserInputBuffer;
 typedef xmlParserInputBuffer *xmlParserInputBufferPtr;
 
 typedef struct _xmlOutputBuffer xmlOutputBuffer;
 typedef xmlOutputBuffer *xmlOutputBufferPtr;
 
 /* parser.h */
 typedef struct _xmlParserInput xmlParserInput;
 typedef xmlParserInput *xmlParserInputPtr;
 
 typedef struct _xmlParserCtxt xmlParserCtxt;
 typedef xmlParserCtxt *xmlParserCtxtPtr;
 
 typedef struct _xmlSAXLocator xmlSAXLocator;
 typedef xmlSAXLocator *xmlSAXLocatorPtr;
 
 typedef struct _xmlSAXHandler xmlSAXHandler;
 typedef xmlSAXHandler *xmlSAXHandlerPtr;
 
 /* entities.h */
 typedef struct _xmlEntity xmlEntity;
 typedef xmlEntity *xmlEntityPtr;
 
 /**
 * BASE_BUFFER_SIZE:
 *
 * default buffer size 4000.
 */
 #define BASE_BUFFER_SIZE 4096
 
 /**
 * LIBXML_NAMESPACE_DICT:
 *
 * Defines experimental behaviour:
 * 1) xmlNs gets an additional field @context (a xmlDoc)
 * 2) when creating a tree, xmlNs->href is stored in the dict of xmlDoc.
 */
 /* #define LIBXML_NAMESPACE_DICT */
 
 /**
 * xmlBufferAllocationScheme:
 *
 * A buffer allocation scheme can be defined to either match exactly the
 * need or double it's allocated size each time it is found too small.
 */
 
 typedef enum {
 XML_BUFFER_ALLOC_DOUBLEIT,    /* double each time one need to grow */
 XML_BUFFER_ALLOC_EXACT,    /* grow only to the minimal size */
 XML_BUFFER_ALLOC_IMMUTABLE, /* immutable buffer */
 XML_BUFFER_ALLOC_IO,    /* special allocation scheme used for I/O */
 XML_BUFFER_ALLOC_HYBRID,    /* exact up to a threshold, and doubleit thereafter */
 XML_BUFFER_ALLOC_BOUNDED    /* limit the upper size of the buffer */
 } xmlBufferAllocationScheme;
 
 /**
 * xmlBuffer:
 *
 * A buffer structure, this old construct is limited to 2GB and
 * is being deprecated, use API with xmlBuf instead
 */
 typedef struct _xmlBuffer xmlBuffer;
 typedef xmlBuffer *xmlBufferPtr;
 struct _xmlBuffer {
 xmlChar *content;        /* The buffer content UTF8 */
 unsigned int use;        /* The buffer size used */
 unsigned int size;        /* The buffer size */
 xmlBufferAllocationScheme alloc; /* The realloc method */
 xmlChar *contentIO;        /* in IO mode we may have a different base */
 };
 
 /**
 * xmlBuf:
 *
 * A buffer structure, new one, the actual structure internals are not public
 */
 
 typedef struct _xmlBuf xmlBuf;
 
 /**
 * xmlBufPtr:
 *
 * A pointer to a buffer structure, the actual structure internals are not
 * public
 */
 
 typedef xmlBuf *xmlBufPtr;
 
 /*
 * A few public routines for xmlBuf. As those are expected to be used
 * mostly internally the bulk of the routines are internal in buf.h
 */
 XMLPUBFUN xmlChar* XMLCALL       xmlBufContent    (const xmlBuf* buf);
 XMLPUBFUN xmlChar* XMLCALL       xmlBufEnd      (xmlBufPtr buf);
 XMLPUBFUN size_t XMLCALL         xmlBufUse      (const xmlBufPtr buf);
 XMLPUBFUN size_t XMLCALL         xmlBufShrink    (xmlBufPtr buf, size_t len);
 
 /*
 * LIBXML2_NEW_BUFFER:
 *
 * Macro used to express that the API use the new buffers for
 * xmlParserInputBuffer and xmlOutputBuffer. The change was
 * introduced in 2.9.0.
 */
 #define LIBXML2_NEW_BUFFER
 
 /**
 * XML_XML_NAMESPACE:
 *
 * This is the namespace for the special xml: prefix predefined in the
 * XML Namespace specification.
 */
 #define XML_XML_NAMESPACE \
 (const xmlChar *) "http://www.w3.org/XML/1998/namespace"
 
 /**
 * XML_XML_ID:
 *
 * This is the name for the special xml:id attribute
 */
 #define XML_XML_ID (const xmlChar *) "xml:id"
 
 /*
 * The different element types carried by an XML tree.
 *
 * NOTE: This is synchronized with DOM Level1 values
 *       See http://www.w3.org/TR/REC-DOM-Level-1/
 *
 * Actually this had diverged a bit, and now XML_DOCUMENT_TYPE_NODE should
 * be deprecated to use an XML_DTD_NODE.
 */
 typedef enum {
 XML_ELEMENT_NODE=        1,
 XML_ATTRIBUTE_NODE=        2,
 XML_TEXT_NODE=        3,
 XML_CDATA_SECTION_NODE=    4,
 XML_ENTITY_REF_NODE=    5,
 XML_ENTITY_NODE=        6,
 XML_PI_NODE=        7,
 XML_COMMENT_NODE=        8,
 XML_DOCUMENT_NODE=        9,
 XML_DOCUMENT_TYPE_NODE=    10,
 XML_DOCUMENT_FRAG_NODE=    11,
 XML_NOTATION_NODE=        12,
 XML_HTML_DOCUMENT_NODE=    13,
 XML_DTD_NODE=        14,
 XML_ELEMENT_DECL=        15,
 XML_ATTRIBUTE_DECL=        16,
 XML_ENTITY_DECL=        17,
 XML_NAMESPACE_DECL=        18,
 XML_XINCLUDE_START=        19,
 XML_XINCLUDE_END=        20
 #ifdef LIBXML_DOCB_ENABLED
 ,XML_DOCB_DOCUMENT_NODE=    21
 #endif
 } xmlElementType;
 
 
 /**
 * xmlNotation:
 *
 * A DTD Notation definition.
 */
 
 typedef struct _xmlNotation xmlNotation;
 typedef xmlNotation *xmlNotationPtr;
 struct _xmlNotation {
 const xmlChar               *name;            /* Notation name */
 const xmlChar               *PublicID;    /* Public identifier, if any */
 const xmlChar               *SystemID;    /* System identifier, if any */
 };
 
 /**
 * xmlAttributeType:
 *
 * A DTD Attribute type definition.
 */
 
 typedef enum {
 XML_ATTRIBUTE_CDATA = 1,
 XML_ATTRIBUTE_ID,
 XML_ATTRIBUTE_IDREF    ,
 XML_ATTRIBUTE_IDREFS,
 XML_ATTRIBUTE_ENTITY,
 XML_ATTRIBUTE_ENTITIES,
 XML_ATTRIBUTE_NMTOKEN,
 XML_ATTRIBUTE_NMTOKENS,
 XML_ATTRIBUTE_ENUMERATION,
 XML_ATTRIBUTE_NOTATION
 } xmlAttributeType;
 
 /**
 * xmlAttributeDefault:
 *
 * A DTD Attribute default definition.
 */
 
 typedef enum {
 XML_ATTRIBUTE_NONE = 1,
 XML_ATTRIBUTE_REQUIRED,
 XML_ATTRIBUTE_IMPLIED,
 XML_ATTRIBUTE_FIXED
 } xmlAttributeDefault;
 
 /**
 * xmlEnumeration:
 *
 * List structure used when there is an enumeration in DTDs.
 */
 
 typedef struct _xmlEnumeration xmlEnumeration;
 typedef xmlEnumeration *xmlEnumerationPtr;
 struct _xmlEnumeration {
 struct _xmlEnumeration    *next;    /* next one */
 const xmlChar            *name;    /* Enumeration name */
 };
 
 /**
 * xmlAttribute:
 *
 * An Attribute declaration in a DTD.
 */
 
 typedef struct _xmlAttribute xmlAttribute;
 typedef xmlAttribute *xmlAttributePtr;
 struct _xmlAttribute {
 void           *_private;            /* application data */
 xmlElementType          type;       /* XML_ATTRIBUTE_DECL, must be second ! */
 const xmlChar          *name;    /* Attribute name */
 struct _xmlNode    *children;    /* NULL */
 struct _xmlNode        *last;    /* NULL */
 struct _xmlDtd       *parent;    /* -> DTD */
 struct _xmlNode        *next;    /* next sibling link  */
 struct _xmlNode        *prev;    /* previous sibling link  */
 struct _xmlDoc          *doc;       /* the containing document */
 
 struct _xmlAttribute  *nexth;    /* next in hash table */
 xmlAttributeType       atype;    /* The attribute type */
 xmlAttributeDefault      def;    /* the default */
 const xmlChar  *defaultValue;    /* or the default value */
 xmlEnumerationPtr       tree;       /* or the enumeration tree if any */
 const xmlChar        *prefix;    /* the namespace prefix if any */
 const xmlChar          *elem;    /* Element holding the attribute */
 };
 
 /**
 * xmlElementContentType:
 *
 * Possible definitions of element content types.
 */
 typedef enum {
 XML_ELEMENT_CONTENT_PCDATA = 1,
 XML_ELEMENT_CONTENT_ELEMENT,
 XML_ELEMENT_CONTENT_SEQ,
 XML_ELEMENT_CONTENT_OR
 } xmlElementContentType;
 
 /**
 * xmlElementContentOccur:
 *
 * Possible definitions of element content occurrences.
 */
 typedef enum {
 XML_ELEMENT_CONTENT_ONCE = 1,
 XML_ELEMENT_CONTENT_OPT,
 XML_ELEMENT_CONTENT_MULT,
 XML_ELEMENT_CONTENT_PLUS
 } xmlElementContentOccur;
 
 /**
 * xmlElementContent:
 *
 * An XML Element content as stored after parsing an element definition
 * in a DTD.
 */
 
 typedef struct _xmlElementContent xmlElementContent;
 typedef xmlElementContent *xmlElementContentPtr;
 struct _xmlElementContent {
 xmlElementContentType     type;    /* PCDATA, ELEMENT, SEQ or OR */
 xmlElementContentOccur    ocur;    /* ONCE, OPT, MULT or PLUS */
 const xmlChar             *name;    /* Element name */
 struct _xmlElementContent *c1;    /* first child */
 struct _xmlElementContent *c2;    /* second child */
 struct _xmlElementContent *parent;    /* parent */
 const xmlChar             *prefix;    /* Namespace prefix */
 };
 
 /**
 * xmlElementTypeVal:
 *
 * The different possibilities for an element content type.
 */
 
 typedef enum {
 XML_ELEMENT_TYPE_UNDEFINED = 0,
 XML_ELEMENT_TYPE_EMPTY = 1,
 XML_ELEMENT_TYPE_ANY,
 XML_ELEMENT_TYPE_MIXED,
 XML_ELEMENT_TYPE_ELEMENT
 } xmlElementTypeVal;
 
 #ifdef __cplusplus
 }
 #endif
 #include <libxml/xmlregexp.h>
 #ifdef __cplusplus
 extern "C" {
 #endif
 
 /**
 * xmlElement:
 *
 * An XML Element declaration from a DTD.
 */
 
 typedef struct _xmlElement xmlElement;
 typedef xmlElement *xmlElementPtr;
 struct _xmlElement {
 void           *_private;            /* application data */
 xmlElementType          type;       /* XML_ELEMENT_DECL, must be second ! */
 const xmlChar          *name;    /* Element name */
 struct _xmlNode    *children;    /* NULL */
 struct _xmlNode        *last;    /* NULL */
 struct _xmlDtd       *parent;    /* -> DTD */
 struct _xmlNode        *next;    /* next sibling link  */
 struct _xmlNode        *prev;    /* previous sibling link  */
 struct _xmlDoc          *doc;       /* the containing document */
 
 xmlElementTypeVal      etype;    /* The type */
 xmlElementContentPtr content;    /* the allowed element content */
 xmlAttributePtr   attributes;    /* List of the declared attributes */
 const xmlChar        *prefix;    /* the namespace prefix if any */
 #ifdef LIBXML_REGEXP_ENABLED
 xmlRegexpPtr       contModel;    /* the validating regexp */
 #else
 void          *contModel;
 #endif
 };
 
 
 /**
 * XML_LOCAL_NAMESPACE:
 *
 * A namespace declaration node.
 */
 #define XML_LOCAL_NAMESPACE XML_NAMESPACE_DECL
 typedef xmlElementType xmlNsType;
 
 /**
 * xmlNs:
 *
 * An XML namespace.
 * Note that prefix == NULL is valid, it defines the default namespace
 * within the subtree (until overridden).
 *
 * xmlNsType is unified with xmlElementType.
 */
 
 typedef struct _xmlNs xmlNs;
 typedef xmlNs *xmlNsPtr;
 struct _xmlNs {
 struct _xmlNs  *next;    /* next Ns link for this node  */
 xmlNsType      type;    /* global or local */
 const xmlChar *href;    /* URL for the namespace */
 const xmlChar *prefix;    /* prefix for the namespace */
 void           *_private;   /* application data */
 struct _xmlDoc *context;        /* normally an xmlDoc */
 };
 
 /**
 * xmlDtd:
 *
 * An XML DTD, as defined by <!DOCTYPE ... There is actually one for
 * the internal subset and for the external subset.
 */
 typedef struct _xmlDtd xmlDtd;
 typedef xmlDtd *xmlDtdPtr;
 struct _xmlDtd {
 void           *_private;    /* application data */
 xmlElementType  type;       /* XML_DTD_NODE, must be second ! */
 const xmlChar *name;    /* Name of the DTD */
 struct _xmlNode *children;    /* the value of the property link */
 struct _xmlNode *last;    /* last child link */
 struct _xmlDoc  *parent;    /* child->parent link */
 struct _xmlNode *next;    /* next sibling link  */
 struct _xmlNode *prev;    /* previous sibling link  */
 struct _xmlDoc  *doc;    /* the containing document */
 
 /* End of common part */
 void          *notations;   /* Hash table for notations if any */
 void          *elements;    /* Hash table for elements if any */
 void          *attributes;  /* Hash table for attributes if any */
 void          *entities;    /* Hash table for entities if any */
 const xmlChar *ExternalID;    /* External identifier for PUBLIC DTD */
 const xmlChar *SystemID;    /* URI for a SYSTEM or PUBLIC DTD */
 void          *pentities;   /* Hash table for param entities if any */
 };
 
 /**
 * xmlAttr:
 *
 * An attribute on an XML node.
 */
 typedef struct _xmlAttr xmlAttr;
 typedef xmlAttr *xmlAttrPtr;
 struct _xmlAttr {
 void           *_private;    /* application data */
 xmlElementType   type;      /* XML_ATTRIBUTE_NODE, must be second ! */
 const xmlChar   *name;      /* the name of the property */
 struct _xmlNode *children;    /* the value of the property */
 struct _xmlNode *last;    /* NULL */
 struct _xmlNode *parent;    /* child->parent link */
 struct _xmlAttr *next;    /* next sibling link  */
 struct _xmlAttr *prev;    /* previous sibling link  */
 struct _xmlDoc  *doc;    /* the containing document */
 xmlNs           *ns;        /* pointer to the associated namespace */
 xmlAttributeType atype;     /* the attribute type if validating */
 void            *psvi;    /* for type/PSVI information */
 };
 
 /**
 * xmlID:
 *
 * An XML ID instance.
 */
 
 typedef struct _xmlID xmlID;
 typedef xmlID *xmlIDPtr;
 struct _xmlID {
 struct _xmlID    *next;    /* next ID */
 const xmlChar    *value;    /* The ID name */
 xmlAttrPtr        attr;    /* The attribute holding it */
 const xmlChar    *name;    /* The attribute if attr is not available */
 int               lineno;    /* The line number if attr is not available */
 struct _xmlDoc   *doc;    /* The document holding the ID */
 };
 
 /**
 * xmlRef:
 *
 * An XML IDREF instance.
 */
 
 typedef struct _xmlRef xmlRef;
 typedef xmlRef *xmlRefPtr;
 struct _xmlRef {
 struct _xmlRef    *next;    /* next Ref */
 const xmlChar     *value;    /* The Ref name */
 xmlAttrPtr        attr;    /* The attribute holding it */
 const xmlChar    *name;    /* The attribute if attr is not available */
 int               lineno;    /* The line number if attr is not available */
 };
 
 /**
 * xmlNode:
 *
 * A node in an XML tree.
 */
 typedef struct _xmlNode xmlNode;
 typedef xmlNode *xmlNodePtr;
 struct _xmlNode {
 void           *_private;    /* application data */
 xmlElementType   type;    /* type number, must be second ! */
 const xmlChar   *name;      /* the name of the node, or the entity */
 struct _xmlNode *children;    /* parent->childs link */
 struct _xmlNode *last;    /* last child link */
 struct _xmlNode *parent;    /* child->parent link */
 struct _xmlNode *next;    /* next sibling link  */
 struct _xmlNode *prev;    /* previous sibling link  */
 struct _xmlDoc  *doc;    /* the containing document */
 
 /* End of common part */
 xmlNs           *ns;        /* pointer to the associated namespace */
 xmlChar         *content;   /* the content */
 struct _xmlAttr *properties;/* properties list */
 xmlNs           *nsDef;     /* namespace definitions on this node */
 void            *psvi;    /* for type/PSVI information */
 unsigned short   line;    /* line number */
 unsigned short   extra;    /* extra data for XPath/XSLT */
 };
 
 /**
 * XML_GET_CONTENT:
 *
 * Macro to extract the content pointer of a node.
 */
 #define XML_GET_CONTENT(n)                    \
 ((n)->type == XML_ELEMENT_NODE ? NULL : (n)->content)
 
 /**
 * XML_GET_LINE:
 *
 * Macro to extract the line number of an element node.
 */
 #define XML_GET_LINE(n)                        \
 (xmlGetLineNo(n))
 
 /**
 * xmlDocProperty
 *
 * Set of properties of the document as found by the parser
 * Some of them are linked to similarly named xmlParserOption
 */
 typedef enum {
 XML_DOC_WELLFORMED        = 1<<0, /* document is XML well formed */
 XML_DOC_NSVALID        = 1<<1, /* document is Namespace valid */
 XML_DOC_OLD10        = 1<<2, /* parsed with old XML-1.0 parser */
 XML_DOC_DTDVALID        = 1<<3, /* DTD validation was successful */
 XML_DOC_XINCLUDE        = 1<<4, /* XInclude substitution was done */
 XML_DOC_USERBUILT        = 1<<5, /* Document was built using the API
 and not by parsing an instance */
 XML_DOC_INTERNAL        = 1<<6, /* built for internal processing */
 XML_DOC_HTML        = 1<<7  /* parsed or built HTML document */
 } xmlDocProperties;
 
 /**
 * xmlDoc:
 *
 * An XML document.
 */
 typedef struct _xmlDoc xmlDoc;
 typedef xmlDoc *xmlDocPtr;
 struct _xmlDoc {
 void           *_private;    /* application data */
 xmlElementType  type;       /* XML_DOCUMENT_NODE, must be second ! */
 char           *name;    /* name/filename/URI of the document */
 struct _xmlNode *children;    /* the document tree */
 struct _xmlNode *last;    /* last child link */
 struct _xmlNode *parent;    /* child->parent link */
 struct _xmlNode *next;    /* next sibling link  */
 struct _xmlNode *prev;    /* previous sibling link  */
 struct _xmlDoc  *doc;    /* autoreference to itself */
 
 /* End of common part */
 int             compression;/* level of zlib compression */
 int             standalone; /* standalone document (no external refs)
 1 if standalone="yes"
 0 if standalone="no"
 -1 if there is no XML declaration
 -2 if there is an XML declaration, but no
 standalone attribute was specified */
 struct _xmlDtd  *intSubset;    /* the document internal subset */
 struct _xmlDtd  *extSubset;    /* the document external subset */
 struct _xmlNs   *oldNs;    /* Global namespace, the old way */
 const xmlChar  *version;    /* the XML version string */
 const xmlChar  *encoding;   /* external initial encoding, if any */
 void           *ids;        /* Hash table for ID attributes if any */
 void           *refs;       /* Hash table for IDREFs attributes if any */
 const xmlChar  *URL;    /* The URI for that document */
 int             charset;    /* Internal flag for charset handling,
 actually an xmlCharEncoding */
 struct _xmlDict *dict;      /* dict used to allocate names or NULL */
 void           *psvi;    /* for type/PSVI information */
 int             parseFlags;    /* set of xmlParserOption used to parse the
 document */
 int             properties;    /* set of xmlDocProperties for this document
 set at the end of parsing */
 };
 
 
 typedef struct _xmlDOMWrapCtxt xmlDOMWrapCtxt;
 typedef xmlDOMWrapCtxt *xmlDOMWrapCtxtPtr;
 
 /**
 * xmlDOMWrapAcquireNsFunction:
 * @ctxt:  a DOM wrapper context
 * @node:  the context node (element or attribute)
 * @nsName:  the requested namespace name
 * @nsPrefix:  the requested namespace prefix
 *
 * A function called to acquire namespaces (xmlNs) from the wrapper.
 *
 * Returns an xmlNsPtr or NULL in case of an error.
 */
 typedef xmlNsPtr (*xmlDOMWrapAcquireNsFunction) (xmlDOMWrapCtxtPtr ctxt,
 xmlNodePtr node,
 const xmlChar *nsName,
 const xmlChar *nsPrefix);
 
 /**
 * xmlDOMWrapCtxt:
 *
 * Context for DOM wrapper-operations.
 */
 struct _xmlDOMWrapCtxt {
 void * _private;
 /*
 * The type of this context, just in case we need specialized
 * contexts in the future.
 */
 int type;
 /*
 * Internal namespace map used for various operations.
 */
 void * namespaceMap;
 /*
 * Use this one to acquire an xmlNsPtr intended for node->ns.
 * (Note that this is not intended for elem->nsDef).
 */
 xmlDOMWrapAcquireNsFunction getNsForNodeFunc;
 };
 
 /**
 * xmlChildrenNode:
 *
 * Macro for compatibility naming layer with libxml1. Maps
 * to "children."
 */
 #ifndef xmlChildrenNode
 #define xmlChildrenNode children
 #endif
 
 /**
 * xmlRootNode:
 *
 * Macro for compatibility naming layer with libxml1. Maps
 * to "children".
 */
 #ifndef xmlRootNode
 #define xmlRootNode children
 #endif
 
 /*
 * Variables.
 */
 
 /*
 * Some helper functions
 */
 #if defined(LIBXML_TREE_ENABLED) || defined(LIBXML_XPATH_ENABLED) || \
 defined(LIBXML_SCHEMAS_ENABLED) || defined(LIBXML_DEBUG_ENABLED) || \
 defined (LIBXML_HTML_ENABLED) || defined(LIBXML_SAX1_ENABLED) || \
 defined(LIBXML_HTML_ENABLED) || defined(LIBXML_WRITER_ENABLED) || \
 defined(LIBXML_DOCB_ENABLED) || defined(LIBXML_LEGACY_ENABLED)
 XMLPUBFUN int XMLCALL
 xmlValidateNCName    (const xmlChar *value,
 int space);
 #endif
 
 #if defined(LIBXML_TREE_ENABLED) || defined(LIBXML_SCHEMAS_ENABLED)
 XMLPUBFUN int XMLCALL
 xmlValidateQName    (const xmlChar *value,
 int space);
 XMLPUBFUN int XMLCALL
 xmlValidateName        (const xmlChar *value,
 int space);
 XMLPUBFUN int XMLCALL
 xmlValidateNMToken    (const xmlChar *value,
 int space);
 #endif
 
 XMLPUBFUN xmlChar * XMLCALL
 xmlBuildQName        (const xmlChar *ncname,
 const xmlChar *prefix,
 xmlChar *memory,
 int len);
 XMLPUBFUN xmlChar * XMLCALL
 xmlSplitQName2        (const xmlChar *name,
 xmlChar **prefix);
 XMLPUBFUN const xmlChar * XMLCALL
 xmlSplitQName3        (const xmlChar *name,
 int *len);
 
 /*
 * Handling Buffers, the old ones see @xmlBuf for the new ones.
 */
 
 XMLPUBFUN void XMLCALL
 xmlSetBufferAllocationScheme(xmlBufferAllocationScheme scheme);
 XMLPUBFUN xmlBufferAllocationScheme XMLCALL
 xmlGetBufferAllocationScheme(void);
 
 XMLPUBFUN xmlBufferPtr XMLCALL
 xmlBufferCreate        (void);
 XMLPUBFUN xmlBufferPtr XMLCALL
 xmlBufferCreateSize    (size_t size);
 XMLPUBFUN xmlBufferPtr XMLCALL
 xmlBufferCreateStatic    (void *mem,
 size_t size);
 XMLPUBFUN int XMLCALL
 xmlBufferResize        (xmlBufferPtr buf,
 unsigned int size);
 XMLPUBFUN void XMLCALL
 xmlBufferFree        (xmlBufferPtr buf);
 XMLPUBFUN int XMLCALL
 xmlBufferDump        (FILE *file,
 xmlBufferPtr buf);
 XMLPUBFUN int XMLCALL
 xmlBufferAdd        (xmlBufferPtr buf,
 const xmlChar *str,
 int len);
 XMLPUBFUN int XMLCALL
 xmlBufferAddHead    (xmlBufferPtr buf,
 const xmlChar *str,
 int len);
 XMLPUBFUN int XMLCALL
 xmlBufferCat        (xmlBufferPtr buf,
 const xmlChar *str);
 XMLPUBFUN int XMLCALL
 xmlBufferCCat        (xmlBufferPtr buf,
 const char *str);
 XMLPUBFUN int XMLCALL
 xmlBufferShrink        (xmlBufferPtr buf,
 unsigned int len);
 XMLPUBFUN int XMLCALL
 xmlBufferGrow        (xmlBufferPtr buf,
 unsigned int len);
 XMLPUBFUN void XMLCALL
 xmlBufferEmpty        (xmlBufferPtr buf);
 XMLPUBFUN const xmlChar* XMLCALL
 xmlBufferContent    (const xmlBuffer *buf);
 XMLPUBFUN xmlChar* XMLCALL
 xmlBufferDetach         (xmlBufferPtr buf);
 XMLPUBFUN void XMLCALL
 xmlBufferSetAllocationScheme(xmlBufferPtr buf,
 xmlBufferAllocationScheme scheme);
 XMLPUBFUN int XMLCALL
 xmlBufferLength        (const xmlBuffer *buf);
 
 /*
 * Creating/freeing new structures.
 */
 XMLPUBFUN xmlDtdPtr XMLCALL
 xmlCreateIntSubset    (xmlDocPtr doc,
 const xmlChar *name,
 const xmlChar *ExternalID,
 const xmlChar *SystemID);
 XMLPUBFUN xmlDtdPtr XMLCALL
 xmlNewDtd        (xmlDocPtr doc,
 const xmlChar *name,
 const xmlChar *ExternalID,
 const xmlChar *SystemID);
 XMLPUBFUN xmlDtdPtr XMLCALL
 xmlGetIntSubset        (const xmlDoc *doc);
 XMLPUBFUN void XMLCALL
 xmlFreeDtd        (xmlDtdPtr cur);
 #ifdef LIBXML_LEGACY_ENABLED
 XMLPUBFUN xmlNsPtr XMLCALL
 xmlNewGlobalNs        (xmlDocPtr doc,
 const xmlChar *href,
 const xmlChar *prefix);
 #endif /* LIBXML_LEGACY_ENABLED */
 XMLPUBFUN xmlNsPtr XMLCALL
 xmlNewNs        (xmlNodePtr node,
 const xmlChar *href,
 const xmlChar *prefix);
 XMLPUBFUN void XMLCALL
 xmlFreeNs        (xmlNsPtr cur);
 XMLPUBFUN void XMLCALL
 xmlFreeNsList        (xmlNsPtr cur);
 XMLPUBFUN xmlDocPtr XMLCALL
 xmlNewDoc        (const xmlChar *version);
 XMLPUBFUN void XMLCALL
 xmlFreeDoc        (xmlDocPtr cur);
 XMLPUBFUN xmlAttrPtr XMLCALL
 xmlNewDocProp        (xmlDocPtr doc,
 const xmlChar *name,
 const xmlChar *value);
 #if defined(LIBXML_TREE_ENABLED) || defined(LIBXML_HTML_ENABLED) || \
 defined(LIBXML_SCHEMAS_ENABLED)
 XMLPUBFUN xmlAttrPtr XMLCALL
 xmlNewProp        (xmlNodePtr node,
 const xmlChar *name,
 const xmlChar *value);
 #endif
 XMLPUBFUN xmlAttrPtr XMLCALL
 xmlNewNsProp        (xmlNodePtr node,
 xmlNsPtr ns,
 const xmlChar *name,
 const xmlChar *value);
 XMLPUBFUN xmlAttrPtr XMLCALL
 xmlNewNsPropEatName    (xmlNodePtr node,
 xmlNsPtr ns,
 xmlChar *name,
 const xmlChar *value);
 XMLPUBFUN void XMLCALL
 xmlFreePropList        (xmlAttrPtr cur);
 XMLPUBFUN void XMLCALL
 xmlFreeProp        (xmlAttrPtr cur);
 XMLPUBFUN xmlAttrPtr XMLCALL
 xmlCopyProp        (xmlNodePtr target,
 xmlAttrPtr cur);
 XMLPUBFUN xmlAttrPtr XMLCALL
 xmlCopyPropList        (xmlNodePtr target,
 xmlAttrPtr cur);
 #ifdef LIBXML_TREE_ENABLED
 XMLPUBFUN xmlDtdPtr XMLCALL
 xmlCopyDtd        (xmlDtdPtr dtd);
 #endif /* LIBXML_TREE_ENABLED */
 #if defined(LIBXML_TREE_ENABLED) || defined(LIBXML_SCHEMAS_ENABLED)
 XMLPUBFUN xmlDocPtr XMLCALL
 xmlCopyDoc        (xmlDocPtr doc,
 int recursive);
 #endif /* defined(LIBXML_TREE_ENABLED) || defined(LIBXML_SCHEMAS_ENABLED) */
 /*
 * Creating new nodes.
 */
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlNewDocNode        (xmlDocPtr doc,
 xmlNsPtr ns,
 const xmlChar *name,
 const xmlChar *content);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlNewDocNodeEatName    (xmlDocPtr doc,
 xmlNsPtr ns,
 xmlChar *name,
 const xmlChar *content);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlNewNode        (xmlNsPtr ns,
 const xmlChar *name);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlNewNodeEatName    (xmlNsPtr ns,
 xmlChar *name);
 #if defined(LIBXML_TREE_ENABLED) || defined(LIBXML_SCHEMAS_ENABLED)
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlNewChild        (xmlNodePtr parent,
 xmlNsPtr ns,
 const xmlChar *name,
 const xmlChar *content);
 #endif
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlNewDocText        (const xmlDoc *doc,
 const xmlChar *content);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlNewText        (const xmlChar *content);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlNewDocPI        (xmlDocPtr doc,
 const xmlChar *name,
 const xmlChar *content);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlNewPI        (const xmlChar *name,
 const xmlChar *content);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlNewDocTextLen    (xmlDocPtr doc,
 const xmlChar *content,
 int len);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlNewTextLen        (const xmlChar *content,
 int len);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlNewDocComment    (xmlDocPtr doc,
 const xmlChar *content);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlNewComment        (const xmlChar *content);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlNewCDataBlock    (xmlDocPtr doc,
 const xmlChar *content,
 int len);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlNewCharRef        (xmlDocPtr doc,
 const xmlChar *name);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlNewReference        (const xmlDoc *doc,
 const xmlChar *name);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlCopyNode        (xmlNodePtr node,
 int recursive);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlDocCopyNode        (xmlNodePtr node,
 xmlDocPtr doc,
 int recursive);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlDocCopyNodeList    (xmlDocPtr doc,
 xmlNodePtr node);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlCopyNodeList        (xmlNodePtr node);
 #ifdef LIBXML_TREE_ENABLED
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlNewTextChild        (xmlNodePtr parent,
 xmlNsPtr ns,
 const xmlChar *name,
 const xmlChar *content);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlNewDocRawNode    (xmlDocPtr doc,
 xmlNsPtr ns,
 const xmlChar *name,
 const xmlChar *content);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlNewDocFragment    (xmlDocPtr doc);
 #endif /* LIBXML_TREE_ENABLED */
 
 /*
 * Navigating.
 */
 XMLPUBFUN long XMLCALL
 xmlGetLineNo        (const xmlNode *node);
 #if defined(LIBXML_TREE_ENABLED) || defined(LIBXML_DEBUG_ENABLED)
 XMLPUBFUN xmlChar * XMLCALL
 xmlGetNodePath        (const xmlNode *node);
 #endif /* defined(LIBXML_TREE_ENABLED) || defined(LIBXML_DEBUG_ENABLED) */
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlDocGetRootElement    (const xmlDoc *doc);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlGetLastChild        (const xmlNode *parent);
 XMLPUBFUN int XMLCALL
 xmlNodeIsText        (const xmlNode *node);
 XMLPUBFUN int XMLCALL
 xmlIsBlankNode        (const xmlNode *node);
 
 /*
 * Changing the structure.
 */
 #if defined(LIBXML_TREE_ENABLED) || defined(LIBXML_WRITER_ENABLED)
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlDocSetRootElement    (xmlDocPtr doc,
 xmlNodePtr root);
 #endif /* defined(LIBXML_TREE_ENABLED) || defined(LIBXML_WRITER_ENABLED) */
 #ifdef LIBXML_TREE_ENABLED
 XMLPUBFUN void XMLCALL
 xmlNodeSetName        (xmlNodePtr cur,
 const xmlChar *name);
 #endif /* LIBXML_TREE_ENABLED */
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlAddChild        (xmlNodePtr parent,
 xmlNodePtr cur);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlAddChildList        (xmlNodePtr parent,
 xmlNodePtr cur);
 #if defined(LIBXML_TREE_ENABLED) || defined(LIBXML_WRITER_ENABLED)
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlReplaceNode        (xmlNodePtr old,
 xmlNodePtr cur);
 #endif /* defined(LIBXML_TREE_ENABLED) || defined(LIBXML_WRITER_ENABLED) */
 #if defined(LIBXML_TREE_ENABLED) || defined(LIBXML_HTML_ENABLED) || \
 defined(LIBXML_SCHEMAS_ENABLED) || defined(LIBXML_XINCLUDE_ENABLED)
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlAddPrevSibling    (xmlNodePtr cur,
 xmlNodePtr elem);
 #endif /* LIBXML_TREE_ENABLED || LIBXML_HTML_ENABLED || LIBXML_SCHEMAS_ENABLED */
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlAddSibling        (xmlNodePtr cur,
 xmlNodePtr elem);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlAddNextSibling    (xmlNodePtr cur,
 xmlNodePtr elem);
 XMLPUBFUN void XMLCALL
 xmlUnlinkNode        (xmlNodePtr cur);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlTextMerge        (xmlNodePtr first,
 xmlNodePtr second);
 XMLPUBFUN int XMLCALL
 xmlTextConcat        (xmlNodePtr node,
 const xmlChar *content,
 int len);
 XMLPUBFUN void XMLCALL
 xmlFreeNodeList        (xmlNodePtr cur);
 XMLPUBFUN void XMLCALL
 xmlFreeNode        (xmlNodePtr cur);
 XMLPUBFUN void XMLCALL
 xmlSetTreeDoc        (xmlNodePtr tree,
 xmlDocPtr doc);
 XMLPUBFUN void XMLCALL
 xmlSetListDoc        (xmlNodePtr list,
 xmlDocPtr doc);
 /*
 * Namespaces.
 */
 XMLPUBFUN xmlNsPtr XMLCALL
 xmlSearchNs        (xmlDocPtr doc,
 xmlNodePtr node,
 const xmlChar *nameSpace);
 XMLPUBFUN xmlNsPtr XMLCALL
 xmlSearchNsByHref    (xmlDocPtr doc,
 xmlNodePtr node,
 const xmlChar *href);
 #if defined(LIBXML_TREE_ENABLED) || defined(LIBXML_XPATH_ENABLED) || \
 defined(LIBXML_SCHEMAS_ENABLED)
 XMLPUBFUN xmlNsPtr * XMLCALL
 xmlGetNsList        (const xmlDoc *doc,
 const xmlNode *node);
 #endif /* defined(LIBXML_TREE_ENABLED) || defined(LIBXML_XPATH_ENABLED) */
 
 XMLPUBFUN void XMLCALL
 xmlSetNs        (xmlNodePtr node,
 xmlNsPtr ns);
 XMLPUBFUN xmlNsPtr XMLCALL
 xmlCopyNamespace    (xmlNsPtr cur);
 XMLPUBFUN xmlNsPtr XMLCALL
 xmlCopyNamespaceList    (xmlNsPtr cur);
 
 /*
 * Changing the content.
 */
 #if defined(LIBXML_TREE_ENABLED) || defined(LIBXML_XINCLUDE_ENABLED) || \
 defined(LIBXML_SCHEMAS_ENABLED) || defined(LIBXML_HTML_ENABLED)
 XMLPUBFUN xmlAttrPtr XMLCALL
 xmlSetProp        (xmlNodePtr node,
 const xmlChar *name,
 const xmlChar *value);
 XMLPUBFUN xmlAttrPtr XMLCALL
 xmlSetNsProp        (xmlNodePtr node,
 xmlNsPtr ns,
 const xmlChar *name,
 const xmlChar *value);
 #endif /* defined(LIBXML_TREE_ENABLED) || defined(LIBXML_XINCLUDE_ENABLED) || \
 defined(LIBXML_SCHEMAS_ENABLED) || defined(LIBXML_HTML_ENABLED) */
 XMLPUBFUN xmlChar * XMLCALL
 xmlGetNoNsProp        (const xmlNode *node,
 const xmlChar *name);
 XMLPUBFUN xmlChar * XMLCALL
 xmlGetProp        (const xmlNode *node,
 const xmlChar *name);
 XMLPUBFUN xmlAttrPtr XMLCALL
 xmlHasProp        (const xmlNode *node,
 const xmlChar *name);
 XMLPUBFUN xmlAttrPtr XMLCALL
 xmlHasNsProp        (const xmlNode *node,
 const xmlChar *name,
 const xmlChar *nameSpace);
 XMLPUBFUN xmlChar * XMLCALL
 xmlGetNsProp        (const xmlNode *node,
 const xmlChar *name,
 const xmlChar *nameSpace);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlStringGetNodeList    (const xmlDoc *doc,
 const xmlChar *value);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlStringLenGetNodeList    (const xmlDoc *doc,
 const xmlChar *value,
 int len);
 XMLPUBFUN xmlChar * XMLCALL
 xmlNodeListGetString    (xmlDocPtr doc,
 const xmlNode *list,
 int inLine);
 #ifdef LIBXML_TREE_ENABLED
 XMLPUBFUN xmlChar * XMLCALL
 xmlNodeListGetRawString    (const xmlDoc *doc,
 const xmlNode *list,
 int inLine);
 #endif /* LIBXML_TREE_ENABLED */
 XMLPUBFUN void XMLCALL
 xmlNodeSetContent    (xmlNodePtr cur,
 const xmlChar *content);
 #ifdef LIBXML_TREE_ENABLED
 XMLPUBFUN void XMLCALL
 xmlNodeSetContentLen    (xmlNodePtr cur,
 const xmlChar *content,
 int len);
 #endif /* LIBXML_TREE_ENABLED */
 XMLPUBFUN void XMLCALL
 xmlNodeAddContent    (xmlNodePtr cur,
 const xmlChar *content);
 XMLPUBFUN void XMLCALL
 xmlNodeAddContentLen    (xmlNodePtr cur,
 const xmlChar *content,
 int len);
 XMLPUBFUN xmlChar * XMLCALL
 xmlNodeGetContent    (const xmlNode *cur);
 
 XMLPUBFUN int XMLCALL
 xmlNodeBufGetContent    (xmlBufferPtr buffer,
 const xmlNode *cur);
 XMLPUBFUN int XMLCALL
 xmlBufGetNodeContent    (xmlBufPtr buf,
 const xmlNode *cur);
 
 XMLPUBFUN xmlChar * XMLCALL
 xmlNodeGetLang        (const xmlNode *cur);
 XMLPUBFUN int XMLCALL
 xmlNodeGetSpacePreserve    (const xmlNode *cur);
 #ifdef LIBXML_TREE_ENABLED
 XMLPUBFUN void XMLCALL
 xmlNodeSetLang        (xmlNodePtr cur,
 const xmlChar *lang);
 XMLPUBFUN void XMLCALL
 xmlNodeSetSpacePreserve (xmlNodePtr cur,
 int val);
 #endif /* LIBXML_TREE_ENABLED */
 XMLPUBFUN xmlChar * XMLCALL
 xmlNodeGetBase        (const xmlDoc *doc,
 const xmlNode *cur);
 #if defined(LIBXML_TREE_ENABLED) || defined(LIBXML_XINCLUDE_ENABLED)
 XMLPUBFUN void XMLCALL
 xmlNodeSetBase        (xmlNodePtr cur,
 const xmlChar *uri);
 #endif
 
 /*
 * Removing content.
 */
 XMLPUBFUN int XMLCALL
 xmlRemoveProp        (xmlAttrPtr cur);
 #if defined(LIBXML_TREE_ENABLED) || defined(LIBXML_SCHEMAS_ENABLED)
 XMLPUBFUN int XMLCALL
 xmlUnsetNsProp        (xmlNodePtr node,
 xmlNsPtr ns,
 const xmlChar *name);
 XMLPUBFUN int XMLCALL
 xmlUnsetProp        (xmlNodePtr node,
 const xmlChar *name);
 #endif /* defined(LIBXML_TREE_ENABLED) || defined(LIBXML_SCHEMAS_ENABLED) */
 
 /*
 * Internal, don't use.
 */
 XMLPUBFUN void XMLCALL
 xmlBufferWriteCHAR    (xmlBufferPtr buf,
 const xmlChar *string);
 XMLPUBFUN void XMLCALL
 xmlBufferWriteChar    (xmlBufferPtr buf,
 const char *string);
 XMLPUBFUN void XMLCALL
 xmlBufferWriteQuotedString(xmlBufferPtr buf,
 const xmlChar *string);
 
 #ifdef LIBXML_OUTPUT_ENABLED
 XMLPUBFUN void xmlAttrSerializeTxtContent(xmlBufferPtr buf,
 xmlDocPtr doc,
 xmlAttrPtr attr,
 const xmlChar *string);
 #endif /* LIBXML_OUTPUT_ENABLED */
 
 #ifdef LIBXML_TREE_ENABLED
 /*
 * Namespace handling.
 */
 XMLPUBFUN int XMLCALL
 xmlReconciliateNs    (xmlDocPtr doc,
 xmlNodePtr tree);
 #endif
 
 #ifdef LIBXML_OUTPUT_ENABLED
 /*
 * Saving.
 */
 XMLPUBFUN void XMLCALL
 xmlDocDumpFormatMemory    (xmlDocPtr cur,
 xmlChar **mem,
 int *size,
 int format);
 XMLPUBFUN void XMLCALL
 xmlDocDumpMemory    (xmlDocPtr cur,
 xmlChar **mem,
 int *size);
 XMLPUBFUN void XMLCALL
 xmlDocDumpMemoryEnc    (xmlDocPtr out_doc,
 xmlChar **doc_txt_ptr,
 int * doc_txt_len,
 const char *txt_encoding);
 XMLPUBFUN void XMLCALL
 xmlDocDumpFormatMemoryEnc(xmlDocPtr out_doc,
 xmlChar **doc_txt_ptr,
 int * doc_txt_len,
 const char *txt_encoding,
 int format);
 XMLPUBFUN int XMLCALL
 xmlDocFormatDump    (FILE *f,
 xmlDocPtr cur,
 int format);
 XMLPUBFUN int XMLCALL
 xmlDocDump        (FILE *f,
 xmlDocPtr cur);
 XMLPUBFUN void XMLCALL
 xmlElemDump        (FILE *f,
 xmlDocPtr doc,
 xmlNodePtr cur);
 XMLPUBFUN int XMLCALL
 xmlSaveFile        (const char *filename,
 xmlDocPtr cur);
 XMLPUBFUN int XMLCALL
 xmlSaveFormatFile    (const char *filename,
 xmlDocPtr cur,
 int format);
 XMLPUBFUN size_t XMLCALL
 xmlBufNodeDump        (xmlBufPtr buf,
 xmlDocPtr doc,
 xmlNodePtr cur,
 int level,
 int format);
 XMLPUBFUN int XMLCALL
 xmlNodeDump        (xmlBufferPtr buf,
 xmlDocPtr doc,
 xmlNodePtr cur,
 int level,
 int format);
 
 XMLPUBFUN int XMLCALL
 xmlSaveFileTo        (xmlOutputBufferPtr buf,
 xmlDocPtr cur,
 const char *encoding);
 XMLPUBFUN int XMLCALL
 xmlSaveFormatFileTo     (xmlOutputBufferPtr buf,
 xmlDocPtr cur,
 const char *encoding,
 int format);
 XMLPUBFUN void XMLCALL
 xmlNodeDumpOutput    (xmlOutputBufferPtr buf,
 xmlDocPtr doc,
 xmlNodePtr cur,
 int level,
 int format,
 const char *encoding);
 
 XMLPUBFUN int XMLCALL
 xmlSaveFormatFileEnc    (const char *filename,
 xmlDocPtr cur,
 const char *encoding,
 int format);
 
 XMLPUBFUN int XMLCALL
 xmlSaveFileEnc        (const char *filename,
 xmlDocPtr cur,
 const char *encoding);
 
 #endif /* LIBXML_OUTPUT_ENABLED */
 /*
 * XHTML
 */
 XMLPUBFUN int XMLCALL
 xmlIsXHTML        (const xmlChar *systemID,
 const xmlChar *publicID);
 
 /*
 * Compression.
 */
 XMLPUBFUN int XMLCALL
 xmlGetDocCompressMode    (const xmlDoc *doc);
 XMLPUBFUN void XMLCALL
 xmlSetDocCompressMode    (xmlDocPtr doc,
 int mode);
 XMLPUBFUN int XMLCALL
 xmlGetCompressMode    (void);
 XMLPUBFUN void XMLCALL
 xmlSetCompressMode    (int mode);
 
 /*
 * DOM-wrapper helper functions.
 */
 XMLPUBFUN xmlDOMWrapCtxtPtr XMLCALL
 xmlDOMWrapNewCtxt    (void);
 XMLPUBFUN void XMLCALL
 xmlDOMWrapFreeCtxt    (xmlDOMWrapCtxtPtr ctxt);
 XMLPUBFUN int XMLCALL
 xmlDOMWrapReconcileNamespaces(xmlDOMWrapCtxtPtr ctxt,
 xmlNodePtr elem,
 int options);
 XMLPUBFUN int XMLCALL
 xmlDOMWrapAdoptNode        (xmlDOMWrapCtxtPtr ctxt,
 xmlDocPtr sourceDoc,
 xmlNodePtr node,
 xmlDocPtr destDoc,
 xmlNodePtr destParent,
 int options);
 XMLPUBFUN int XMLCALL
 xmlDOMWrapRemoveNode    (xmlDOMWrapCtxtPtr ctxt,
 xmlDocPtr doc,
 xmlNodePtr node,
 int options);
 XMLPUBFUN int XMLCALL
 xmlDOMWrapCloneNode        (xmlDOMWrapCtxtPtr ctxt,
 xmlDocPtr sourceDoc,
 xmlNodePtr node,
 xmlNodePtr *clonedNode,
 xmlDocPtr destDoc,
 xmlNodePtr destParent,
 int deep,
 int options);
 
 #ifdef LIBXML_TREE_ENABLED
 /*
 * 5 interfaces from DOM ElementTraversal, but different in entities
 * traversal.
 */
 XMLPUBFUN unsigned long XMLCALL
 xmlChildElementCount        (xmlNodePtr parent);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlNextElementSibling       (xmlNodePtr node);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlFirstElementChild        (xmlNodePtr parent);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlLastElementChild         (xmlNodePtr parent);
 XMLPUBFUN xmlNodePtr XMLCALL
 xmlPreviousElementSibling   (xmlNodePtr node);
 #endif
 #ifdef __cplusplus
 }
 #endif
 #ifndef __XML_PARSER_H__
 #include <libxml/xmlmemory.h>
 #endif
 
 #endif /* __XML_TREE_H__ */
 
 
 |