<html>
<head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/> <title>tree: interfaces for tree manipulation</title> <meta name="generator" content="Libxml2 devhelp stylesheet"/> <link rel="start" href="index.html" title="libxml2 Reference Manual"/> <link rel="up" href="general.html" title="API"/> <link rel="stylesheet" href="style.css" type="text/css"/> <link rel="chapter" href="general.html" title="API"/> </head> <body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF"> <table class="navigation" width="100%" summary="Navigation header" cellpadding="2" cellspacing="2"> <tr valign="middle"> <td> <a accesskey="p" href="libxml2-threads.html"> <img src="left.png" width="24" height="24" border="0" alt="Prev"/> </a> </td> <td> <a accesskey="u" href="general.html"> <img src="up.png" width="24" height="24" border="0" alt="Up"/> </a> </td> <td> <a accesskey="h" href="index.html"> <img src="home.png" width="24" height="24" border="0" alt="Home"/> </a> </td> <td> <a accesskey="n" href="libxml2-uri.html"> <img src="right.png" width="24" height="24" border="0" alt="Next"/> </a> </td> <th width="100%" align="center">libxml2 Reference Manual</th> </tr> </table> <h2> <span class="refentrytitle">tree</span> </h2> <p>tree - interfaces for tree manipulation</p> <p>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 </p> <p>Author(s): Daniel Veillard </p> <div class="refsynopsisdiv"> <h2>Synopsis</h2> <pre class="synopsis">#define <a href="#XML_LOCAL_NAMESPACE">XML_LOCAL_NAMESPACE</a>;
define <a href=“#BASE_BUFFER_SIZE”>BASE_BUFFER_SIZE</a>; define <a href=“#XML_XML_ID”>XML_XML_ID</a>; define <a href=“#xmlRootNode”>xmlRootNode</a>; define <a href=“#XML_GET_LINE”>XML_GET_LINE</a>; define <a href=“#XML_GET_CONTENT”>XML_GET_CONTENT</a>; define <a href=“#xmlChildrenNode”>xmlChildrenNode</a>; define <a href=“#XML_XML_NAMESPACE”>XML_XML_NAMESPACE</a>; define <a href=“#LIBXML2_NEW_BUFFER”>LIBXML2_NEW_BUFFER</a>; typedef struct _xmlNs <a href=“#xmlNs”>xmlNs</a>; typedef struct _xmlElementContent <a href=“#xmlElementContent”>xmlElementContent</a>; typedef <a href=“libxml2-tree.html#xmlEnumeration”>xmlEnumeration</a> * <a href=“#xmlEnumerationPtr”>xmlEnumerationPtr</a>; typedef struct _xmlBuffer <a href=“#xmlBuffer”>xmlBuffer</a>; typedef <a href=“libxml2-tree.html#xmlParserInput”>xmlParserInput</a> * <a href=“#xmlParserInputPtr”>xmlParserInputPtr</a>; typedef <a href=“libxml2-tree.html#xmlSAXLocator”>xmlSAXLocator</a> * <a href=“#xmlSAXLocatorPtr”>xmlSAXLocatorPtr</a>; typedef struct _xmlParserInput <a href=“#xmlParserInput”>xmlParserInput</a>; typedef struct _xmlElement <a href=“#xmlElement”>xmlElement</a>; typedef <a href=“libxml2-tree.html#xmlElementType”>xmlElementType</a> <a href=“#xmlNsType”>xmlNsType</a>; typedef enum <a href=“#xmlBufferAllocationScheme”>xmlBufferAllocationScheme</a>; typedef struct _xmlNode <a href=“#xmlNode”>xmlNode</a>; typedef <a href=“libxml2-tree.html#xmlDoc”>xmlDoc</a> * <a href=“#xmlDocPtr”>xmlDocPtr</a>; typedef <a href=“libxml2-tree.html#xmlBuffer”>xmlBuffer</a> * <a href=“#xmlBufferPtr”>xmlBufferPtr</a>; typedef <a href=“libxml2-tree.html#xmlDOMWrapCtxt”>xmlDOMWrapCtxt</a> * <a href=“#xmlDOMWrapCtxtPtr”>xmlDOMWrapCtxtPtr</a>; typedef <a href=“libxml2-tree.html#xmlRef”>xmlRef</a> * <a href=“#xmlRefPtr”>xmlRefPtr</a>; typedef struct _xmlParserInputBuffer <a href=“#xmlParserInputBuffer”>xmlParserInputBuffer</a>; typedef struct _xmlRef <a href=“#xmlRef”>xmlRef</a>; typedef struct _xmlDOMWrapCtxt <a href=“#xmlDOMWrapCtxt”>xmlDOMWrapCtxt</a>; typedef <a href=“libxml2-tree.html#xmlNode”>xmlNode</a> * <a href=“#xmlNodePtr”>xmlNodePtr</a>; typedef struct _xmlParserCtxt <a href=“#xmlParserCtxt”>xmlParserCtxt</a>; typedef <a href=“libxml2-tree.html#xmlDtd”>xmlDtd</a> * <a href=“#xmlDtdPtr”>xmlDtdPtr</a>; typedef enum <a href=“#xmlAttributeDefault”>xmlAttributeDefault</a>; typedef struct _xmlBuf <a href=“#xmlBuf”>xmlBuf</a>; typedef struct _xmlNotation <a href=“#xmlNotation”>xmlNotation</a>; typedef enum <a href=“#xmlElementType”>xmlElementType</a>; typedef struct _xmlEntity <a href=“#xmlEntity”>xmlEntity</a>; typedef struct _xmlAttr <a href=“#xmlAttr”>xmlAttr</a>; typedef <a href=“libxml2-tree.html#xmlAttribute”>xmlAttribute</a> * <a href=“#xmlAttributePtr”>xmlAttributePtr</a>; typedef enum <a href=“#xmlElementTypeVal”>xmlElementTypeVal</a>; typedef <a href=“libxml2-tree.html#xmlNotation”>xmlNotation</a> * <a href=“#xmlNotationPtr”>xmlNotationPtr</a>; typedef <a href=“libxml2-tree.html#xmlElement”>xmlElement</a> * <a href=“#xmlElementPtr”>xmlElementPtr</a>; typedef <a href=“libxml2-tree.html#xmlBuf”>xmlBuf</a> * <a href=“#xmlBufPtr”>xmlBufPtr</a>; typedef enum <a href=“#xmlElementContentOccur”>xmlElementContentOccur</a>; typedef <a href=“libxml2-tree.html#xmlAttr”>xmlAttr</a> * <a href=“#xmlAttrPtr”>xmlAttrPtr</a>; typedef struct _xmlDoc <a href=“#xmlDoc”>xmlDoc</a>; typedef struct _xmlID <a href=“#xmlID”>xmlID</a>; typedef <a href=“libxml2-tree.html#xmlParserCtxt”>xmlParserCtxt</a> * <a href=“#xmlParserCtxtPtr”>xmlParserCtxtPtr</a>; typedef <a href=“libxml2-tree.html#xmlEntity”>xmlEntity</a> * <a href=“#xmlEntityPtr”>xmlEntityPtr</a>; typedef struct _xmlEnumeration <a href=“#xmlEnumeration”>xmlEnumeration</a>; typedef enum <a href=“#xmlAttributeType”>xmlAttributeType</a>; typedef <a href=“libxml2-tree.html#xmlNs”>xmlNs</a> * <a href=“#xmlNsPtr”>xmlNsPtr</a>; typedef <a href=“libxml2-tree.html#xmlParserInputBuffer”>xmlParserInputBuffer</a> * <a href=“#xmlParserInputBufferPtr”>xmlParserInputBufferPtr</a>; typedef struct _xmlSAXHandler <a href=“#xmlSAXHandler”>xmlSAXHandler</a>; typedef struct _xmlOutputBuffer <a href=“#xmlOutputBuffer”>xmlOutputBuffer</a>; typedef struct _xmlSAXLocator <a href=“#xmlSAXLocator”>xmlSAXLocator</a>; typedef <a href=“libxml2-tree.html#xmlElementContent”>xmlElementContent</a> * <a href=“#xmlElementContentPtr”>xmlElementContentPtr</a>; typedef enum <a href=“#xmlElementContentType”>xmlElementContentType</a>; typedef enum <a href=“#xmlDocProperties”>xmlDocProperties</a>; typedef <a href=“libxml2-tree.html#xmlID”>xmlID</a> * <a href=“#xmlIDPtr”>xmlIDPtr</a>; typedef struct _xmlDtd <a href=“#xmlDtd”>xmlDtd</a>; typedef struct _xmlAttribute <a href=“#xmlAttribute”>xmlAttribute</a>; typedef <a href=“libxml2-tree.html#xmlOutputBuffer”>xmlOutputBuffer</a> * <a href=“#xmlOutputBufferPtr”>xmlOutputBufferPtr</a>; typedef <a href=“libxml2-tree.html#xmlSAXHandler”>xmlSAXHandler</a> * <a href=“#xmlSAXHandlerPtr”>xmlSAXHandlerPtr</a>; <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlDocCopyNode”>xmlDocCopyNode</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> node, <br/> <a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc, <br/> int extended); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlNewDocRawNode”>xmlNewDocRawNode</a> (<a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc, <br/> <a href=“libxml2-tree.html#xmlNsPtr”>xmlNsPtr</a> ns, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * content); <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * <a href=“#xmlBufContent”>xmlBufContent</a> (const <a href=“libxml2-tree.html#xmlBuf”>xmlBuf</a> * buf); <a href=“libxml2-tree.html#xmlAttrPtr”>xmlAttrPtr</a> <a href=“#xmlNewNsPropEatName”>xmlNewNsPropEatName</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> node, <br/> <a href=“libxml2-tree.html#xmlNsPtr”>xmlNsPtr</a> ns, <br/> <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * value); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlStringGetNodeList”>xmlStringGetNodeList</a> (const <a href=“libxml2-tree.html#xmlDoc”>xmlDoc</a> * doc, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * value); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlNewCDataBlock”>xmlNewCDataBlock</a> (<a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * content, <br/> int len); void <a href=“#xmlBufferWriteCHAR”>xmlBufferWriteCHAR</a> (<a href=“libxml2-tree.html#xmlBufferPtr”>xmlBufferPtr</a> buf, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * string); <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * <a href=“#xmlNodeGetBase”>xmlNodeGetBase</a> (const <a href=“libxml2-tree.html#xmlDoc”>xmlDoc</a> * doc, <br/> const <a href=“libxml2-tree.html#xmlNode”>xmlNode</a> * cur); void <a href=“#xmlBufferEmpty”>xmlBufferEmpty</a> (<a href=“libxml2-tree.html#xmlBufferPtr”>xmlBufferPtr</a> buf); <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * <a href=“#xmlBuildQName”>xmlBuildQName</a> (const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * ncname, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * prefix, <br/> <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * memory, <br/> int len); int <a href=“#xmlValidateNMToken”>xmlValidateNMToken</a> (const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * value, <br/> int space); int <a href=“#xmlSaveFormatFileEnc”>xmlSaveFormatFileEnc</a> (const char * filename, <br/> <a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> cur, <br/> const char * encoding, <br/> int format); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlAddSibling”>xmlAddSibling</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> cur, <br/> <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> elem); <a href=“libxml2-tree.html#xmlBufferPtr”>xmlBufferPtr</a> <a href=“#xmlBufferCreate”>xmlBufferCreate</a> (void); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlNewDocFragment”>xmlNewDocFragment</a> (<a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlDocGetRootElement”>xmlDocGetRootElement</a> (const <a href=“libxml2-tree.html#xmlDoc”>xmlDoc</a> * doc); <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * <a href=“#xmlGetProp”>xmlGetProp</a> (const <a href=“libxml2-tree.html#xmlNode”>xmlNode</a> * node, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name); int <a href=“#xmlValidateName”>xmlValidateName</a> (const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * value, <br/> int space); <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * <a href=“#xmlBufEnd”>xmlBufEnd</a> (<a href=“libxml2-tree.html#xmlBufPtr”>xmlBufPtr</a> buf); int <a href=“#xmlValidateQName”>xmlValidateQName</a> (const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * value, <br/> int space); <a href=“libxml2-tree.html#xmlAttrPtr”>xmlAttrPtr</a> <a href=“#xmlHasNsProp”>xmlHasNsProp</a> (const <a href=“libxml2-tree.html#xmlNode”>xmlNode</a> * node, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * nameSpace); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlAddPrevSibling”>xmlAddPrevSibling</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> cur, <br/> <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> elem); int <a href=“#xmlBufferAddHead”>xmlBufferAddHead</a> (<a href=“libxml2-tree.html#xmlBufferPtr”>xmlBufferPtr</a> buf, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * str, <br/> int len); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlNewPI”>xmlNewPI</a> (const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * content); void <a href=“#xmlDocDumpFormatMemoryEnc”>xmlDocDumpFormatMemoryEnc</a> (<a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> out_doc, <br/> <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> ** doc_txt_ptr, <br/> int * doc_txt_len, <br/> const char * txt_encoding, <br/> int format); <a href=“libxml2-tree.html#xmlAttrPtr”>xmlAttrPtr</a> <a href=“#xmlSetProp”>xmlSetProp</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> node, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * value); unsigned long <a href=“#xmlChildElementCount”>xmlChildElementCount</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> parent); void <a href=“#xmlElemDump”>xmlElemDump</a> (FILE * f, <br/> <a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc, <br/> <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> cur); int <a href=“#xmlSaveFormatFileTo”>xmlSaveFormatFileTo</a> (<a href=“libxml2-tree.html#xmlOutputBufferPtr”>xmlOutputBufferPtr</a> buf, <br/> <a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> cur, <br/> const char * encoding, <br/> int format); <a href=“libxml2-tree.html#xmlDtdPtr”>xmlDtdPtr</a> <a href=“#xmlGetIntSubset”>xmlGetIntSubset</a> (const <a href=“libxml2-tree.html#xmlDoc”>xmlDoc</a> * doc); int <a href=“#xmlNodeBufGetContent”>xmlNodeBufGetContent</a> (<a href=“libxml2-tree.html#xmlBufferPtr”>xmlBufferPtr</a> buffer, <br/> const <a href=“libxml2-tree.html#xmlNode”>xmlNode</a> * cur); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlNextElementSibling”>xmlNextElementSibling</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> node); void <a href=“#xmlBufferWriteChar”>xmlBufferWriteChar</a> (<a href=“libxml2-tree.html#xmlBufferPtr”>xmlBufferPtr</a> buf, <br/> const char * string); void <a href=“#xmlBufferFree”>xmlBufferFree</a> (<a href=“libxml2-tree.html#xmlBufferPtr”>xmlBufferPtr</a> buf); int <a href=“#xmlDOMWrapCloneNode”>xmlDOMWrapCloneNode</a> (<a href=“libxml2-tree.html#xmlDOMWrapCtxtPtr”>xmlDOMWrapCtxtPtr</a> ctxt, <br/> <a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> sourceDoc, <br/> <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> node, <br/> <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> * resNode, <br/> <a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> destDoc, <br/> <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> destParent, <br/> int deep, <br/> int options); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlNewNode”>xmlNewNode</a> (<a href=“libxml2-tree.html#xmlNsPtr”>xmlNsPtr</a> ns, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name); int <a href=“#xmlSaveFileTo”>xmlSaveFileTo</a> (<a href=“libxml2-tree.html#xmlOutputBufferPtr”>xmlOutputBufferPtr</a> buf, <br/> <a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> cur, <br/> const char * encoding); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlNewTextLen”>xmlNewTextLen</a> (const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * content, <br/> int len); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlNewTextChild”>xmlNewTextChild</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> parent, <br/> <a href=“libxml2-tree.html#xmlNsPtr”>xmlNsPtr</a> ns, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * content); void <a href=“#xmlNodeSetContent”>xmlNodeSetContent</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> cur, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * content); int <a href=“#xmlBufferAdd”>xmlBufferAdd</a> (<a href=“libxml2-tree.html#xmlBufferPtr”>xmlBufferPtr</a> buf, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * str, <br/> int len); void <a href=“#xmlNodeDumpOutput”>xmlNodeDumpOutput</a> (<a href=“libxml2-tree.html#xmlOutputBufferPtr”>xmlOutputBufferPtr</a> buf, <br/> <a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc, <br/> <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> cur, <br/> int level, <br/> int format, <br/> const char * encoding); <a href=“libxml2-tree.html#xmlNsPtr”>xmlNsPtr</a> <a href=“#xmlCopyNamespace”>xmlCopyNamespace</a> (<a href=“libxml2-tree.html#xmlNsPtr”>xmlNsPtr</a> cur); <a href=“libxml2-tree.html#xmlNsPtr”>xmlNsPtr</a> <a href=“#xmlSearchNsByHref”>xmlSearchNsByHref</a> (<a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc, <br/> <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> node, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * href); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlAddChild”>xmlAddChild</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> parent, <br/> <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> cur); int <a href=“#xmlReconciliateNs”>xmlReconciliateNs</a> (<a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc, <br/> <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> tree); int <a href=“#xmlValidateNCName”>xmlValidateNCName</a> (const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * value, <br/> int space); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlNewDocComment”>xmlNewDocComment</a> (<a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * content); int <a href=“#xmlGetCompressMode”>xmlGetCompressMode</a> (void); int <a href=“#xmlNodeDump”>xmlNodeDump</a> (<a href=“libxml2-tree.html#xmlBufferPtr”>xmlBufferPtr</a> buf, <br/> <a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc, <br/> <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> cur, <br/> int level, <br/> int format); <a href=“libxml2-tree.html#xmlBufferPtr”>xmlBufferPtr</a> <a href=“#xmlBufferCreateSize”>xmlBufferCreateSize</a> (size_t size); <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * <a href=“#xmlNodeListGetString”>xmlNodeListGetString</a> (<a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc, <br/> const <a href=“libxml2-tree.html#xmlNode”>xmlNode</a> * list, <br/> int inLine); void <a href=“#xmlSetCompressMode”>xmlSetCompressMode</a> (int mode); void <a href=“#xmlSetTreeDoc”>xmlSetTreeDoc</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> tree, <br/> <a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc); int <a href=“#xmlDOMWrapAdoptNode”>xmlDOMWrapAdoptNode</a> (<a href=“libxml2-tree.html#xmlDOMWrapCtxtPtr”>xmlDOMWrapCtxtPtr</a> ctxt, <br/> <a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> sourceDoc, <br/> <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> node, <br/> <a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> destDoc, <br/> <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> destParent, <br/> int options); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlCopyNodeList”>xmlCopyNodeList</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> node); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlNewDocNodeEatName”>xmlNewDocNodeEatName</a> (<a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc, <br/> <a href=“libxml2-tree.html#xmlNsPtr”>xmlNsPtr</a> ns, <br/> <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * content); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlAddChildList”>xmlAddChildList</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> parent, <br/> <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> cur); <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * <a href=“#xmlGetNodePath”>xmlGetNodePath</a> (const <a href=“libxml2-tree.html#xmlNode”>xmlNode</a> * node); void <a href=“#xmlFreePropList”>xmlFreePropList</a> (<a href=“libxml2-tree.html#xmlAttrPtr”>xmlAttrPtr</a> cur); void <a href=“#xmlNodeAddContent”>xmlNodeAddContent</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> cur, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * content); int <a href=“#xmlUnsetNsProp”>xmlUnsetNsProp</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> node, <br/> <a href=“libxml2-tree.html#xmlNsPtr”>xmlNsPtr</a> ns, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlFirstElementChild”>xmlFirstElementChild</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> parent); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlAddNextSibling”>xmlAddNextSibling</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> cur, <br/> <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> elem); int <a href=“#xmlIsBlankNode”>xmlIsBlankNode</a> (const <a href=“libxml2-tree.html#xmlNode”>xmlNode</a> * node); <a href=“libxml2-tree.html#xmlNsPtr”>xmlNsPtr</a> <a href=“#xmlNewGlobalNs”>xmlNewGlobalNs</a> (<a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * href, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * prefix); int <a href=“#xmlBufferDump”>xmlBufferDump</a> (FILE * file, <br/> <a href=“libxml2-tree.html#xmlBufferPtr”>xmlBufferPtr</a> buf); <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * <a href=“#xmlNodeGetContent”>xmlNodeGetContent</a> (const <a href=“libxml2-tree.html#xmlNode”>xmlNode</a> * cur); <a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> <a href=“#xmlCopyDoc”>xmlCopyDoc</a> (<a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc, <br/> int recursive); <a href=“libxml2-tree.html#xmlDOMWrapCtxtPtr”>xmlDOMWrapCtxtPtr</a> <a href=“#xmlDOMWrapNewCtxt”>xmlDOMWrapNewCtxt</a> (void); void <a href=“#xmlDocDumpMemoryEnc”>xmlDocDumpMemoryEnc</a> (<a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> out_doc, <br/> <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> ** doc_txt_ptr, <br/> int * doc_txt_len, <br/> const char * txt_encoding); int <a href=“#xmlBufGetNodeContent”>xmlBufGetNodeContent</a> (<a href=“libxml2-tree.html#xmlBufPtr”>xmlBufPtr</a> buf, <br/> const <a href=“libxml2-tree.html#xmlNode”>xmlNode</a> * cur); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlTextMerge”>xmlTextMerge</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> first, <br/> <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> second); void <a href=“#xmlDocDumpMemory”>xmlDocDumpMemory</a> (<a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> cur, <br/> <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> ** mem, <br/> int * size); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlNewDocPI”>xmlNewDocPI</a> (<a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * content); void <a href=“#xmlFreeNs”>xmlFreeNs</a> (<a href=“libxml2-tree.html#xmlNsPtr”>xmlNsPtr</a> cur); int <a href=“#xmlDocDump”>xmlDocDump</a> (FILE * f, <br/> <a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> cur); void <a href=“#xmlFreeProp”>xmlFreeProp</a> (<a href=“libxml2-tree.html#xmlAttrPtr”>xmlAttrPtr</a> cur); <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * <a href=“#xmlGetNoNsProp”>xmlGetNoNsProp</a> (const <a href=“libxml2-tree.html#xmlNode”>xmlNode</a> * node, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name); <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * <a href=“#xmlSplitQName2”>xmlSplitQName2</a> (const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name, <br/> <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> ** prefix); <a href=“libxml2-tree.html#xmlAttrPtr”>xmlAttrPtr</a> <a href=“#xmlNewProp”>xmlNewProp</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> node, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * value); int <a href=“#xmlTextConcat”>xmlTextConcat</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> node, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * content, <br/> int len); int <a href=“#xmlNodeGetSpacePreserve”>xmlNodeGetSpacePreserve</a> (const <a href=“libxml2-tree.html#xmlNode”>xmlNode</a> * cur); int <a href=“#xmlBufferShrink”>xmlBufferShrink</a> (<a href=“libxml2-tree.html#xmlBufferPtr”>xmlBufferPtr</a> buf, <br/> unsigned int len); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlPreviousElementSibling”>xmlPreviousElementSibling</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> node); void <a href=“#xmlNodeSetContentLen”>xmlNodeSetContentLen</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> cur, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * content, <br/> int len); void <a href=“#xmlNodeAddContentLen”>xmlNodeAddContentLen</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> cur, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * content, <br/> int len); void <a href=“#xmlBufferWriteQuotedString”>xmlBufferWriteQuotedString</a> (<a href=“libxml2-tree.html#xmlBufferPtr”>xmlBufferPtr</a> buf, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * string); <a href=“libxml2-tree.html#xmlAttrPtr”>xmlAttrPtr</a> <a href=“#xmlCopyProp”>xmlCopyProp</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> target, <br/> <a href=“libxml2-tree.html#xmlAttrPtr”>xmlAttrPtr</a> cur); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlReplaceNode”>xmlReplaceNode</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> old, <br/> <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> cur); void <a href=“#xmlSetDocCompressMode”>xmlSetDocCompressMode</a> (<a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc, <br/> int mode); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlCopyNode”>xmlCopyNode</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> node, <br/> int extended); void <a href=“#xmlUnlinkNode”>xmlUnlinkNode</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> cur); const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * <a href=“#xmlSplitQName3”>xmlSplitQName3</a> (const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name, <br/> int * len); typedef <a href=“libxml2-tree.html#xmlNsPtr”>xmlNsPtr</a> <a href=“#xmlDOMWrapAcquireNsFunction”>xmlDOMWrapAcquireNsFunction</a> (<a href=“libxml2-tree.html#xmlDOMWrapCtxtPtr”>xmlDOMWrapCtxtPtr</a> ctxt, <br/> <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> node, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * nsName, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * nsPrefix); size_t <a href=“#xmlBufUse”>xmlBufUse</a> (const <a href=“libxml2-tree.html#xmlBufPtr”>xmlBufPtr</a> buf); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlDocSetRootElement”>xmlDocSetRootElement</a> (<a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc, <br/> <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> root); long <a href=“#xmlGetLineNo”>xmlGetLineNo</a> (const <a href=“libxml2-tree.html#xmlNode”>xmlNode</a> * node); const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * <a href=“#xmlBufferContent”>xmlBufferContent</a> (const <a href=“libxml2-tree.html#xmlBuffer”>xmlBuffer</a> * buf); int <a href=“#xmlRemoveProp”>xmlRemoveProp</a> (<a href=“libxml2-tree.html#xmlAttrPtr”>xmlAttrPtr</a> cur); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlLastElementChild”>xmlLastElementChild</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> parent); <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * <a href=“#xmlNodeGetLang”>xmlNodeGetLang</a> (const <a href=“libxml2-tree.html#xmlNode”>xmlNode</a> * cur); int <a href=“#xmlGetDocCompressMode”>xmlGetDocCompressMode</a> (const <a href=“libxml2-tree.html#xmlDoc”>xmlDoc</a> * doc); size_t <a href=“#xmlBufNodeDump”>xmlBufNodeDump</a> (<a href=“libxml2-tree.html#xmlBufPtr”>xmlBufPtr</a> buf, <br/> <a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc, <br/> <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> cur, <br/> int level, <br/> int format); <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * <a href=“#xmlGetNsProp”>xmlGetNsProp</a> (const <a href=“libxml2-tree.html#xmlNode”>xmlNode</a> * node, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * nameSpace); <a href=“libxml2-tree.html#xmlAttrPtr”>xmlAttrPtr</a> <a href=“#xmlNewDocProp”>xmlNewDocProp</a> (<a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * value); void <a href=“#xmlFreeNode”>xmlFreeNode</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> cur); <a href=“libxml2-tree.html#xmlAttrPtr”>xmlAttrPtr</a> <a href=“#xmlNewNsProp”>xmlNewNsProp</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> node, <br/> <a href=“libxml2-tree.html#xmlNsPtr”>xmlNsPtr</a> ns, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * value); void <a href=“#xmlDOMWrapFreeCtxt”>xmlDOMWrapFreeCtxt</a> (<a href=“libxml2-tree.html#xmlDOMWrapCtxtPtr”>xmlDOMWrapCtxtPtr</a> ctxt); <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * <a href=“#xmlBufferDetach”>xmlBufferDetach</a> (<a href=“libxml2-tree.html#xmlBufferPtr”>xmlBufferPtr</a> buf); void <a href=“#xmlBufferSetAllocationScheme”>xmlBufferSetAllocationScheme</a> (<a href=“libxml2-tree.html#xmlBufferPtr”>xmlBufferPtr</a> buf, <br/> <a href=“libxml2-tree.html#xmlBufferAllocationScheme”>xmlBufferAllocationScheme</a> scheme); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlNewChild”>xmlNewChild</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> parent, <br/> <a href=“libxml2-tree.html#xmlNsPtr”>xmlNsPtr</a> ns, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * content); <a href=“libxml2-tree.html#xmlNsPtr”>xmlNsPtr</a> <a href=“#xmlSearchNs”>xmlSearchNs</a> (<a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc, <br/> <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> node, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * nameSpace); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlStringLenGetNodeList”>xmlStringLenGetNodeList</a> (const <a href=“libxml2-tree.html#xmlDoc”>xmlDoc</a> * doc, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * value, <br/> int len); int <a href=“#xmlSaveFormatFile”>xmlSaveFormatFile</a> (const char * filename, <br/> <a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> cur, <br/> int format); <a href=“libxml2-tree.html#xmlAttrPtr”>xmlAttrPtr</a> <a href=“#xmlCopyPropList”>xmlCopyPropList</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> target, <br/> <a href=“libxml2-tree.html#xmlAttrPtr”>xmlAttrPtr</a> cur); int <a href=“#xmlDocFormatDump”>xmlDocFormatDump</a> (FILE * f, <br/> <a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> cur, <br/> int format); void <a href=“#xmlNodeSetSpacePreserve”>xmlNodeSetSpacePreserve</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> cur, <br/> int val); <a href=“libxml2-tree.html#xmlAttrPtr”>xmlAttrPtr</a> <a href=“#xmlHasProp”>xmlHasProp</a> (const <a href=“libxml2-tree.html#xmlNode”>xmlNode</a> * node, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name); int <a href=“#xmlBufferCat”>xmlBufferCat</a> (<a href=“libxml2-tree.html#xmlBufferPtr”>xmlBufferPtr</a> buf, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * str); <a href=“libxml2-tree.html#xmlDtdPtr”>xmlDtdPtr</a> <a href=“#xmlCreateIntSubset”>xmlCreateIntSubset</a> (<a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * ExternalID, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * SystemID); <a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> <a href=“#xmlNewDoc”>xmlNewDoc</a> (const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * version); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlNewCharRef”>xmlNewCharRef</a> (<a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name); <a href=“libxml2-tree.html#xmlNsPtr”>xmlNsPtr</a> <a href=“#xmlCopyNamespaceList”>xmlCopyNamespaceList</a> (<a href=“libxml2-tree.html#xmlNsPtr”>xmlNsPtr</a> cur); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlNewNodeEatName”>xmlNewNodeEatName</a> (<a href=“libxml2-tree.html#xmlNsPtr”>xmlNsPtr</a> ns, <br/> <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name); int <a href=“#xmlBufferResize”>xmlBufferResize</a> (<a href=“libxml2-tree.html#xmlBufferPtr”>xmlBufferPtr</a> buf, <br/> unsigned int size); void <a href=“#xmlNodeSetBase”>xmlNodeSetBase</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> cur, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * uri); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlNewComment”>xmlNewComment</a> (const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * content); int <a href=“#xmlBufferLength”>xmlBufferLength</a> (const <a href=“libxml2-tree.html#xmlBuffer”>xmlBuffer</a> * buf); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlNewText”>xmlNewText</a> (const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * content); int <a href=“#xmlUnsetProp”>xmlUnsetProp</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> node, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name); <a href=“libxml2-tree.html#xmlBufferAllocationScheme”>xmlBufferAllocationScheme</a> <a href=“#xmlGetBufferAllocationScheme”>xmlGetBufferAllocationScheme</a> (void); int <a href=“#xmlSaveFile”>xmlSaveFile</a> (const char * filename, <br/> <a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> cur); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlDocCopyNodeList”>xmlDocCopyNodeList</a> (<a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc, <br/> <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> node); void <a href=“#xmlSetNs”>xmlSetNs</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> node, <br/> <a href=“libxml2-tree.html#xmlNsPtr”>xmlNsPtr</a> ns); <a href=“libxml2-tree.html#xmlNsPtr”>xmlNsPtr</a> <a href=“#xmlNewNs”>xmlNewNs</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> node, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * href, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * prefix); int <a href=“#xmlDOMWrapRemoveNode”>xmlDOMWrapRemoveNode</a> (<a href=“libxml2-tree.html#xmlDOMWrapCtxtPtr”>xmlDOMWrapCtxtPtr</a> ctxt, <br/> <a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc, <br/> <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> node, <br/> int options); void <a href=“#xmlAttrSerializeTxtContent”>xmlAttrSerializeTxtContent</a> (<a href=“libxml2-tree.html#xmlBufferPtr”>xmlBufferPtr</a> buf, <br/> <a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc, <br/> <a href=“libxml2-tree.html#xmlAttrPtr”>xmlAttrPtr</a> attr, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * string); <a href=“libxml2-tree.html#xmlDtdPtr”>xmlDtdPtr</a> <a href=“#xmlCopyDtd”>xmlCopyDtd</a> (<a href=“libxml2-tree.html#xmlDtdPtr”>xmlDtdPtr</a> dtd); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlNewDocText”>xmlNewDocText</a> (const <a href=“libxml2-tree.html#xmlDoc”>xmlDoc</a> * doc, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * content); <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * <a href=“#xmlNodeListGetRawString”>xmlNodeListGetRawString</a> (const <a href=“libxml2-tree.html#xmlDoc”>xmlDoc</a> * doc, <br/> const <a href=“libxml2-tree.html#xmlNode”>xmlNode</a> * list, <br/> int inLine); <a href=“libxml2-tree.html#xmlBufferPtr”>xmlBufferPtr</a> <a href=“#xmlBufferCreateStatic”>xmlBufferCreateStatic</a> (void * mem, <br/> size_t size); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlNewReference”>xmlNewReference</a> (const <a href=“libxml2-tree.html#xmlDoc”>xmlDoc</a> * doc, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name); int <a href=“#xmlDOMWrapReconcileNamespaces”>xmlDOMWrapReconcileNamespaces</a> (<a href=“libxml2-tree.html#xmlDOMWrapCtxtPtr”>xmlDOMWrapCtxtPtr</a> ctxt, <br/> <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> elem, <br/> int options); int <a href=“#xmlBufferCCat”>xmlBufferCCat</a> (<a href=“libxml2-tree.html#xmlBufferPtr”>xmlBufferPtr</a> buf, <br/> const char * str); <a href=“libxml2-tree.html#xmlNsPtr”>xmlNsPtr</a> * <a href=“#xmlGetNsList”>xmlGetNsList</a> (const <a href=“libxml2-tree.html#xmlDoc”>xmlDoc</a> * doc, <br/> const <a href=“libxml2-tree.html#xmlNode”>xmlNode</a> * node); int <a href=“#xmlBufferGrow”>xmlBufferGrow</a> (<a href=“libxml2-tree.html#xmlBufferPtr”>xmlBufferPtr</a> buf, <br/> unsigned int len); int <a href=“#xmlNodeIsText”>xmlNodeIsText</a> (const <a href=“libxml2-tree.html#xmlNode”>xmlNode</a> * node); void <a href=“#xmlSetBufferAllocationScheme”>xmlSetBufferAllocationScheme</a> (<a href=“libxml2-tree.html#xmlBufferAllocationScheme”>xmlBufferAllocationScheme</a> scheme); int <a href=“#xmlIsXHTML”>xmlIsXHTML</a> (const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * systemID, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * publicID); void <a href=“#xmlNodeSetLang”>xmlNodeSetLang</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> cur, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * lang); void <a href=“#xmlFreeDtd”>xmlFreeDtd</a> (<a href=“libxml2-tree.html#xmlDtdPtr”>xmlDtdPtr</a> cur); void <a href=“#xmlFreeNodeList”>xmlFreeNodeList</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> cur); void <a href=“#xmlFreeDoc”>xmlFreeDoc</a> (<a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> cur); size_t <a href=“#xmlBufShrink”>xmlBufShrink</a> (<a href=“libxml2-tree.html#xmlBufPtr”>xmlBufPtr</a> buf, <br/> size_t len); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlNewDocNode”>xmlNewDocNode</a> (<a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc, <br/> <a href=“libxml2-tree.html#xmlNsPtr”>xmlNsPtr</a> ns, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * content); int <a href=“#xmlSaveFileEnc”>xmlSaveFileEnc</a> (const char * filename, <br/> <a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> cur, <br/> const char * encoding); <a href=“libxml2-tree.html#xmlAttrPtr”>xmlAttrPtr</a> <a href=“#xmlSetNsProp”>xmlSetNsProp</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> node, <br/> <a href=“libxml2-tree.html#xmlNsPtr”>xmlNsPtr</a> ns, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * value); void <a href=“#xmlDocDumpFormatMemory”>xmlDocDumpFormatMemory</a> (<a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> cur, <br/> <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> ** mem, <br/> int * size, <br/> int format); void <a href=“#xmlSetListDoc”>xmlSetListDoc</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> list, <br/> <a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc); void <a href=“#xmlNodeSetName”>xmlNodeSetName</a> (<a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> cur, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlNewDocTextLen”>xmlNewDocTextLen</a> (<a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * content, <br/> int len); <a href=“libxml2-tree.html#xmlDtdPtr”>xmlDtdPtr</a> <a href=“#xmlNewDtd”>xmlNewDtd</a> (<a href=“libxml2-tree.html#xmlDocPtr”>xmlDocPtr</a> doc, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * name, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * ExternalID, <br/> const <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> * SystemID); void <a href=“#xmlFreeNsList”>xmlFreeNsList</a> (<a href=“libxml2-tree.html#xmlNsPtr”>xmlNsPtr</a> cur); <a href=“libxml2-tree.html#xmlNodePtr”>xmlNodePtr</a> <a href=“#xmlGetLastChild”>xmlGetLastChild</a> (const <a href=“libxml2-tree.html#xmlNode”>xmlNode</a> * parent); </pre>
</div> <div class="refsect1" lang="en"> <h2>Description</h2> </div> <div class="refsect1" lang="en"> <h2>Details</h2> <div class="refsect2" lang="en"> <div class="refsect2" lang="en"><h3><a name="BASE_BUFFER_SIZE">Macro </a>BASE_BUFFER_SIZE</h3><pre class="programlisting">#define <a href="#BASE_BUFFER_SIZE">BASE_BUFFER_SIZE</a>;
</pre><p>default buffer size 4000.</p> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="LIBXML2_NEW_BUFFER">Macro </a>LIBXML2_NEW_BUFFER</h3><pre class="programlisting">#define <a href="#LIBXML2_NEW_BUFFER">LIBXML2_NEW_BUFFER</a>;
</pre><p>Macro used to express that the API use the new buffers for <a href=“libxml2-tree.html#xmlParserInputBuffer”>xmlParserInputBuffer</a> and xmlOutputBuffer. The change was introduced in 2.9.0.</p> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="XML_GET_CONTENT">Macro </a>XML_GET_CONTENT</h3><pre class="programlisting">#define <a href="#XML_GET_CONTENT">XML_GET_CONTENT</a>;
</pre><p>Macro to extract the content pointer of a node.</p> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="XML_GET_LINE">Macro </a>XML_GET_LINE</h3><pre class="programlisting">#define <a href="#XML_GET_LINE">XML_GET_LINE</a>;
</pre><p>Macro to extract the line number of an element node.</p> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="XML_LOCAL_NAMESPACE">Macro </a>XML_LOCAL_NAMESPACE</h3><pre class="programlisting">#define <a href="#XML_LOCAL_NAMESPACE">XML_LOCAL_NAMESPACE</a>;
</pre><p>A namespace declaration node.</p> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="XML_XML_ID">Macro </a>XML_XML_ID</h3><pre class="programlisting">#define <a href="#XML_XML_ID">XML_XML_ID</a>;
</pre><p>This is the name for the special xml:id <a href=“libxml2-SAX.html#attribute”>attribute</a></p> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="XML_XML_NAMESPACE">Macro </a>XML_XML_NAMESPACE</h3><pre class="programlisting">#define <a href="#XML_XML_NAMESPACE">XML_XML_NAMESPACE</a>;
</pre><p>This is the namespace for the special xml: prefix predefined in the XML Namespace specification.</p> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlChildrenNode">Macro </a>xmlChildrenNode</h3><pre class="programlisting">#define <a href="#xmlChildrenNode">xmlChildrenNode</a>;
</pre><p>Macro for compatibility naming layer with libxml1. Maps to “children.”</p> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlRootNode">Macro </a>xmlRootNode</h3><pre class="programlisting">#define <a href="#xmlRootNode">xmlRootNode</a>;
</pre><p>Macro for compatibility naming layer with libxml1. Maps to “children”.</p> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlAttr">Structure </a>xmlAttr</h3><pre class="programlisting">struct _xmlAttr { void * _private : application data <a href="libxml2-tree.html#xmlElementType">xmlElementType</a> type : XML_ATTRIBUTE_NODE, must be second ! const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * 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 <a href="libxml2-tree.html#xmlNs">xmlNs</a> * ns : pointer to the associated namespace <a href="libxml2-tree.html#xmlAttributeType">xmlAttributeType</a> atype : the <a href="libxml2-SAX.html#attribute">attribute</a> type if validating void * psvi : for type/PSVI informations
} xmlAttr; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlAttrPtr">Typedef </a>xmlAttrPtr</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlAttr">xmlAttr</a> * xmlAttrPtr;
</pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlAttribute">Structure </a>xmlAttribute</h3><pre class="programlisting">struct _xmlAttribute { void * _private : application data <a href="libxml2-tree.html#xmlElementType">xmlElementType</a> type : XML_ATTRIBUTE_DECL, must be second ! const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * 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 <a href="libxml2-tree.html#xmlAttributeType">xmlAttributeType</a> atype : The <a href="libxml2-SAX.html#attribute">attribute</a> type <a href="libxml2-tree.html#xmlAttributeDefault">xmlAttributeDefault</a> def : the default const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * defaultValue : or the default value <a href="libxml2-tree.html#xmlEnumerationPtr">xmlEnumerationPtr</a> tree : or the enumeration tree if any const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * prefix : the namespace prefix if any const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * elem : Element holding the <a href="libxml2-SAX.html#attribute">attribute</a>
} xmlAttribute; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlAttributeDefault">Enum </a>xmlAttributeDefault</h3><pre class="programlisting">enum <a href="#xmlAttributeDefault">xmlAttributeDefault</a> { <a name="XML_ATTRIBUTE_NONE">XML_ATTRIBUTE_NONE</a> = 1 <a name="XML_ATTRIBUTE_REQUIRED">XML_ATTRIBUTE_REQUIRED</a> = 2 <a name="XML_ATTRIBUTE_IMPLIED">XML_ATTRIBUTE_IMPLIED</a> = 3 <a name="XML_ATTRIBUTE_FIXED">XML_ATTRIBUTE_FIXED</a> = 4
}; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlAttributePtr">Typedef </a>xmlAttributePtr</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlAttribute">xmlAttribute</a> * xmlAttributePtr;
</pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlAttributeType">Enum </a>xmlAttributeType</h3><pre class="programlisting">enum <a href="#xmlAttributeType">xmlAttributeType</a> { <a name="XML_ATTRIBUTE_CDATA">XML_ATTRIBUTE_CDATA</a> = 1 <a name="XML_ATTRIBUTE_ID">XML_ATTRIBUTE_ID</a> = 2 <a name="XML_ATTRIBUTE_IDREF">XML_ATTRIBUTE_IDREF</a> = 3 <a name="XML_ATTRIBUTE_IDREFS">XML_ATTRIBUTE_IDREFS</a> = 4 <a name="XML_ATTRIBUTE_ENTITY">XML_ATTRIBUTE_ENTITY</a> = 5 <a name="XML_ATTRIBUTE_ENTITIES">XML_ATTRIBUTE_ENTITIES</a> = 6 <a name="XML_ATTRIBUTE_NMTOKEN">XML_ATTRIBUTE_NMTOKEN</a> = 7 <a name="XML_ATTRIBUTE_NMTOKENS">XML_ATTRIBUTE_NMTOKENS</a> = 8 <a name="XML_ATTRIBUTE_ENUMERATION">XML_ATTRIBUTE_ENUMERATION</a> = 9 <a name="XML_ATTRIBUTE_NOTATION">XML_ATTRIBUTE_NOTATION</a> = 10
}; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBuf">Structure </a>xmlBuf</h3><pre class="programlisting">struct _xmlBuf {
The content of this structure is not made public by the API. } xmlBuf; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufPtr">Typedef </a>xmlBufPtr</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlBuf">xmlBuf</a> * xmlBufPtr;
</pre><p>A pointer to a buffer structure, the actual structure internals are not public</p> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBuffer">Structure </a>xmlBuffer</h3><pre class="programlisting">struct _xmlBuffer { <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * content : The buffer content UTF8 unsigned int use : The buffer size used unsigned int size : The buffer size <a href="libxml2-tree.html#xmlBufferAllocationScheme">xmlBufferAllocationScheme</a> alloc : The realloc method <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * contentIO : in IO mode we may have a different base
} xmlBuffer; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufferAllocationScheme">Enum </a>xmlBufferAllocationScheme</h3><pre class="programlisting">enum <a href="#xmlBufferAllocationScheme">xmlBufferAllocationScheme</a> { <a name="XML_BUFFER_ALLOC_DOUBLEIT">XML_BUFFER_ALLOC_DOUBLEIT</a> = 1 double each time one need to grow <a name="XML_BUFFER_ALLOC_EXACT">XML_BUFFER_ALLOC_EXACT</a> = 2 grow only to the minimal size <a name="XML_BUFFER_ALLOC_IMMUTABLE">XML_BUFFER_ALLOC_IMMUTABLE</a> = 3 /* immutable buffer */ <a name="XML_BUFFER_ALLOC_IO">XML_BUFFER_ALLOC_IO</a> = 4 /* special allocation scheme used for I/O */ <a name="XML_BUFFER_ALLOC_HYBRID">XML_BUFFER_ALLOC_HYBRID</a> = 5 /* exact up to a threshold, and doubleit thereafter */ <a name="XML_BUFFER_ALLOC_BOUNDED">XML_BUFFER_ALLOC_BOUNDED</a> = 6 /* limit the upper size of the buffer */
}; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufferPtr">Typedef </a>xmlBufferPtr</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlBuffer">xmlBuffer</a> * xmlBufferPtr;
</pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlDOMWrapCtxt">Structure </a>xmlDOMWrapCtxt</h3><pre class="programlisting">struct _xmlDOMWrapCtxt { void * _private : * The type of this context, just in case we need specialized * context int type : * Internal namespace map used for various operations. * void * namespaceMap : * Use this one to acquire an <a href="libxml2-tree.html#xmlNsPtr">xmlNsPtr</a> intended for node->ns. * (Note t <a href="libxml2-tree.html#xmlDOMWrapAcquireNsFunction">xmlDOMWrapAcquireNsFunction</a> getNsForNodeFunc
} xmlDOMWrapCtxt; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlDOMWrapCtxtPtr">Typedef </a>xmlDOMWrapCtxtPtr</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlDOMWrapCtxt">xmlDOMWrapCtxt</a> * xmlDOMWrapCtxtPtr;
</pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlDoc">Structure </a>xmlDoc</h3><pre class="programlisting">struct _xmlDoc { void * _private : application data <a href="libxml2-tree.html#xmlElementType">xmlElementType</a> 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 sta struct _xmlDtd * intSubset : the document internal subset struct _xmlDtd * extSubset : the document external subset struct _xmlNs * oldNs : Global namespace, the old way const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * version : the XML version string const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * 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 <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * URL : The URI for that document int charset : Internal flag for charset handling, actually an <a href="libxml2-encoding.html#xmlCharEncoding">xmlCharEncoding</a> struct _xmlDict * dict : dict used to allocate names or NULL void * psvi : for type/PSVI informations int parseFlags : set of <a href="libxml2-parser.html#xmlParserOption">xmlParserOption</a> used to parse the document int properties : set of <a href="libxml2-tree.html#xmlDocProperties">xmlDocProperties</a> for this document set at the end of parsing
} xmlDoc; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlDocProperties">Enum </a>xmlDocProperties</h3><pre class="programlisting">enum <a href="#xmlDocProperties">xmlDocProperties</a> { <a name="XML_DOC_WELLFORMED">XML_DOC_WELLFORMED</a> = 1 /* document is XML well formed */ <a name="XML_DOC_NSVALID">XML_DOC_NSVALID</a> = 2 /* document is Namespace valid */ <a name="XML_DOC_OLD10">XML_DOC_OLD10</a> = 4 /* parsed with old XML-1.0 parser */ <a name="XML_DOC_DTDVALID">XML_DOC_DTDVALID</a> = 8 /* DTD validation was successful */ <a name="XML_DOC_XINCLUDE">XML_DOC_XINCLUDE</a> = 16 /* XInclude substitution was done */ <a name="XML_DOC_USERBUILT">XML_DOC_USERBUILT</a> = 32 /* Document was built using the API and not by parsing an instance */ <a name="XML_DOC_INTERNAL">XML_DOC_INTERNAL</a> = 64 /* built for internal processing */ <a name="XML_DOC_HTML">XML_DOC_HTML</a> = 128 /* parsed or built HTML document */
}; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlDocPtr">Typedef </a>xmlDocPtr</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlDoc">xmlDoc</a> * xmlDocPtr;
</pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlDtd">Structure </a>xmlDtd</h3><pre class="programlisting">struct _xmlDtd { void * _private : application data <a href="libxml2-tree.html#xmlElementType">xmlElementType</a> type : XML_DTD_NODE, must be second ! const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * 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 <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * ExternalID : External identifier for PUBLIC DTD const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * SystemID : URI for a SYSTEM or PUBLIC DTD void * pentities : Hash table for param entities if any
} xmlDtd; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlDtdPtr">Typedef </a>xmlDtdPtr</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlDtd">xmlDtd</a> * xmlDtdPtr;
</pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlElement">Structure </a>xmlElement</h3><pre class="programlisting">struct _xmlElement { void * _private : application data <a href="libxml2-tree.html#xmlElementType">xmlElementType</a> type : XML_ELEMENT_DECL, must be second ! const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * 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 <a href="libxml2-tree.html#xmlElementTypeVal">xmlElementTypeVal</a> etype : The type <a href="libxml2-tree.html#xmlElementContentPtr">xmlElementContentPtr</a> content : the allowed element content <a href="libxml2-tree.html#xmlAttributePtr">xmlAttributePtr</a> attributes : List of the declared attributes const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * prefix : the namespace prefix if any <a href="libxml2-xmlregexp.html#xmlRegexpPtr">xmlRegexpPtr</a> contModel : the validating regexp void * contModel
} xmlElement; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlElementContent">Structure </a>xmlElementContent</h3><pre class="programlisting">struct _xmlElementContent { <a href="libxml2-tree.html#xmlElementContentType">xmlElementContentType</a> type : PCDATA, ELEMENT, SEQ or OR <a href="libxml2-tree.html#xmlElementContentOccur">xmlElementContentOccur</a> ocur : ONCE, OPT, MULT or PLUS const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name : Element name struct _xmlElementContent * c1 : first child struct _xmlElementContent * c2 : second child struct _xmlElementContent * parent : parent const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * prefix : Namespace prefix
} xmlElementContent; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlElementContentOccur">Enum </a>xmlElementContentOccur</h3><pre class="programlisting">enum <a href="#xmlElementContentOccur">xmlElementContentOccur</a> { <a name="XML_ELEMENT_CONTENT_ONCE">XML_ELEMENT_CONTENT_ONCE</a> = 1 <a name="XML_ELEMENT_CONTENT_OPT">XML_ELEMENT_CONTENT_OPT</a> = 2 <a name="XML_ELEMENT_CONTENT_MULT">XML_ELEMENT_CONTENT_MULT</a> = 3 <a name="XML_ELEMENT_CONTENT_PLUS">XML_ELEMENT_CONTENT_PLUS</a> = 4
}; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlElementContentPtr">Typedef </a>xmlElementContentPtr</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlElementContent">xmlElementContent</a> * xmlElementContentPtr;
</pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlElementContentType">Enum </a>xmlElementContentType</h3><pre class="programlisting">enum <a href="#xmlElementContentType">xmlElementContentType</a> { <a name="XML_ELEMENT_CONTENT_PCDATA">XML_ELEMENT_CONTENT_PCDATA</a> = 1 <a name="XML_ELEMENT_CONTENT_ELEMENT">XML_ELEMENT_CONTENT_ELEMENT</a> = 2 <a name="XML_ELEMENT_CONTENT_SEQ">XML_ELEMENT_CONTENT_SEQ</a> = 3 <a name="XML_ELEMENT_CONTENT_OR">XML_ELEMENT_CONTENT_OR</a> = 4
}; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlElementPtr">Typedef </a>xmlElementPtr</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlElement">xmlElement</a> * xmlElementPtr;
</pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlElementType">Enum </a>xmlElementType</h3><pre class="programlisting">enum <a href="#xmlElementType">xmlElementType</a> { <a name="XML_ELEMENT_NODE">XML_ELEMENT_NODE</a> = 1 <a name="XML_ATTRIBUTE_NODE">XML_ATTRIBUTE_NODE</a> = 2 <a name="XML_TEXT_NODE">XML_TEXT_NODE</a> = 3 <a name="XML_CDATA_SECTION_NODE">XML_CDATA_SECTION_NODE</a> = 4 <a name="XML_ENTITY_REF_NODE">XML_ENTITY_REF_NODE</a> = 5 <a name="XML_ENTITY_NODE">XML_ENTITY_NODE</a> = 6 <a name="XML_PI_NODE">XML_PI_NODE</a> = 7 <a name="XML_COMMENT_NODE">XML_COMMENT_NODE</a> = 8 <a name="XML_DOCUMENT_NODE">XML_DOCUMENT_NODE</a> = 9 <a name="XML_DOCUMENT_TYPE_NODE">XML_DOCUMENT_TYPE_NODE</a> = 10 <a name="XML_DOCUMENT_FRAG_NODE">XML_DOCUMENT_FRAG_NODE</a> = 11 <a name="XML_NOTATION_NODE">XML_NOTATION_NODE</a> = 12 <a name="XML_HTML_DOCUMENT_NODE">XML_HTML_DOCUMENT_NODE</a> = 13 <a name="XML_DTD_NODE">XML_DTD_NODE</a> = 14 <a name="XML_ELEMENT_DECL">XML_ELEMENT_DECL</a> = 15 <a name="XML_ATTRIBUTE_DECL">XML_ATTRIBUTE_DECL</a> = 16 <a name="XML_ENTITY_DECL">XML_ENTITY_DECL</a> = 17 <a name="XML_NAMESPACE_DECL">XML_NAMESPACE_DECL</a> = 18 <a name="XML_XINCLUDE_START">XML_XINCLUDE_START</a> = 19 <a name="XML_XINCLUDE_END">XML_XINCLUDE_END</a> = 20 <a name="XML_DOCB_DOCUMENT_NODE">XML_DOCB_DOCUMENT_NODE</a> = 21
}; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlElementTypeVal">Enum </a>xmlElementTypeVal</h3><pre class="programlisting">enum <a href="#xmlElementTypeVal">xmlElementTypeVal</a> { <a name="XML_ELEMENT_TYPE_UNDEFINED">XML_ELEMENT_TYPE_UNDEFINED</a> = 0 <a name="XML_ELEMENT_TYPE_EMPTY">XML_ELEMENT_TYPE_EMPTY</a> = 1 <a name="XML_ELEMENT_TYPE_ANY">XML_ELEMENT_TYPE_ANY</a> = 2 <a name="XML_ELEMENT_TYPE_MIXED">XML_ELEMENT_TYPE_MIXED</a> = 3 <a name="XML_ELEMENT_TYPE_ELEMENT">XML_ELEMENT_TYPE_ELEMENT</a> = 4
}; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlEntity">Structure </a>xmlEntity</h3><pre class="programlisting">struct _xmlEntity { void * _private : application data <a href="libxml2-tree.html#xmlElementType">xmlElementType</a> type : XML_ENTITY_DECL, must be second ! const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name : Entity name struct _xmlNode * children : First child link struct _xmlNode * last : Last child link struct _xmlDtd * parent : -> DTD struct _xmlNode * next : next sibling link struct _xmlNode * prev : previous sibling link struct _xmlDoc * doc : the containing document <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * orig : content without ref substitution <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * content : content or ndata if unparsed int length : the content length <a href="libxml2-entities.html#xmlEntityType">xmlEntityType</a> etype : The entity type const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * ExternalID : External identifier for PUBLIC const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * SystemID : URI for a SYSTEM or PUBLIC Entity struct _xmlEntity * nexte : unused const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * URI : the full URI as computed int owner : does the entity own the childrens int checked : was the entity content checked this is also used to count entities *
} xmlEntity; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlEntityPtr">Typedef </a>xmlEntityPtr</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlEntity">xmlEntity</a> * xmlEntityPtr;
</pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlEnumeration">Structure </a>xmlEnumeration</h3><pre class="programlisting">struct _xmlEnumeration { struct _xmlEnumeration * next : next one const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name : Enumeration name
} xmlEnumeration; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlEnumerationPtr">Typedef </a>xmlEnumerationPtr</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlEnumeration">xmlEnumeration</a> * xmlEnumerationPtr;
</pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlID">Structure </a>xmlID</h3><pre class="programlisting">struct _xmlID { struct _xmlID * next : next ID const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * value : The ID name <a href="libxml2-tree.html#xmlAttrPtr">xmlAttrPtr</a> attr : The <a href="libxml2-SAX.html#attribute">attribute</a> holding it const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name : The <a href="libxml2-SAX.html#attribute">attribute</a> if attr is not available int lineno : The line number if attr is not available struct _xmlDoc * doc : The document holding the ID
} xmlID; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlIDPtr">Typedef </a>xmlIDPtr</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlID">xmlID</a> * xmlIDPtr;
</pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNode">Structure </a>xmlNode</h3><pre class="programlisting">struct _xmlNode { void * _private : application data <a href="libxml2-tree.html#xmlElementType">xmlElementType</a> type : type number, must be second ! const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * 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 <a href="libxml2-tree.html#xmlNs">xmlNs</a> * ns : pointer to the associated namespace <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * content : the content struct _xmlAttr * properties : properties list <a href="libxml2-tree.html#xmlNs">xmlNs</a> * nsDef : namespace definitions on this node void * psvi : for type/PSVI informations unsigned short line : line number unsigned short extra : extra data for XPath/XSLT
} xmlNode; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNodePtr">Typedef </a>xmlNodePtr</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNode">xmlNode</a> * xmlNodePtr;
</pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNotation">Structure </a>xmlNotation</h3><pre class="programlisting">struct _xmlNotation { const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name : Notation name const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * PublicID : Public identifier, if any const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * SystemID : System identifier, if any
} xmlNotation; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNotationPtr">Typedef </a>xmlNotationPtr</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNotation">xmlNotation</a> * xmlNotationPtr;
</pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNs">Structure </a>xmlNs</h3><pre class="programlisting">struct _xmlNs { struct _xmlNs * next : next Ns link for this node <a href="libxml2-tree.html#xmlNsType">xmlNsType</a> type : global or local const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * href : URL for the namespace const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * prefix : prefix for the namespace void * _private : application data struct _xmlDoc * context : normally an <a href="libxml2-tree.html#xmlDoc">xmlDoc</a>
} xmlNs; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNsPtr">Typedef </a>xmlNsPtr</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNs">xmlNs</a> * xmlNsPtr;
</pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNsType">Typedef </a>xmlNsType</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlElementType">xmlElementType</a> xmlNsType;
</pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlOutputBuffer">Structure </a>xmlOutputBuffer</h3><pre class="programlisting">struct _xmlOutputBuffer { void * context <a href="libxml2-xmlIO.html#xmlOutputWriteCallback">xmlOutputWriteCallback</a> writecallback <a href="libxml2-xmlIO.html#xmlOutputCloseCallback">xmlOutputCloseCallback</a> closecallback <a href="libxml2-encoding.html#xmlCharEncodingHandlerPtr">xmlCharEncodingHandlerPtr</a> encoder : I18N conversions to UTF-8 <a href="libxml2-tree.html#xmlBufPtr">xmlBufPtr</a> buffer : Local buffer encoded in UTF-8 or ISOLatin <a href="libxml2-tree.html#xmlBufPtr">xmlBufPtr</a> conv : if encoder != NULL buffer for output int written : total number of byte written int error
} xmlOutputBuffer; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlOutputBufferPtr">Typedef </a>xmlOutputBufferPtr</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlOutputBuffer">xmlOutputBuffer</a> * xmlOutputBufferPtr;
</pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlParserCtxt">Structure </a>xmlParserCtxt</h3><pre class="programlisting">struct _xmlParserCtxt { struct _xmlSAXHandler * sax : The SAX handler void * userData : For SAX interface only, used by DOM build <a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> myDoc : the document being built int wellFormed : is the document well formed int replaceEntities : shall we replace entities ? const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * version : the XML version string const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * encoding : the declared encoding, if any int standalone : standalone document int html : an HTML(1)/Docbook(2) document * 3 is HTML after <head> * 10 is HTML <a href="libxml2-tree.html#xmlParserInputPtr">xmlParserInputPtr</a> input : Current input stream int inputNr : Number of current input streams int inputMax : Max number of input streams <a href="libxml2-tree.html#xmlParserInputPtr">xmlParserInputPtr</a> * inputTab : stack of inputs Node analysis stack only used for DOM building <a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> node : Current parsed Node int nodeNr : Depth of the parsing stack int nodeMax : Max depth of the parsing stack <a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> * nodeTab : array of nodes int record_info : Whether node info should be kept <a href="libxml2-parser.html#xmlParserNodeInfoSeq">xmlParserNodeInfoSeq</a> node_seq : info about each node parsed int errNo : error code int hasExternalSubset : <a href="libxml2-SAX.html#reference">reference</a> and external subset int hasPErefs : the internal subset has PE refs int external : are we parsing an external entity int valid : is the document valid int validate : shall we try to validate ? <a href="libxml2-valid.html#xmlValidCtxt">xmlValidCtxt</a> vctxt : The validity context <a href="libxml2-parser.html#xmlParserInputState">xmlParserInputState</a> instate : current type of input int token : next char look-ahead char * directory : the data directory Node name stack const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name : Current parsed Node int nameNr : Depth of the parsing stack int nameMax : Max depth of the parsing stack const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * * nameTab : array of nodes long nbChars : number of <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> processed long checkIndex : used by progressive parsing lookup int keepBlanks : ugly but ... int disableSAX : SAX callbacks are disabled int inSubset : Parsing is in int 1/ext 2 subset const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * intSubName : name of subset <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * extSubURI : URI of external subset <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * extSubSystem : SYSTEM ID of external subset xml:space values int * space : Should the parser preserve spaces int spaceNr : Depth of the parsing stack int spaceMax : Max depth of the parsing stack int * spaceTab : array of space infos int depth : to prevent entity substitution loops <a href="libxml2-tree.html#xmlParserInputPtr">xmlParserInputPtr</a> entity : used to check entities boundaries int charset : encoding of the in-memory content actually an <a href="libxml2-encoding.html#xmlCharEncoding">xmlCharEncoding</a> int nodelen : Those two fields are there to int nodemem : Speed up large node parsing int pedantic : signal pedantic warnings void * _private : For user data, libxml won't touch it int loadsubset : should the external subset be loaded int linenumbers : set line number in element content void * catalogs : document's own catalog int recovery : run in recovery mode int progressive : is this a progressive parsing <a href="libxml2-dict.html#xmlDictPtr">xmlDictPtr</a> dict : dictionary for the parser const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * * atts : array for the attributes callbacks int maxatts : the size of the array int docdict : * pre-interned strings * const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * str_xml const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * str_xmlns const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * str_xml_ns : * Everything below is used only by the new SAX mode * int sax2 : operating in the new SAX mode int nsNr : the number of inherited namespaces int nsMax : the size of the arrays const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * * nsTab : the array of prefix/namespace name int * attallocs : which <a href="libxml2-SAX.html#attribute">attribute</a> were allocated void * * pushTab : array of data for push <a href="libxml2-hash.html#xmlHashTablePtr">xmlHashTablePtr</a> attsDefault : defaulted attributes if any <a href="libxml2-hash.html#xmlHashTablePtr">xmlHashTablePtr</a> attsSpecial : non-CDATA attributes if any int nsWellFormed : is the document XML Namespace okay int options : * Those fields are needed only for streaming parsing so far * int dictNames : Use dictionary names for the tree int freeElemsNr : number of freed element nodes <a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> freeElems : List of freed element nodes int freeAttrsNr : number of freed attributes nodes <a href="libxml2-tree.html#xmlAttrPtr">xmlAttrPtr</a> freeAttrs : * the complete error informations for the last error. * <a href="libxml2-xmlerror.html#xmlError">xmlError</a> lastError <a href="libxml2-parser.html#xmlParserMode">xmlParserMode</a> parseMode : the parser mode unsigned long nbentities : number of entities references unsigned long sizeentities : size of parsed entities for use by HTML non-recursive parser <a href="libxml2-parser.html#xmlParserNodeInfo">xmlParserNodeInfo</a> * nodeInfo : Current NodeInfo int nodeInfoNr : Depth of the parsing stack int nodeInfoMax : Max depth of the parsing stack <a href="libxml2-parser.html#xmlParserNodeInfo">xmlParserNodeInfo</a> * nodeInfoTab : array of nodeInfos int input_id : we need to label inputs unsigned long sizeentcopy : volume of entity copy
} xmlParserCtxt; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlParserCtxtPtr">Typedef </a>xmlParserCtxtPtr</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlParserCtxt">xmlParserCtxt</a> * xmlParserCtxtPtr;
</pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlParserInput">Structure </a>xmlParserInput</h3><pre class="programlisting">struct _xmlParserInput { <a href="libxml2-tree.html#xmlParserInputBufferPtr">xmlParserInputBufferPtr</a> buf : UTF-8 encoded buffer const char * filename : The file analyzed, if any const char * directory : the directory/base of the file const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * base : Base of the array to parse const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * cur : Current char being parsed const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * end : end of the array to parse int length : length if known int line : Current line int col : * NOTE: consumed is only tested for equality in the parser code, * unsigned long consumed : How many xmlChars already consumed <a href="libxml2-parser.html#xmlParserInputDeallocate">xmlParserInputDeallocate</a> free : function to deallocate the base const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * encoding : the encoding string for entity const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * version : the version string for entity int standalone : Was that entity marked standalone int id : an unique identifier for the entity
} xmlParserInput; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlParserInputBuffer">Structure </a>xmlParserInputBuffer</h3><pre class="programlisting">struct _xmlParserInputBuffer { void * context <a href="libxml2-xmlIO.html#xmlInputReadCallback">xmlInputReadCallback</a> readcallback <a href="libxml2-xmlIO.html#xmlInputCloseCallback">xmlInputCloseCallback</a> closecallback <a href="libxml2-encoding.html#xmlCharEncodingHandlerPtr">xmlCharEncodingHandlerPtr</a> encoder : I18N conversions to UTF-8 <a href="libxml2-tree.html#xmlBufPtr">xmlBufPtr</a> buffer : Local buffer encoded in UTF-8 <a href="libxml2-tree.html#xmlBufPtr">xmlBufPtr</a> raw : if encoder != NULL buffer for raw input int compressed : -1=unknown, 0=not compressed, 1=compressed int error unsigned long rawconsumed : amount consumed from raw
} xmlParserInputBuffer; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlParserInputBufferPtr">Typedef </a>xmlParserInputBufferPtr</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlParserInputBuffer">xmlParserInputBuffer</a> * xmlParserInputBufferPtr;
</pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlParserInputPtr">Typedef </a>xmlParserInputPtr</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlParserInput">xmlParserInput</a> * xmlParserInputPtr;
</pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlRef">Structure </a>xmlRef</h3><pre class="programlisting">struct _xmlRef { struct _xmlRef * next : next Ref const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * value : The Ref name <a href="libxml2-tree.html#xmlAttrPtr">xmlAttrPtr</a> attr : The <a href="libxml2-SAX.html#attribute">attribute</a> holding it const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name : The <a href="libxml2-SAX.html#attribute">attribute</a> if attr is not available int lineno : The line number if attr is not available
} xmlRef; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlRefPtr">Typedef </a>xmlRefPtr</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlRef">xmlRef</a> * xmlRefPtr;
</pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlSAXHandler">Structure </a>xmlSAXHandler</h3><pre class="programlisting">struct _xmlSAXHandler { <a href="libxml2-parser.html#internalSubsetSAXFunc">internalSubsetSAXFunc</a> internalSubset <a href="libxml2-parser.html#isStandaloneSAXFunc">isStandaloneSAXFunc</a> isStandalone <a href="libxml2-parser.html#hasInternalSubsetSAXFunc">hasInternalSubsetSAXFunc</a> hasInternalSubset <a href="libxml2-parser.html#hasExternalSubsetSAXFunc">hasExternalSubsetSAXFunc</a> hasExternalSubset <a href="libxml2-parser.html#resolveEntitySAXFunc">resolveEntitySAXFunc</a> resolveEntity <a href="libxml2-parser.html#getEntitySAXFunc">getEntitySAXFunc</a> getEntity <a href="libxml2-parser.html#entityDeclSAXFunc">entityDeclSAXFunc</a> entityDecl <a href="libxml2-parser.html#notationDeclSAXFunc">notationDeclSAXFunc</a> notationDecl <a href="libxml2-parser.html#attributeDeclSAXFunc">attributeDeclSAXFunc</a> attributeDecl <a href="libxml2-parser.html#elementDeclSAXFunc">elementDeclSAXFunc</a> elementDecl <a href="libxml2-parser.html#unparsedEntityDeclSAXFunc">unparsedEntityDeclSAXFunc</a> unparsedEntityDecl <a href="libxml2-parser.html#setDocumentLocatorSAXFunc">setDocumentLocatorSAXFunc</a> setDocumentLocator <a href="libxml2-parser.html#startDocumentSAXFunc">startDocumentSAXFunc</a> startDocument <a href="libxml2-parser.html#endDocumentSAXFunc">endDocumentSAXFunc</a> endDocument <a href="libxml2-parser.html#startElementSAXFunc">startElementSAXFunc</a> startElement <a href="libxml2-parser.html#endElementSAXFunc">endElementSAXFunc</a> endElement <a href="libxml2-parser.html#referenceSAXFunc">referenceSAXFunc</a> reference <a href="libxml2-parser.html#charactersSAXFunc">charactersSAXFunc</a> characters <a href="libxml2-parser.html#ignorableWhitespaceSAXFunc">ignorableWhitespaceSAXFunc</a> ignorableWhitespace <a href="libxml2-parser.html#processingInstructionSAXFunc">processingInstructionSAXFunc</a> processingInstruction <a href="libxml2-parser.html#commentSAXFunc">commentSAXFunc</a> comment <a href="libxml2-parser.html#warningSAXFunc">warningSAXFunc</a> warning <a href="libxml2-parser.html#errorSAXFunc">errorSAXFunc</a> error <a href="libxml2-parser.html#fatalErrorSAXFunc">fatalErrorSAXFunc</a> fatalError : unused error() get all the errors <a href="libxml2-parser.html#getParameterEntitySAXFunc">getParameterEntitySAXFunc</a> getParameterEntity <a href="libxml2-parser.html#cdataBlockSAXFunc">cdataBlockSAXFunc</a> cdataBlock <a href="libxml2-parser.html#externalSubsetSAXFunc">externalSubsetSAXFunc</a> externalSubset unsigned int initialized : The following fields are extensions available only on version 2 void * _private <a href="libxml2-parser.html#startElementNsSAX2Func">startElementNsSAX2Func</a> startElementNs <a href="libxml2-parser.html#endElementNsSAX2Func">endElementNsSAX2Func</a> endElementNs <a href="libxml2-xmlerror.html#xmlStructuredErrorFunc">xmlStructuredErrorFunc</a> serror
} xmlSAXHandler; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlSAXHandlerPtr">Typedef </a>xmlSAXHandlerPtr</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlSAXHandler">xmlSAXHandler</a> * xmlSAXHandlerPtr;
</pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlSAXLocator">Structure </a>xmlSAXLocator</h3><pre class="programlisting">struct _xmlSAXLocator { const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> *(*getPublicId) getPublicId const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> *(*getSystemId) getSystemId int(*getLineNumber) getLineNumber int(*getColumnNumber) getColumnNumber
} xmlSAXLocator; </pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlSAXLocatorPtr">Typedef </a>xmlSAXLocatorPtr</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlSAXLocator">xmlSAXLocator</a> * xmlSAXLocatorPtr;
</pre><p/> </div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlDOMWrapAcquireNsFunction"/>Function type xmlDOMWrapAcquireNsFunction</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNsPtr">xmlNsPtr</a> xmlDOMWrapAcquireNsFunction (<a href="libxml2-tree.html#xmlDOMWrapCtxtPtr">xmlDOMWrapCtxtPtr</a> ctxt, <br/> <a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> node, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * nsName, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * nsPrefix)<br/>
</pre><p>A function called to acquire namespaces (xmlNs) from
the wrapper.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>ctxt
:</span></td><td>a
DOM wrapper context</td></tr><tr><td><span
class=“term”>node
:</span></td><td>the
context node (element or
attribute)</td></tr><tr><td><span
class=“term”>nsName
:</span></td><td>the
requested namespace name</td></tr><tr><td><span
class=“term”>nsPrefix
:</span></td><td>the
requested namespace
prefix</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>an
<a href=“libxml2-tree.html#xmlNsPtr”>xmlNsPtr</a> or NULL in
case of an
error.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlAddChild"/>xmlAddChild ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlAddChild (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> parent, <br/> <a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> cur)<br/>
</pre><p>Add a new node to @parent, at the end of the child (or
property) list merging adjacent TEXT nodes (in which case @cur is freed) If
the new node is ATTRIBUTE, it is added into properties instead of children.
If there is an <a
href=“libxml2-SAX.html#attribute”>attribute</a> with equal name,
it is first destroyed.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>parent
:</span></td><td>the
parent node</td></tr><tr><td><span
class=“term”>cur
:</span></td><td>the
child node</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
child or NULL in case of
error.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlAddChildList"/>xmlAddChildList ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlAddChildList (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> parent, <br/> <a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> cur)<br/>
</pre><p>Add a list of node at the end of the child list of the
parent merging adjacent TEXT nodes (@cur may be freed)</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>parent
:</span></td><td>the
parent node</td></tr><tr><td><span
class=“term”>cur
:</span></td><td>the
first node in the list</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
last child or NULL in case of
error.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlAddNextSibling"/>xmlAddNextSibling ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlAddNextSibling (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> cur, <br/> <a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> elem)<br/>
</pre><p>Add a new node @elem as the next sibling of @cur If
the new node was already inserted in a document it is first unlinked from
its existing context. As a result of text merging @elem may be freed. If
the new node is ATTRIBUTE, it is added into properties instead of children.
If there is an <a
href=“libxml2-SAX.html#attribute”>attribute</a> with equal name,
it is first destroyed.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>cur
:</span></td><td>the
child node</td></tr><tr><td><span
class=“term”>elem
:</span></td><td>the
new node</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
new node or NULL in case of
error.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlAddPrevSibling"/>xmlAddPrevSibling ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlAddPrevSibling (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> cur, <br/> <a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> elem)<br/>
</pre><p>Add a new node @elem as the previous sibling of @cur
merging adjacent TEXT nodes (@elem may be freed) If the new node was
already inserted in a document it is first unlinked from its existing
context. If the new node is ATTRIBUTE, it is added into properties instead
of children. If there is an <a
href=“libxml2-SAX.html#attribute”>attribute</a> with equal name,
it is first destroyed.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>cur
:</span></td><td>the
child node</td></tr><tr><td><span
class=“term”>elem
:</span></td><td>the
new node</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
new node or NULL in case of
error.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlAddSibling"/>xmlAddSibling ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlAddSibling (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> cur, <br/> <a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> elem)<br/>
</pre><p>Add a new element @elem to the list of siblings of
@cur merging adjacent TEXT nodes (@elem may be freed) If the new element
was already inserted in a document it is first unlinked from its existing
context.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>cur
:</span></td><td>the
child node</td></tr><tr><td><span
class=“term”>elem
:</span></td><td>the
new node</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
new element or NULL in case of
error.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlAttrSerializeTxtContent"/>xmlAttrSerializeTxtContent ()</h3><pre class="programlisting">void xmlAttrSerializeTxtContent (<a href="libxml2-tree.html#xmlBufferPtr">xmlBufferPtr</a> buf, <br/> <a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc, <br/> <a href="libxml2-tree.html#xmlAttrPtr">xmlAttrPtr</a> attr, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * string)<br/>
</pre><p>Serialize text <a
href=“libxml2-SAX.html#attribute”>attribute</a> values to an xml
simple buffer</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>buf
:</span></td><td>the
XML buffer output</td></tr><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>attr
:</span></td><td>the
<a href=“libxml2-SAX.html#attribute”>attribute</a>
node</td></tr><tr><td><span
class=“term”>string
:</span></td><td>the
text
content</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufContent"/>xmlBufContent ()</h3><pre class="programlisting"><a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * xmlBufContent (const <a href="libxml2-tree.html#xmlBuf">xmlBuf</a> * buf)<br/>
</pre><p>Function to extract the content of a buffer</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>buf
:</span></td><td>the
buffer</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
internal
content</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufEnd"/>xmlBufEnd ()</h3><pre class="programlisting"><a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * xmlBufEnd (<a href="libxml2-tree.html#xmlBufPtr">xmlBufPtr</a> buf)<br/>
</pre><p>Function to extract the end of the content of a
buffer</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>buf
:</span></td><td>the
buffer</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
end of the internal content or NULL in case of
error</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufGetNodeContent"/>xmlBufGetNodeContent ()</h3><pre class="programlisting">int xmlBufGetNodeContent (<a href="libxml2-tree.html#xmlBufPtr">xmlBufPtr</a> buf, <br/> const <a href="libxml2-tree.html#xmlNode">xmlNode</a> * cur)<br/>
</pre><p>Read the value of a node @cur, this can be either the
text carried directly by this node if it's a TEXT node or the aggregate
string of the values carried by this node child's (TEXT and
ENTITY_REF). Entity references are substituted. Fills up the buffer @buf
with this value</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>buf
:</span></td><td>a
buffer <a
href=“libxml2-tree.html#xmlBufPtr”>xmlBufPtr</a></td></tr><tr><td><span
class=“term”>cur
:</span></td><td>the
node being read</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>0
in case of success and -1 in case of
error.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufNodeDump"/>xmlBufNodeDump ()</h3><pre class="programlisting">size_t xmlBufNodeDump (<a href="libxml2-tree.html#xmlBufPtr">xmlBufPtr</a> buf, <br/> <a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc, <br/> <a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> cur, <br/> int level, <br/> int format)<br/>
</pre><p>Dump an XML node, recursive behaviour,children are
printed too. Note that @format = 1 provide node indenting only if <a
href=“libxml2-globals.html#xmlIndentTreeOutput”>xmlIndentTreeOutput</a>
= 1 or xmlKeepBlanksDefault(0) was called</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>buf
:</span></td><td>the
XML buffer output</td></tr><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>cur
:</span></td><td>the
current node</td></tr><tr><td><span
class=“term”>level
:</span></td><td>the
imbrication level for
indenting</td></tr><tr><td><span
class=“term”>format
:</span></td><td>is
formatting allowed</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
number of bytes written to the buffer, in case of error 0 is returned or
@buf stores the
error</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufShrink"/>xmlBufShrink ()</h3><pre class="programlisting">size_t xmlBufShrink (<a href="libxml2-tree.html#xmlBufPtr">xmlBufPtr</a> buf, <br/> size_t len)<br/>
</pre><p>Remove the beginning of an XML buffer. NOTE that this
routine behaviour differs from xmlBufferShrink() as it will return 0 on
error instead of -1 due to size_t being used as the return type.</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>buf
:</span></td><td>the
buffer to dump</td></tr><tr><td><span
class=“term”>len
:</span></td><td>the
number of <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a>
to remove</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
number of byte removed or 0 in case of
failure</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufUse"/>xmlBufUse ()</h3><pre class="programlisting">size_t xmlBufUse (const <a href="libxml2-tree.html#xmlBufPtr">xmlBufPtr</a> buf)<br/>
</pre><p>Function to get the length of a buffer</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>buf
:</span></td><td>the
buffer</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
length of data in the internal
content</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufferAdd"/>xmlBufferAdd ()</h3><pre class="programlisting">int xmlBufferAdd (<a href="libxml2-tree.html#xmlBufferPtr">xmlBufferPtr</a> buf, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * str, <br/> int len)<br/>
</pre><p>Add a string range to an XML buffer. if len == -1, the
length of str is recomputed.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>buf
:</span></td><td>the
buffer to dump</td></tr><tr><td><span
class=“term”>str
:</span></td><td>the
xmlChar string</td></tr><tr><td><span
class=“term”>len
:</span></td><td>the
number of xmlChar to add</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>0
successful, a positive error code number otherwise and -1 in case of
internal or API
error.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufferAddHead"/>xmlBufferAddHead ()</h3><pre class="programlisting">int xmlBufferAddHead (<a href="libxml2-tree.html#xmlBufferPtr">xmlBufferPtr</a> buf, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * str, <br/> int len)<br/>
</pre><p>Add a string range to the beginning of an XML buffer.
if len == -1, the length of @str is recomputed.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>buf
:</span></td><td>the
buffer</td></tr><tr><td><span
class=“term”>str
:</span></td><td>the
xmlChar string</td></tr><tr><td><span
class=“term”>len
:</span></td><td>the
number of xmlChar to add</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>0
successful, a positive error code number otherwise and -1 in case of
internal or API
error.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufferCCat"/>xmlBufferCCat ()</h3><pre class="programlisting">int xmlBufferCCat (<a href="libxml2-tree.html#xmlBufferPtr">xmlBufferPtr</a> buf, <br/> const char * str)<br/>
</pre><p>Append a zero terminated C string to an XML
buffer.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>buf
:</span></td><td>the
buffer to dump</td></tr><tr><td><span
class=“term”>str
:</span></td><td>the
C char string</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>0
successful, a positive error code number otherwise and -1 in case of
internal or API
error.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufferCat"/>xmlBufferCat ()</h3><pre class="programlisting">int xmlBufferCat (<a href="libxml2-tree.html#xmlBufferPtr">xmlBufferPtr</a> buf, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * str)<br/>
</pre><p>Append a zero terminated string to an XML
buffer.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>buf
:</span></td><td>the
buffer to add to</td></tr><tr><td><span
class=“term”>str
:</span></td><td>the
xmlChar string</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>0
successful, a positive error code number otherwise and -1 in case of
internal or API
error.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufferContent"/>xmlBufferContent ()</h3><pre class="programlisting">const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * xmlBufferContent (const <a href="libxml2-tree.html#xmlBuffer">xmlBuffer</a> * buf)<br/>
</pre><p>Function to extract the content of a buffer</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>buf
:</span></td><td>the
buffer</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
internal
content</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufferCreate"/>xmlBufferCreate ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlBufferPtr">xmlBufferPtr</a> xmlBufferCreate (void)<br/>
</pre><p>routine to create an XML buffer.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>Returns
:</span></td><td>the
new
structure.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufferCreateSize"/>xmlBufferCreateSize ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlBufferPtr">xmlBufferPtr</a> xmlBufferCreateSize (size_t size)<br/>
</pre><p>routine to create an XML buffer.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>size
:</span></td><td>initial
size of buffer</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
new
structure.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufferCreateStatic"/>xmlBufferCreateStatic ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlBufferPtr">xmlBufferPtr</a> xmlBufferCreateStatic (void * mem, <br/> size_t size)<br/>
</pre><p>routine to create an XML buffer from an immutable
memory area. The area won't be modified nor copied, and is expected to
be present until the end of the buffer lifetime.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>mem
:</span></td><td>the
memory area</td></tr><tr><td><span
class=“term”>size
:</span></td><td>the
size in byte</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
new
structure.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufferDetach"/>xmlBufferDetach ()</h3><pre class="programlisting"><a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * xmlBufferDetach (<a href="libxml2-tree.html#xmlBufferPtr">xmlBufferPtr</a> buf)<br/>
</pre><p>Remove the string contained in a buffer and gie it
back to the caller. The buffer is reset to an empty content. This
doesn't work with immutable buffers as they can't be
reset.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>buf
:</span></td><td>the
buffer</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
previous string contained by the
buffer.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufferDump"/>xmlBufferDump ()</h3><pre class="programlisting">int xmlBufferDump (FILE * file, <br/> <a href="libxml2-tree.html#xmlBufferPtr">xmlBufferPtr</a> buf)<br/>
</pre><p>Dumps an XML buffer to a FILE *.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>file
:</span></td><td>the
file output</td></tr><tr><td><span
class=“term”>buf
:</span></td><td>the
buffer to dump</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
number of xmlChar
written</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufferEmpty"/>xmlBufferEmpty ()</h3><pre class="programlisting">void xmlBufferEmpty (<a href="libxml2-tree.html#xmlBufferPtr">xmlBufferPtr</a> buf)<br/>
</pre><p>empty a buffer.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>buf
:</span></td><td>the
buffer</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufferFree"/>xmlBufferFree ()</h3><pre class="programlisting">void xmlBufferFree (<a href="libxml2-tree.html#xmlBufferPtr">xmlBufferPtr</a> buf)<br/>
</pre><p>Frees an XML buffer. It frees both the content and the
structure which encapsulate it.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>buf
:</span></td><td>the
buffer to
free</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufferGrow"/>xmlBufferGrow ()</h3><pre class="programlisting">int xmlBufferGrow (<a href="libxml2-tree.html#xmlBufferPtr">xmlBufferPtr</a> buf, <br/> unsigned int len)<br/>
</pre><p>Grow the available space of an XML buffer.</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>buf
:</span></td><td>the
buffer</td></tr><tr><td><span
class=“term”>len
:</span></td><td>the
minimum free size to
allocate</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
new available space or -1 in case of
error</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufferLength"/>xmlBufferLength ()</h3><pre class="programlisting">int xmlBufferLength (const <a href="libxml2-tree.html#xmlBuffer">xmlBuffer</a> * buf)<br/>
</pre><p>Function to get the length of a buffer</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>buf
:</span></td><td>the
buffer</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
length of data in the internal
content</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufferResize"/>xmlBufferResize ()</h3><pre class="programlisting">int xmlBufferResize (<a href="libxml2-tree.html#xmlBufferPtr">xmlBufferPtr</a> buf, <br/> unsigned int size)<br/>
</pre><p>Resize a buffer to accommodate minimum size of
@size.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>buf
:</span></td><td>the
buffer to resize</td></tr><tr><td><span
class=“term”>size
:</span></td><td>the
desired size</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>0
in case of problems, 1
otherwise</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufferSetAllocationScheme"/>xmlBufferSetAllocationScheme ()</h3><pre class="programlisting">void xmlBufferSetAllocationScheme (<a href="libxml2-tree.html#xmlBufferPtr">xmlBufferPtr</a> buf, <br/> <a href="libxml2-tree.html#xmlBufferAllocationScheme">xmlBufferAllocationScheme</a> scheme)<br/>
</pre><p>Sets the allocation scheme for this buffer</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>buf
:</span></td><td>the
buffer to tune</td></tr><tr><td><span
class=“term”>scheme
:</span></td><td>allocation
scheme to
use</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufferShrink"/>xmlBufferShrink ()</h3><pre class="programlisting">int xmlBufferShrink (<a href="libxml2-tree.html#xmlBufferPtr">xmlBufferPtr</a> buf, <br/> unsigned int len)<br/>
</pre><p>Remove the beginning of an XML buffer.</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>buf
:</span></td><td>the
buffer to dump</td></tr><tr><td><span
class=“term”>len
:</span></td><td>the
number of <a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a>
to remove</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
number of xmlChar removed, or -1 in case of
failure.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufferWriteCHAR"/>xmlBufferWriteCHAR ()</h3><pre class="programlisting">void xmlBufferWriteCHAR (<a href="libxml2-tree.html#xmlBufferPtr">xmlBufferPtr</a> buf, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * string)<br/>
</pre><p>routine which manages and grows an output buffer. This
one adds xmlChars at the end of the buffer.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>buf
:</span></td><td>the
XML buffer</td></tr><tr><td><span
class=“term”>string
:</span></td><td>the
string to
add</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufferWriteChar"/>xmlBufferWriteChar ()</h3><pre class="programlisting">void xmlBufferWriteChar (<a href="libxml2-tree.html#xmlBufferPtr">xmlBufferPtr</a> buf, <br/> const char * string)<br/>
</pre><p>routine which manage and grows an output buffer. This
one add C chars at the end of the array.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>buf
:</span></td><td>the
XML buffer output</td></tr><tr><td><span
class=“term”>string
:</span></td><td>the
string to
add</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBufferWriteQuotedString"/>xmlBufferWriteQuotedString ()</h3><pre class="programlisting">void xmlBufferWriteQuotedString (<a href="libxml2-tree.html#xmlBufferPtr">xmlBufferPtr</a> buf, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * string)<br/>
</pre><p>routine which manage and grows an output buffer. This
one writes a quoted or double quoted xmlChar string, checking first if it
holds quote or double-quotes internally</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>buf
:</span></td><td>the
XML buffer output</td></tr><tr><td><span
class=“term”>string
:</span></td><td>the
string to
add</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlBuildQName"/>xmlBuildQName ()</h3><pre class="programlisting"><a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * xmlBuildQName (const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * ncname, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * prefix, <br/> <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * memory, <br/> int len)<br/>
</pre><p>Builds the QName @prefix:@ncname in @memory if there
is enough space and prefix is not NULL nor empty, otherwise allocate a new
string. If prefix is NULL or empty it returns ncname.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>ncname
:</span></td><td>the
Name</td></tr><tr><td><span
class=“term”>prefix
:</span></td><td>the
prefix</td></tr><tr><td><span
class=“term”>memory
:</span></td><td>preallocated
memory</td></tr><tr><td><span
class=“term”>len
:</span></td><td>preallocated
memory length</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
new string which must be freed by the caller if different from @memory and
@ncname or NULL in case of
error</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlChildElementCount"/>xmlChildElementCount ()</h3><pre class="programlisting">unsigned long xmlChildElementCount (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> parent)<br/>
</pre><p>Finds the current number of child nodes of that
element which are element nodes. Note the handling of entities references
is different than in the W3C DOM element traversal spec since we don't
have back <a href=“libxml2-SAX.html#reference”>reference</a>
from entities content to entities references.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>parent
:</span></td><td>the
parent node</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
count of element child or 0 if not
available</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlCopyDoc"/>xmlCopyDoc ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> xmlCopyDoc (<a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc, <br/> int recursive)<br/>
</pre><p>Do a copy of the document info. If recursive, the
content tree will be copied too as well as DTD, namespaces and
entities.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>recursive
:</span></td><td>if
not zero do a recursive
copy.</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
new xmlDocPtr, or NULL in case of
error.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlCopyDtd"/>xmlCopyDtd ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlDtdPtr">xmlDtdPtr</a> xmlCopyDtd (<a href="libxml2-tree.html#xmlDtdPtr">xmlDtdPtr</a> dtd)<br/>
</pre><p>Do a copy of the dtd.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>dtd
:</span></td><td>the
dtd</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
new xmlDtdPtr, or NULL in case of
error.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlCopyNamespace"/>xmlCopyNamespace ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNsPtr">xmlNsPtr</a> xmlCopyNamespace (<a href="libxml2-tree.html#xmlNsPtr">xmlNsPtr</a> cur)<br/>
</pre><p>Do a copy of the namespace.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>cur
:</span></td><td>the
namespace</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
new xmlNsPtr, or NULL in case of
error.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlCopyNamespaceList"/>xmlCopyNamespaceList ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNsPtr">xmlNsPtr</a> xmlCopyNamespaceList (<a href="libxml2-tree.html#xmlNsPtr">xmlNsPtr</a> cur)<br/>
</pre><p>Do a copy of an namespace list.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>cur
:</span></td><td>the
first namespace</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
new xmlNsPtr, or NULL in case of
error.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlCopyNode"/>xmlCopyNode ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlCopyNode (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> node, <br/> int extended)<br/>
</pre><p>Do a copy of the node.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>node
:</span></td><td>the
node</td></tr><tr><td><span
class=“term”>extended
:</span></td><td>if
1 do a recursive copy (properties, namespaces and children when applicable)
if 2 copy properties and namespaces (when
applicable)</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
new xmlNodePtr, or NULL in case of
error.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlCopyNodeList"/>xmlCopyNodeList ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlCopyNodeList (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> node)<br/>
</pre><p>Do a recursive copy of the node list. Use
xmlDocCopyNodeList() if possible to ensure string interning.</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>node
:</span></td><td>the
first node in the list.</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
new xmlNodePtr, or NULL in case of
error.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlCopyProp"/>xmlCopyProp ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlAttrPtr">xmlAttrPtr</a> xmlCopyProp (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> target, <br/> <a href="libxml2-tree.html#xmlAttrPtr">xmlAttrPtr</a> cur)<br/>
</pre><p>Do a copy of the attribute.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>target
:</span></td><td>the
element where the <a
href=“libxml2-SAX.html#attribute”>attribute</a> will be
grafted</td></tr><tr><td><span
class=“term”>cur
:</span></td><td>the
<a
href=“libxml2-SAX.html#attribute”>attribute</a></td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
new xmlAttrPtr, or NULL in case of
error.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlCopyPropList"/>xmlCopyPropList ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlAttrPtr">xmlAttrPtr</a> xmlCopyPropList (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> target, <br/> <a href="libxml2-tree.html#xmlAttrPtr">xmlAttrPtr</a> cur)<br/>
</pre><p>Do a copy of an <a
href=“libxml2-SAX.html#attribute”>attribute</a> list.</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>target
:</span></td><td>the
element where the attributes will be
grafted</td></tr><tr><td><span
class=“term”>cur
:</span></td><td>the
first <a
href=“libxml2-SAX.html#attribute”>attribute</a></td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
new xmlAttrPtr, or NULL in case of
error.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlCreateIntSubset"/>xmlCreateIntSubset ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlDtdPtr">xmlDtdPtr</a> xmlCreateIntSubset (<a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * ExternalID, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * SystemID)<br/>
</pre><p>Create the internal subset of a document</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document pointer</td></tr><tr><td><span
class=“term”>name
:</span></td><td>the
DTD name</td></tr><tr><td><span
class=“term”>ExternalID
:</span></td><td>the
external (PUBLIC) ID</td></tr><tr><td><span
class=“term”>SystemID
:</span></td><td>the
system ID</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the new DTD
structure</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlDOMWrapAdoptNode"/>xmlDOMWrapAdoptNode ()</h3><pre class="programlisting">int xmlDOMWrapAdoptNode (<a href="libxml2-tree.html#xmlDOMWrapCtxtPtr">xmlDOMWrapCtxtPtr</a> ctxt, <br/> <a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> sourceDoc, <br/> <a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> node, <br/> <a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> destDoc, <br/> <a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> destParent, <br/> int options)<br/>
</pre><p>References of out-of scope ns-decls are remapped to
point to @destDoc: 1) If @destParent is given, then nsDef entries on
element-nodes are used 2) If no @destParent is given, then
@destDoc->oldNs entries are used This is the case when you have an
unlinked node and just want to move it to the context of If @destParent is
given, it ensures that the tree is namespace wellformed by creating
additional ns-decls where needed. Note that, since prefixes of already
existent ns-decls can be shadowed by this process, it could break QNames in
<a href=“libxml2-SAX.html#attribute”>attribute</a> values or
element content. NOTE: This function was not intensively tested.</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>ctxt
:</span></td><td>the
optional context for custom
processing</td></tr><tr><td><span
class=“term”>sourceDoc
:</span></td><td>the
optional sourceDoc</td></tr><tr><td><span
class=“term”>node
:</span></td><td>the
node to start with</td></tr><tr><td><span
class=“term”>destDoc
:</span></td><td>the
destination doc</td></tr><tr><td><span
class=“term”>destParent
:</span></td><td>the
optional new parent of @node in
@destDoc</td></tr><tr><td><span
class=“term”>options
:</span></td><td>option
flags</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>0
if the operation succeeded, 1 if a node of unsupported type was given, 2 if
a node of not yet supported type was given and -1 on API/internal
errors.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlDOMWrapCloneNode"/>xmlDOMWrapCloneNode ()</h3><pre class="programlisting">int xmlDOMWrapCloneNode (<a href="libxml2-tree.html#xmlDOMWrapCtxtPtr">xmlDOMWrapCtxtPtr</a> ctxt, <br/> <a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> sourceDoc, <br/> <a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> node, <br/> <a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> * resNode, <br/> <a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> destDoc, <br/> <a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> destParent, <br/> int deep, <br/> int options)<br/>
</pre><p>References of out-of scope ns-decls are remapped to
point to @destDoc: 1) If @destParent is given, then nsDef entries on
element-nodes are used 2) If no @destParent is given, then
@destDoc->oldNs entries are used. This is the case when you
don't know already where the cloned branch will be added to. If
@destParent is given, it ensures that the tree is namespace wellformed by
creating additional ns-decls where needed. Note that, since prefixes of
already existent ns-decls can be shadowed by this process, it could break
QNames in <a href=“libxml2-SAX.html#attribute”>attribute</a>
values or element content. TODO: 1) What to do with XInclude? Currently
this returns an error for XInclude.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>ctxt
:</span></td><td>the
optional context for custom
processing</td></tr><tr><td><span
class=“term”>sourceDoc
:</span></td><td>the
optional sourceDoc</td></tr><tr><td><span
class=“term”>node
:</span></td><td>the
node to start with</td></tr><tr><td><span
class=“term”>resNode
:</span></td><td>the
clone of the given @node</td></tr><tr><td><span
class=“term”>destDoc
:</span></td><td>the
destination doc</td></tr><tr><td><span
class=“term”>destParent
:</span></td><td>the
optional new parent of @node in
@destDoc</td></tr><tr><td><span
class=“term”>deep
:</span></td><td>descend
into child if set</td></tr><tr><td><span
class=“term”>options
:</span></td><td>option
flags</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>0
if the operation succeeded, 1 if a node of unsupported (or not yet
supported) type was given, -1 on API/internal
errors.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlDOMWrapFreeCtxt"/>xmlDOMWrapFreeCtxt ()</h3><pre class="programlisting">void xmlDOMWrapFreeCtxt (<a href="libxml2-tree.html#xmlDOMWrapCtxtPtr">xmlDOMWrapCtxtPtr</a> ctxt)<br/>
</pre><p>Frees the DOM-wrapper context.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>ctxt
:</span></td><td>the
DOM-wrapper
context</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlDOMWrapNewCtxt"/>xmlDOMWrapNewCtxt ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlDOMWrapCtxtPtr">xmlDOMWrapCtxtPtr</a> xmlDOMWrapNewCtxt (void)<br/>
</pre><p>Allocates and initializes a new DOM-wrapper
context.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>Returns
:</span></td><td>the
<a
href=“libxml2-tree.html#xmlDOMWrapCtxtPtr”>xmlDOMWrapCtxtPtr</a>
or NULL in case of an internal
error.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlDOMWrapReconcileNamespaces"/>xmlDOMWrapReconcileNamespaces ()</h3><pre class="programlisting">int xmlDOMWrapReconcileNamespaces (<a href="libxml2-tree.html#xmlDOMWrapCtxtPtr">xmlDOMWrapCtxtPtr</a> ctxt, <br/> <a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> elem, <br/> int options)<br/>
</pre><p>Ensures that ns-references point to ns-decls hold on
element-nodes. Ensures that the tree is namespace wellformed by creating
additional ns-decls where needed. Note that, since prefixes of already
existent ns-decls can be shadowed by this process, it could break QNames in
<a href=“libxml2-SAX.html#attribute”>attribute</a> values or
element content. NOTE: This function was not intensively tested.</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>ctxt
:</span></td><td>DOM
wrapper context, unused at the
moment</td></tr><tr><td><span
class=“term”>elem
:</span></td><td>the
element-node</td></tr><tr><td><span
class=“term”>options
:</span></td><td>option
flags</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>0
if succeeded, -1 otherwise and on API/internal
errors.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlDOMWrapRemoveNode"/>xmlDOMWrapRemoveNode ()</h3><pre class="programlisting">int xmlDOMWrapRemoveNode (<a href="libxml2-tree.html#xmlDOMWrapCtxtPtr">xmlDOMWrapCtxtPtr</a> ctxt, <br/> <a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc, <br/> <a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> node, <br/> int options)<br/>
</pre><p>Unlinks the given node from its owner. This will
substitute ns-references to node->nsDef for ns-references to
doc->oldNs, thus ensuring the removed branch to be autark wrt
ns-references. NOTE: This function was not intensively tested.</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>ctxt
:</span></td><td>a
DOM wrapper context</td></tr><tr><td><span
class=“term”>doc
:</span></td><td>the
doc</td></tr><tr><td><span
class=“term”>node
:</span></td><td>the
node to be removed.</td></tr><tr><td><span
class=“term”>options
:</span></td><td>set
of options, unused at the
moment</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>0
on success, 1 if the node is not supported, -1 on API and internal
errors.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlDocCopyNode"/>xmlDocCopyNode ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlDocCopyNode (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> node, <br/> <a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc, <br/> int extended)<br/>
</pre><p>Do a copy of the node to a given document.</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>node
:</span></td><td>the
node</td></tr><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>extended
:</span></td><td>if
1 do a recursive copy (properties, namespaces and children when applicable)
if 2 copy properties and namespaces (when
applicable)</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
new xmlNodePtr, or NULL in case of
error.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlDocCopyNodeList"/>xmlDocCopyNodeList ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlDocCopyNodeList (<a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc, <br/> <a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> node)<br/>
</pre><p>Do a recursive copy of the node list.</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
target document</td></tr><tr><td><span
class=“term”>node
:</span></td><td>the
first node in the list.</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
new xmlNodePtr, or NULL in case of
error.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlDocDump"/>xmlDocDump ()</h3><pre class="programlisting">int xmlDocDump (FILE * f, <br/> <a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> cur)<br/>
</pre><p>Dump an XML document to an open FILE.</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>f
:</span></td><td>the
FILE*</td></tr><tr><td><span
class=“term”>cur
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
number of bytes written or -1 in case of
failure.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlDocDumpFormatMemory"/>xmlDocDumpFormatMemory ()</h3><pre class="programlisting">void xmlDocDumpFormatMemory (<a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> cur, <br/> <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> ** mem, <br/> int * size, <br/> int format)<br/>
</pre><p>Dump an XML document in memory and return the xmlChar
* and it's size. It's up to the caller to free the memory with
xmlFree(). Note that @format = 1 provide node indenting only if <a
href=“libxml2-globals.html#xmlIndentTreeOutput”>xmlIndentTreeOutput</a>
= 1 or xmlKeepBlanksDefault(0) was called</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>cur
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>mem
:</span></td><td>OUT:
the memory pointer</td></tr><tr><td><span
class=“term”>size
:</span></td><td>OUT:
the memory length</td></tr><tr><td><span
class=“term”>format
:</span></td><td>should
formatting spaces been
added</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlDocDumpFormatMemoryEnc"/>xmlDocDumpFormatMemoryEnc ()</h3><pre class="programlisting">void xmlDocDumpFormatMemoryEnc (<a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> out_doc, <br/> <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> ** doc_txt_ptr, <br/> int * doc_txt_len, <br/> const char * txt_encoding, <br/> int format)<br/>
</pre><p>Dump the current DOM tree into memory using the
character encoding specified by the caller. Note it is up to the caller of
this function to free the allocated memory with xmlFree(). Note that
@format = 1 provide node indenting only if <a
href=“libxml2-globals.html#xmlIndentTreeOutput”>xmlIndentTreeOutput</a>
= 1 or xmlKeepBlanksDefault(0) was called</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>out_doc
:</span></td><td>Document
to generate XML text from</td></tr><tr><td><span
class=“term”>doc_txt_ptr
:</span></td><td>Memory
pointer for allocated XML
text</td></tr><tr><td><span
class=“term”>doc_txt_len
:</span></td><td>Length
of the generated XML text</td></tr><tr><td><span
class=“term”>txt_encoding
:</span></td><td>Character
encoding to use when generating XML
text</td></tr><tr><td><span
class=“term”>format
:</span></td><td>should
formatting spaces been
added</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlDocDumpMemory"/>xmlDocDumpMemory ()</h3><pre class="programlisting">void xmlDocDumpMemory (<a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> cur, <br/> <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> ** mem, <br/> int * size)<br/>
</pre><p>Dump an XML document in memory and return the xmlChar
* and it's size in bytes. It's up to the caller to free the memory
with xmlFree(). The resulting byte array is zero terminated, though the
last 0 is not included in the returned size.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>cur
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>mem
:</span></td><td>OUT:
the memory pointer</td></tr><tr><td><span
class=“term”>size
:</span></td><td>OUT:
the memory
length</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlDocDumpMemoryEnc"/>xmlDocDumpMemoryEnc ()</h3><pre class="programlisting">void xmlDocDumpMemoryEnc (<a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> out_doc, <br/> <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> ** doc_txt_ptr, <br/> int * doc_txt_len, <br/> const char * txt_encoding)<br/>
</pre><p>Dump the current DOM tree into memory using the
character encoding specified by the caller. Note it is up to the caller of
this function to free the allocated memory with xmlFree().</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>out_doc
:</span></td><td>Document
to generate XML text from</td></tr><tr><td><span
class=“term”>doc_txt_ptr
:</span></td><td>Memory
pointer for allocated XML
text</td></tr><tr><td><span
class=“term”>doc_txt_len
:</span></td><td>Length
of the generated XML text</td></tr><tr><td><span
class=“term”>txt_encoding
:</span></td><td>Character
encoding to use when generating XML
text</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlDocFormatDump"/>xmlDocFormatDump ()</h3><pre class="programlisting">int xmlDocFormatDump (FILE * f, <br/> <a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> cur, <br/> int format)<br/>
</pre><p>Dump an XML document to an open FILE.</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>f
:</span></td><td>the
FILE*</td></tr><tr><td><span
class=“term”>cur
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>format
:</span></td><td>should
formatting spaces been
added</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
number of bytes written or -1 in case of failure. Note that @format = 1
provide node indenting only if <a
href=“libxml2-globals.html#xmlIndentTreeOutput”>xmlIndentTreeOutput</a>
= 1 or xmlKeepBlanksDefault(0) was
called</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlDocGetRootElement"/>xmlDocGetRootElement ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlDocGetRootElement (const <a href="libxml2-tree.html#xmlDoc">xmlDoc</a> * doc)<br/>
</pre><p>Get the root element of the document
(doc->children is a list containing possibly comments, PIs, etc
…).</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
xmlNodePtr for the root or
NULL</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlDocSetRootElement"/>xmlDocSetRootElement ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlDocSetRootElement (<a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc, <br/> <a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> root)<br/>
</pre><p>Set the root element of the document
(doc->children is a list containing possibly comments, PIs, etc
…).</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>root
:</span></td><td>the
new document root element, if root is NULL no action is taken, to remove a
node from a document use xmlUnlinkNode(root)
instead.</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
old root element if any was found, NULL if root was
NULL</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlElemDump"/>xmlElemDump ()</h3><pre class="programlisting">void xmlElemDump (FILE * f, <br/> <a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc, <br/> <a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> cur)<br/>
</pre><p>Dump an XML/HTML node, recursive behaviour, children
are printed too.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>f
:</span></td><td>the
FILE * for the output</td></tr><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>cur
:</span></td><td>the
current
node</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlFirstElementChild"/>xmlFirstElementChild ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlFirstElementChild (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> parent)<br/>
</pre><p>Finds the first child node of that element which is a
Element node Note the handling of entities references is different than in
the W3C DOM element traversal spec since we don't have back <a
href=“libxml2-SAX.html#reference”>reference</a> from entities
content to entities references.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>parent
:</span></td><td>the
parent node</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
first element child or NULL if not
available</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlFreeDoc"/>xmlFreeDoc ()</h3><pre class="programlisting">void xmlFreeDoc (<a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> cur)<br/>
</pre><p>Free up all the structures used by a document, tree
included.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>cur
:</span></td><td>pointer
to the
document</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlFreeDtd"/>xmlFreeDtd ()</h3><pre class="programlisting">void xmlFreeDtd (<a href="libxml2-tree.html#xmlDtdPtr">xmlDtdPtr</a> cur)<br/>
</pre><p>Free a DTD structure.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>cur
:</span></td><td>the
DTD structure to free
up</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlFreeNode"/>xmlFreeNode ()</h3><pre class="programlisting">void xmlFreeNode (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> cur)<br/>
</pre><p>Free a node, this is a recursive behaviour, all the
children are freed too. This doesn't unlink the child from the list,
use xmlUnlinkNode() first.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>cur
:</span></td><td>the
node</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlFreeNodeList"/>xmlFreeNodeList ()</h3><pre class="programlisting">void xmlFreeNodeList (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> cur)<br/>
</pre><p>Free a node and all its siblings, this is a recursive
behaviour, all the children are freed too.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>cur
:</span></td><td>the
first node in the
list</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlFreeNs"/>xmlFreeNs ()</h3><pre class="programlisting">void xmlFreeNs (<a href="libxml2-tree.html#xmlNsPtr">xmlNsPtr</a> cur)<br/>
</pre><p>Free up the structures associated to a
namespace</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>cur
:</span></td><td>the
namespace
pointer</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlFreeNsList"/>xmlFreeNsList ()</h3><pre class="programlisting">void xmlFreeNsList (<a href="libxml2-tree.html#xmlNsPtr">xmlNsPtr</a> cur)<br/>
</pre><p>Free up all the structures associated to the chained
namespaces.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>cur
:</span></td><td>the
first namespace
pointer</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlFreeProp"/>xmlFreeProp ()</h3><pre class="programlisting">void xmlFreeProp (<a href="libxml2-tree.html#xmlAttrPtr">xmlAttrPtr</a> cur)<br/>
</pre><p>Free one attribute, all the content is freed
too</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>cur
:</span></td><td>an
<a
href=“libxml2-SAX.html#attribute”>attribute</a></td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlFreePropList"/>xmlFreePropList ()</h3><pre class="programlisting">void xmlFreePropList (<a href="libxml2-tree.html#xmlAttrPtr">xmlAttrPtr</a> cur)<br/>
</pre><p>Free a property and all its siblings, all the children
are freed too.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>cur
:</span></td><td>the
first property in the
list</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlGetBufferAllocationScheme"/>xmlGetBufferAllocationScheme ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlBufferAllocationScheme">xmlBufferAllocationScheme</a> xmlGetBufferAllocationScheme (void)<br/>
</pre><p>Types are <a
href=“libxml2-tree.html#XML_BUFFER_ALLOC_EXACT”>XML_BUFFER_ALLOC_EXACT</a>
- use exact sizes, keeps memory usage down <a
href=“libxml2-tree.html#XML_BUFFER_ALLOC_DOUBLEIT”>XML_BUFFER_ALLOC_DOUBLEIT</a>
- double buffer when extra needed, improves performance <a
href=“libxml2-tree.html#XML_BUFFER_ALLOC_HYBRID”>XML_BUFFER_ALLOC_HYBRID</a>
- use exact sizes on small strings to keep memory usage tight in normal
usage, and doubleit on large strings to avoid pathological
performance.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>Returns
:</span></td><td>the
current allocation
scheme</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlGetCompressMode"/>xmlGetCompressMode ()</h3><pre class="programlisting">int xmlGetCompressMode (void)<br/>
</pre><p>get the default compression mode used, ZLIB
based.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>Returns
:</span></td><td>0
(uncompressed) to 9 (max
compression)</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlGetDocCompressMode"/>xmlGetDocCompressMode ()</h3><pre class="programlisting">int xmlGetDocCompressMode (const <a href="libxml2-tree.html#xmlDoc">xmlDoc</a> * doc)<br/>
</pre><p>get the compression ratio for a document, ZLIB
based</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>0
(uncompressed) to 9 (max
compression)</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlGetIntSubset"/>xmlGetIntSubset ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlDtdPtr">xmlDtdPtr</a> xmlGetIntSubset (const <a href="libxml2-tree.html#xmlDoc">xmlDoc</a> * doc)<br/>
</pre><p>Get the internal subset of a document</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document pointer</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the DTD structure or NULL if not
found</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlGetLastChild"/>xmlGetLastChild ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlGetLastChild (const <a href="libxml2-tree.html#xmlNode">xmlNode</a> * parent)<br/>
</pre><p>Search the last child of a node.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>parent
:</span></td><td>the
parent node</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
last child or NULL if
none.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlGetLineNo"/>xmlGetLineNo ()</h3><pre class="programlisting">long xmlGetLineNo (const <a href="libxml2-tree.html#xmlNode">xmlNode</a> * node)<br/>
</pre><p>Get line number of @node. Try to override the
limitation of lines being store in 16 bits ints if <a
href=“libxml2-parser.html#XML_PARSE_BIG_LINES”>XML_PARSE_BIG_LINES</a>
parser option was used</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>node
:</span></td><td>valid
node</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
line number if successful, -1
otherwise</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlGetNoNsProp"/>xmlGetNoNsProp ()</h3><pre class="programlisting"><a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * xmlGetNoNsProp (const <a href="libxml2-tree.html#xmlNode">xmlNode</a> * node, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name)<br/>
</pre><p>Search and get the value of an <a
href=“libxml2-SAX.html#attribute”>attribute</a> associated to a
node This does the entity substitution. This function looks in DTD <a
href=“libxml2-SAX.html#attribute”>attribute</a> declaration for
#FIXED or default declaration values unless DTD use has been turned off.
This function is similar to <a
href=“libxml2-tree.html#xmlGetProp”>xmlGetProp</a> except it will
accept only an <a
href=“libxml2-SAX.html#attribute”>attribute</a> in no
namespace.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>node
:</span></td><td>the
node</td></tr><tr><td><span
class=“term”>name
:</span></td><td>the
<a href=“libxml2-SAX.html#attribute”>attribute</a>
name</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
<a href=“libxml2-SAX.html#attribute”>attribute</a> value or
NULL if not found. It's up to the caller to free the memory with
xmlFree().</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlGetNodePath"/>xmlGetNodePath ()</h3><pre class="programlisting"><a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * xmlGetNodePath (const <a href="libxml2-tree.html#xmlNode">xmlNode</a> * node)<br/>
</pre><p>Build a structure based Path for the given
node</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>node
:</span></td><td>a
node</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
new path or NULL in case of error. The caller must free the returned
string</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlGetNsList"/>xmlGetNsList ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNsPtr">xmlNsPtr</a> * xmlGetNsList (const <a href="libxml2-tree.html#xmlDoc">xmlDoc</a> * doc, <br/> const <a href="libxml2-tree.html#xmlNode">xmlNode</a> * node)<br/>
</pre><p>Search all the namespace applying to a given
element.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>node
:</span></td><td>the
current node</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>an
NULL terminated array of all the xmlNsPtr found that need to be freed by
the caller or NULL if no namespace if
defined</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlGetNsProp"/>xmlGetNsProp ()</h3><pre class="programlisting"><a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * xmlGetNsProp (const <a href="libxml2-tree.html#xmlNode">xmlNode</a> * node, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * nameSpace)<br/>
</pre><p>Search and get the value of an <a
href=“libxml2-SAX.html#attribute”>attribute</a> associated to a
node This <a href=“libxml2-SAX.html#attribute”>attribute</a>
has to be anchored in the namespace specified. This does the entity
substitution. This function looks in DTD <a
href=“libxml2-SAX.html#attribute”>attribute</a> declaration for
#FIXED or default declaration values unless DTD use has been turned
off.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>node
:</span></td><td>the
node</td></tr><tr><td><span
class=“term”>name
:</span></td><td>the
<a href=“libxml2-SAX.html#attribute”>attribute</a>
name</td></tr><tr><td><span
class=“term”>nameSpace
:</span></td><td>the
URI of the namespace</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
<a href=“libxml2-SAX.html#attribute”>attribute</a> value or
NULL if not found. It's up to the caller to free the memory with
xmlFree().</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlGetProp"/>xmlGetProp ()</h3><pre class="programlisting"><a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * xmlGetProp (const <a href="libxml2-tree.html#xmlNode">xmlNode</a> * node, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name)<br/>
</pre><p>Search and get the value of an <a
href=“libxml2-SAX.html#attribute”>attribute</a> associated to a
node This does the entity substitution. This function looks in DTD <a
href=“libxml2-SAX.html#attribute”>attribute</a> declaration for
#FIXED or default declaration values unless DTD use has been turned off.
NOTE: this function acts independently of namespaces associated to the
attribute. Use xmlGetNsProp() or xmlGetNoNsProp() for namespace aware
processing.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>node
:</span></td><td>the
node</td></tr><tr><td><span
class=“term”>name
:</span></td><td>the
<a href=“libxml2-SAX.html#attribute”>attribute</a>
name</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
<a href=“libxml2-SAX.html#attribute”>attribute</a> value or
NULL if not found. It's up to the caller to free the memory with
xmlFree().</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlHasNsProp"/>xmlHasNsProp ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlAttrPtr">xmlAttrPtr</a> xmlHasNsProp (const <a href="libxml2-tree.html#xmlNode">xmlNode</a> * node, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * nameSpace)<br/>
</pre><p>Search for an <a
href=“libxml2-SAX.html#attribute”>attribute</a> associated to a
node This <a href=“libxml2-SAX.html#attribute”>attribute</a>
has to be anchored in the namespace specified. This does the entity
substitution. This function looks in DTD <a
href=“libxml2-SAX.html#attribute”>attribute</a> declaration for
#FIXED or default declaration values unless DTD use has been turned off.
Note that a namespace of NULL indicates to use the default
namespace.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>node
:</span></td><td>the
node</td></tr><tr><td><span
class=“term”>name
:</span></td><td>the
<a href=“libxml2-SAX.html#attribute”>attribute</a>
name</td></tr><tr><td><span
class=“term”>nameSpace
:</span></td><td>the
URI of the namespace</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
<a href=“libxml2-SAX.html#attribute”>attribute</a> or the <a
href=“libxml2-SAX.html#attribute”>attribute</a> declaration or
NULL if neither was
found.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlHasProp"/>xmlHasProp ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlAttrPtr">xmlAttrPtr</a> xmlHasProp (const <a href="libxml2-tree.html#xmlNode">xmlNode</a> * node, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name)<br/>
</pre><p>Search an <a
href=“libxml2-SAX.html#attribute”>attribute</a> associated to a
node This function also looks in DTD <a
href=“libxml2-SAX.html#attribute”>attribute</a> declaration for
#FIXED or default declaration values unless DTD use has been turned
off.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>node
:</span></td><td>the
node</td></tr><tr><td><span
class=“term”>name
:</span></td><td>the
<a href=“libxml2-SAX.html#attribute”>attribute</a>
name</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
<a href=“libxml2-SAX.html#attribute”>attribute</a> or the <a
href=“libxml2-SAX.html#attribute”>attribute</a> declaration or
NULL if neither was
found.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlIsBlankNode"/>xmlIsBlankNode ()</h3><pre class="programlisting">int xmlIsBlankNode (const <a href="libxml2-tree.html#xmlNode">xmlNode</a> * node)<br/>
</pre><p>Checks whether this node is an empty or whitespace
only (and possibly ignorable) text-node.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>node
:</span></td><td>the
node</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>1
yes, 0
no</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlIsXHTML"/>xmlIsXHTML ()</h3><pre class="programlisting">int xmlIsXHTML (const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * systemID, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * publicID)<br/>
</pre><p>Try to find if the document correspond to an XHTML
DTD</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>systemID
:</span></td><td>the
system identifier</td></tr><tr><td><span
class=“term”>publicID
:</span></td><td>the
public identifier</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>1
if true, 0 if not and -1 in case of
error</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlLastElementChild"/>xmlLastElementChild ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlLastElementChild (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> parent)<br/>
</pre><p>Finds the last child node of that element which is a
Element node Note the handling of entities references is different than in
the W3C DOM element traversal spec since we don't have back <a
href=“libxml2-SAX.html#reference”>reference</a> from entities
content to entities references.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>parent
:</span></td><td>the
parent node</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
last element child or NULL if not
available</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNewCDataBlock"/>xmlNewCDataBlock ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlNewCDataBlock (<a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * content, <br/> int len)<br/>
</pre><p>Creation of a new node containing a CDATA
block.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>content
:</span></td><td>the
CDATA block content
content</td></tr><tr><td><span
class=“term”>len
:</span></td><td>the
length of the block</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the new node
object.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNewCharRef"/>xmlNewCharRef ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlNewCharRef (<a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name)<br/>
</pre><p>Creation of a new character <a
href=“libxml2-SAX.html#reference”>reference</a> node.</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>name
:</span></td><td>the
char ref string, starting with # or “&# …
;”</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the new node
object.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNewChild"/>xmlNewChild ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlNewChild (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> parent, <br/> <a href="libxml2-tree.html#xmlNsPtr">xmlNsPtr</a> ns, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * content)<br/>
</pre><p>Creation of a new child element, added at the end of
@parent children list. @ns and @content parameters are optional (NULL). If
@ns is NULL, the newly created element inherits the namespace of @parent.
If @content is non NULL, a child list containing the TEXTs and ENTITY_REFs
node will be created. NOTE: @content is supposed to be a piece of XML
CDATA, so it allows entity references. XML special chars must be escaped
first by using xmlEncodeEntitiesReentrant(), or xmlNewTextChild() should be
used.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>parent
:</span></td><td>the
parent node</td></tr><tr><td><span
class=“term”>ns
:</span></td><td>a
namespace if any</td></tr><tr><td><span
class=“term”>name
:</span></td><td>the
name of the child</td></tr><tr><td><span
class=“term”>content
:</span></td><td>the
XML content of the child if
any.</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the new node
object.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNewComment"/>xmlNewComment ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlNewComment (const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * content)<br/>
</pre><p>Creation of a new node containing a comment.</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>content
:</span></td><td>the
<a href=“libxml2-SAX.html#comment”>comment</a>
content</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the new node
object.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNewDoc"/>xmlNewDoc ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> xmlNewDoc (const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * version)<br/>
</pre><p>Creates a new XML document</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>version
:</span></td><td><a
href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a> string giving
the version of XML “1.0”</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
new
document</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNewDocComment"/>xmlNewDocComment ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlNewDocComment (<a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * content)<br/>
</pre><p>Creation of a new node containing a <a
href=“libxml2-SAX.html#comment”>comment</a> within a
document.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>content
:</span></td><td>the
<a href=“libxml2-SAX.html#comment”>comment</a>
content</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the new node
object.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNewDocFragment"/>xmlNewDocFragment ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlNewDocFragment (<a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc)<br/>
</pre><p>Creation of a new Fragment node.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document owning the
fragment</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the new node
object.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNewDocNode"/>xmlNewDocNode ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlNewDocNode (<a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc, <br/> <a href="libxml2-tree.html#xmlNsPtr">xmlNsPtr</a> ns, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * content)<br/>
</pre><p>Creation of a new node element within a document. @ns
and @content are optional (NULL). NOTE: @content is supposed to be a piece
of XML CDATA, so it allow entities references, but XML special chars need
to be escaped first by using xmlEncodeEntitiesReentrant(). Use
xmlNewDocRawNode() if you don't need entities support.</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>ns
:</span></td><td>namespace
if any</td></tr><tr><td><span
class=“term”>name
:</span></td><td>the
node name</td></tr><tr><td><span
class=“term”>content
:</span></td><td>the
XML text content if any</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the new node
object.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNewDocNodeEatName"/>xmlNewDocNodeEatName ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlNewDocNodeEatName (<a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc, <br/> <a href="libxml2-tree.html#xmlNsPtr">xmlNsPtr</a> ns, <br/> <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * content)<br/>
</pre><p>Creation of a new node element within a document. @ns
and @content are optional (NULL). NOTE: @content is supposed to be a piece
of XML CDATA, so it allow entities references, but XML special chars need
to be escaped first by using xmlEncodeEntitiesReentrant(). Use
xmlNewDocRawNode() if you don't need entities support.</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>ns
:</span></td><td>namespace
if any</td></tr><tr><td><span
class=“term”>name
:</span></td><td>the
node name</td></tr><tr><td><span
class=“term”>content
:</span></td><td>the
XML text content if any</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the new node
object.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNewDocPI"/>xmlNewDocPI ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlNewDocPI (<a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * content)<br/>
</pre><p>Creation of a processing instruction
element.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
target document</td></tr><tr><td><span
class=“term”>name
:</span></td><td>the
processing instruction
name</td></tr><tr><td><span
class=“term”>content
:</span></td><td>the
PI content</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the new node
object.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNewDocProp"/>xmlNewDocProp ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlAttrPtr">xmlAttrPtr</a> xmlNewDocProp (<a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * value)<br/>
</pre><p>Create a new property carried by a document.</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>name
:</span></td><td>the
name of the <a
href=“libxml2-SAX.html#attribute”>attribute</a></td></tr><tr><td><span
class=“term”>value
:</span></td><td>the
value of the <a
href=“libxml2-SAX.html#attribute”>attribute</a></td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the <a
href=“libxml2-SAX.html#attribute”>attribute</a></td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNewDocRawNode"/>xmlNewDocRawNode ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlNewDocRawNode (<a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc, <br/> <a href="libxml2-tree.html#xmlNsPtr">xmlNsPtr</a> ns, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * content)<br/>
</pre><p>Creation of a new node element within a document. @ns
and @content are optional (NULL).</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>ns
:</span></td><td>namespace
if any</td></tr><tr><td><span
class=“term”>name
:</span></td><td>the
node name</td></tr><tr><td><span
class=“term”>content
:</span></td><td>the
text content if any</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the new node
object.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNewDocText"/>xmlNewDocText ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlNewDocText (const <a href="libxml2-tree.html#xmlDoc">xmlDoc</a> * doc, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * content)<br/>
</pre><p>Creation of a new text node within a
document.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>content
:</span></td><td>the
text content</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the new node
object.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNewDocTextLen"/>xmlNewDocTextLen ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlNewDocTextLen (<a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * content, <br/> int len)<br/>
</pre><p>Creation of a new text node with an extra content
length parameter. The text node pertain to a given document.</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>content
:</span></td><td>the
text content</td></tr><tr><td><span
class=“term”>len
:</span></td><td>the
text len.</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the new node
object.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNewDtd"/>xmlNewDtd ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlDtdPtr">xmlDtdPtr</a> xmlNewDtd (<a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * ExternalID, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * SystemID)<br/>
</pre><p>Creation of a new DTD for the external subset. To
create an internal subset, use xmlCreateIntSubset().</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document pointer</td></tr><tr><td><span
class=“term”>name
:</span></td><td>the
DTD name</td></tr><tr><td><span
class=“term”>ExternalID
:</span></td><td>the
external ID</td></tr><tr><td><span
class=“term”>SystemID
:</span></td><td>the
system ID</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the new DTD
structure</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNewGlobalNs"/>xmlNewGlobalNs ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNsPtr">xmlNsPtr</a> xmlNewGlobalNs (<a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * href, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * prefix)<br/>
</pre><p>Creation of a Namespace, the old way using PI and
without scoping DEPRECATED !!!</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document carrying the
namespace</td></tr><tr><td><span
class=“term”>href
:</span></td><td>the
URI associated</td></tr><tr><td><span
class=“term”>prefix
:</span></td><td>the
prefix for the namespace</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>NULL
this functionality had been
removed</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNewNode"/>xmlNewNode ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlNewNode (<a href="libxml2-tree.html#xmlNsPtr">xmlNsPtr</a> ns, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name)<br/>
</pre><p>Creation of a new node element. @ns is optional
(NULL).</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>ns
:</span></td><td>namespace
if any</td></tr><tr><td><span
class=“term”>name
:</span></td><td>the
node name</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the new node object. Uses xmlStrdup() to make copy of
@name.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNewNodeEatName"/>xmlNewNodeEatName ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlNewNodeEatName (<a href="libxml2-tree.html#xmlNsPtr">xmlNsPtr</a> ns, <br/> <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name)<br/>
</pre><p>Creation of a new node element. @ns is optional
(NULL).</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>ns
:</span></td><td>namespace
if any</td></tr><tr><td><span
class=“term”>name
:</span></td><td>the
node name</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the new node object, with pointer @name as new node's name.
Use xmlNewNode() if a copy of @name string is is needed as new node's
name.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNewNs"/>xmlNewNs ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNsPtr">xmlNsPtr</a> xmlNewNs (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> node, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * href, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * prefix)<br/>
</pre><p>Creation of a new Namespace. This function will refuse
to create a namespace with a similar prefix than an existing one present on
this node. Note that for a default namespace, @prefix should be NULL. We
use href==NULL in the case of an element creation where the namespace was
not defined.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>node
:</span></td><td>the
element carrying the
namespace</td></tr><tr><td><span
class=“term”>href
:</span></td><td>the
URI associated</td></tr><tr><td><span
class=“term”>prefix
:</span></td><td>the
prefix for the namespace</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
new namespace pointer or
NULL</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNewNsProp"/>xmlNewNsProp ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlAttrPtr">xmlAttrPtr</a> xmlNewNsProp (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> node, <br/> <a href="libxml2-tree.html#xmlNsPtr">xmlNsPtr</a> ns, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * value)<br/>
</pre><p>Create a new property tagged with a namespace and
carried by a node.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>node
:</span></td><td>the
holding node</td></tr><tr><td><span
class=“term”>ns
:</span></td><td>the
namespace</td></tr><tr><td><span
class=“term”>name
:</span></td><td>the
name of the <a
href=“libxml2-SAX.html#attribute”>attribute</a></td></tr><tr><td><span
class=“term”>value
:</span></td><td>the
value of the <a
href=“libxml2-SAX.html#attribute”>attribute</a></td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the <a
href=“libxml2-SAX.html#attribute”>attribute</a></td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNewNsPropEatName"/>xmlNewNsPropEatName ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlAttrPtr">xmlAttrPtr</a> xmlNewNsPropEatName (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> node, <br/> <a href="libxml2-tree.html#xmlNsPtr">xmlNsPtr</a> ns, <br/> <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * value)<br/>
</pre><p>Create a new property tagged with a namespace and
carried by a node.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>node
:</span></td><td>the
holding node</td></tr><tr><td><span
class=“term”>ns
:</span></td><td>the
namespace</td></tr><tr><td><span
class=“term”>name
:</span></td><td>the
name of the <a
href=“libxml2-SAX.html#attribute”>attribute</a></td></tr><tr><td><span
class=“term”>value
:</span></td><td>the
value of the <a
href=“libxml2-SAX.html#attribute”>attribute</a></td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the <a
href=“libxml2-SAX.html#attribute”>attribute</a></td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNewPI"/>xmlNewPI ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlNewPI (const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * content)<br/>
</pre><p>Creation of a processing instruction element. Use
xmlDocNewPI preferably to get string interning</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>name
:</span></td><td>the
processing instruction
name</td></tr><tr><td><span
class=“term”>content
:</span></td><td>the
PI content</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the new node
object.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNewProp"/>xmlNewProp ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlAttrPtr">xmlAttrPtr</a> xmlNewProp (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> node, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * value)<br/>
</pre><p>Create a new property carried by a node.</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>node
:</span></td><td>the
holding node</td></tr><tr><td><span
class=“term”>name
:</span></td><td>the
name of the <a
href=“libxml2-SAX.html#attribute”>attribute</a></td></tr><tr><td><span
class=“term”>value
:</span></td><td>the
value of the <a
href=“libxml2-SAX.html#attribute”>attribute</a></td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the <a
href=“libxml2-SAX.html#attribute”>attribute</a></td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNewReference"/>xmlNewReference ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlNewReference (const <a href="libxml2-tree.html#xmlDoc">xmlDoc</a> * doc, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name)<br/>
</pre><p>Creation of a new <a
href=“libxml2-SAX.html#reference”>reference</a> node.</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>name
:</span></td><td>the
<a href=“libxml2-SAX.html#reference”>reference</a> name, or the
<a href=“libxml2-SAX.html#reference”>reference</a> string with
& and ;</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the new node
object.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNewText"/>xmlNewText ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlNewText (const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * content)<br/>
</pre><p>Creation of a new text node.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>content
:</span></td><td>the
text content</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the new node
object.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNewTextChild"/>xmlNewTextChild ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlNewTextChild (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> parent, <br/> <a href="libxml2-tree.html#xmlNsPtr">xmlNsPtr</a> ns, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * content)<br/>
</pre><p>Creation of a new child element, added at the end of
@parent children list. @ns and @content parameters are optional (NULL). If
@ns is NULL, the newly created element inherits the namespace of @parent.
If @content is non NULL, a child TEXT node will be created containing the
string @content. NOTE: Use xmlNewChild() if @content will contain entities
that need to be preserved. Use this function, xmlNewTextChild(), if you
need to ensure that reserved XML chars that might appear in @content, such
as the ampersand, greater-than or less-than signs, are automatically
replaced by their XML escaped entity representations.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>parent
:</span></td><td>the
parent node</td></tr><tr><td><span
class=“term”>ns
:</span></td><td>a
namespace if any</td></tr><tr><td><span
class=“term”>name
:</span></td><td>the
name of the child</td></tr><tr><td><span
class=“term”>content
:</span></td><td>the
text content of the child if
any.</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the new node
object.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNewTextLen"/>xmlNewTextLen ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlNewTextLen (const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * content, <br/> int len)<br/>
</pre><p>Creation of a new text node with an extra parameter
for the content's length</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>content
:</span></td><td>the
text content</td></tr><tr><td><span
class=“term”>len
:</span></td><td>the
text len.</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the new node
object.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNextElementSibling"/>xmlNextElementSibling ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlNextElementSibling (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> node)<br/>
</pre><p>Finds the first closest next sibling of the node which
is an element node. Note the handling of entities references is different
than in the W3C DOM element traversal spec since we don't have back
<a href=“libxml2-SAX.html#reference”>reference</a> from
entities content to entities references.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>node
:</span></td><td>the
current node</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
next element sibling or NULL if not
available</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNodeAddContent"/>xmlNodeAddContent ()</h3><pre class="programlisting">void xmlNodeAddContent (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> cur, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * content)<br/>
</pre><p>Append the extra substring to the node content. NOTE:
In contrast to xmlNodeSetContent(), @content is supposed to be raw text, so
unescaped XML special chars are allowed, entity references are not
supported.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>cur
:</span></td><td>the
node being modified</td></tr><tr><td><span
class=“term”>content
:</span></td><td>extra
content</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNodeAddContentLen"/>xmlNodeAddContentLen ()</h3><pre class="programlisting">void xmlNodeAddContentLen (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> cur, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * content, <br/> int len)<br/>
</pre><p>Append the extra substring to the node content. NOTE:
In contrast to xmlNodeSetContentLen(), @content is supposed to be raw text,
so unescaped XML special chars are allowed, entity references are not
supported.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>cur
:</span></td><td>the
node being modified</td></tr><tr><td><span
class=“term”>content
:</span></td><td>extra
content</td></tr><tr><td><span
class=“term”>len
:</span></td><td>the
size of
@content</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNodeBufGetContent"/>xmlNodeBufGetContent ()</h3><pre class="programlisting">int xmlNodeBufGetContent (<a href="libxml2-tree.html#xmlBufferPtr">xmlBufferPtr</a> buffer, <br/> const <a href="libxml2-tree.html#xmlNode">xmlNode</a> * cur)<br/>
</pre><p>Read the value of a node @cur, this can be either the
text carried directly by this node if it's a TEXT node or the aggregate
string of the values carried by this node child's (TEXT and
ENTITY_REF). Entity references are substituted. Fills up the buffer @buffer
with this value</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>buffer
:</span></td><td>a
buffer</td></tr><tr><td><span
class=“term”>cur
:</span></td><td>the
node being read</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>0
in case of success and -1 in case of
error.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNodeDump"/>xmlNodeDump ()</h3><pre class="programlisting">int xmlNodeDump (<a href="libxml2-tree.html#xmlBufferPtr">xmlBufferPtr</a> buf, <br/> <a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc, <br/> <a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> cur, <br/> int level, <br/> int format)<br/>
</pre><p>Dump an XML node, recursive behaviour,children are
printed too. Note that @format = 1 provide node indenting only if <a
href=“libxml2-globals.html#xmlIndentTreeOutput”>xmlIndentTreeOutput</a>
= 1 or xmlKeepBlanksDefault(0) was called. Since this is using <a
href=“libxml2-tree.html#xmlBuffer”>xmlBuffer</a> structures it is
limited to 2GB and somehow deprecated, use xmlNodeDumpOutput()
instead.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>buf
:</span></td><td>the
XML buffer output</td></tr><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>cur
:</span></td><td>the
current node</td></tr><tr><td><span
class=“term”>level
:</span></td><td>the
imbrication level for
indenting</td></tr><tr><td><span
class=“term”>format
:</span></td><td>is
formatting allowed</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
number of bytes written to the buffer or -1 in case of
error</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNodeDumpOutput"/>xmlNodeDumpOutput ()</h3><pre class="programlisting">void xmlNodeDumpOutput (<a href="libxml2-tree.html#xmlOutputBufferPtr">xmlOutputBufferPtr</a> buf, <br/> <a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc, <br/> <a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> cur, <br/> int level, <br/> int format, <br/> const char * encoding)<br/>
</pre><p>Dump an XML node, recursive behaviour, children are
printed too. Note that @format = 1 provide node indenting only if <a
href=“libxml2-globals.html#xmlIndentTreeOutput”>xmlIndentTreeOutput</a>
= 1 or xmlKeepBlanksDefault(0) was called</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>buf
:</span></td><td>the
XML buffer output</td></tr><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>cur
:</span></td><td>the
current node</td></tr><tr><td><span
class=“term”>level
:</span></td><td>the
imbrication level for
indenting</td></tr><tr><td><span
class=“term”>format
:</span></td><td>is
formatting allowed</td></tr><tr><td><span
class=“term”>encoding
:</span></td><td>an
optional encoding
string</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNodeGetBase"/>xmlNodeGetBase ()</h3><pre class="programlisting"><a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * xmlNodeGetBase (const <a href="libxml2-tree.html#xmlDoc">xmlDoc</a> * doc, <br/> const <a href="libxml2-tree.html#xmlNode">xmlNode</a> * cur)<br/>
</pre><p>Searches for the BASE URL. The code should work on
both XML and HTML document even if base mechanisms are completely
different. It returns the base as defined in RFC 2396 sections 5.1.1. Base
URI within Document Content and 5.1.2. Base URI from the Encapsulating
Entity However it does not return the document base (5.1.3), use
doc->URL in this case</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document the node pertains
to</td></tr><tr><td><span
class=“term”>cur
:</span></td><td>the
node being checked</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the base URL, or NULL if not found It's up to the caller to
free the memory with
xmlFree().</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNodeGetContent"/>xmlNodeGetContent ()</h3><pre class="programlisting"><a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * xmlNodeGetContent (const <a href="libxml2-tree.html#xmlNode">xmlNode</a> * cur)<br/>
</pre><p>Read the value of a node, this can be either the text
carried directly by this node if it's a TEXT node or the aggregate
string of the values carried by this node child's (TEXT and
ENTITY_REF). Entity references are substituted.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>cur
:</span></td><td>the
node being read</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
new xmlChar * or NULL if no content is available. It's up to the caller
to free the memory with
xmlFree().</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNodeGetLang"/>xmlNodeGetLang ()</h3><pre class="programlisting"><a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * xmlNodeGetLang (const <a href="libxml2-tree.html#xmlNode">xmlNode</a> * cur)<br/>
</pre><p>Searches the language of a node, i.e. the values of
the xml:lang <a href=“libxml2-SAX.html#attribute”>attribute</a>
or the one carried by the nearest ancestor.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>cur
:</span></td><td>the
node being checked</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the lang value, or NULL if not found It's up to the caller
to free the memory with
xmlFree().</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNodeGetSpacePreserve"/>xmlNodeGetSpacePreserve ()</h3><pre class="programlisting">int xmlNodeGetSpacePreserve (const <a href="libxml2-tree.html#xmlNode">xmlNode</a> * cur)<br/>
</pre><p>Searches the space preserving behaviour of a node,
i.e. the values of the xml:space <a
href=“libxml2-SAX.html#attribute”>attribute</a> or the one carried
by the nearest ancestor.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>cur
:</span></td><td>the
node being checked</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>-1
if xml:space is not inherited, 0 if “default”, 1 if
“preserve”</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNodeIsText"/>xmlNodeIsText ()</h3><pre class="programlisting">int xmlNodeIsText (const <a href="libxml2-tree.html#xmlNode">xmlNode</a> * node)<br/>
</pre><p>Is this node a Text node ?</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>node
:</span></td><td>the
node</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>1
yes, 0
no</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNodeListGetRawString"/>xmlNodeListGetRawString ()</h3><pre class="programlisting"><a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * xmlNodeListGetRawString (const <a href="libxml2-tree.html#xmlDoc">xmlDoc</a> * doc, <br/> const <a href="libxml2-tree.html#xmlNode">xmlNode</a> * list, <br/> int inLine)<br/>
</pre><p>Builds the string equivalent to the text contained in
the Node list made of TEXTs and ENTITY_REFs, contrary to
xmlNodeListGetString() this function doesn't do any character encoding
handling.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>list
:</span></td><td>a
Node list</td></tr><tr><td><span
class=“term”>inLine
:</span></td><td>should
we replace entity contents or show their external
form</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the string copy, the caller must free it with
xmlFree().</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNodeListGetString"/>xmlNodeListGetString ()</h3><pre class="programlisting"><a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * xmlNodeListGetString (<a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc, <br/> const <a href="libxml2-tree.html#xmlNode">xmlNode</a> * list, <br/> int inLine)<br/>
</pre><p>Build the string equivalent to the text contained in
the Node list made of TEXTs and ENTITY_REFs</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>list
:</span></td><td>a
Node list</td></tr><tr><td><span
class=“term”>inLine
:</span></td><td>should
we replace entity contents or show their external
form</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the string copy, the caller must free it with
xmlFree().</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNodeSetBase"/>xmlNodeSetBase ()</h3><pre class="programlisting">void xmlNodeSetBase (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> cur, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * uri)<br/>
</pre><p>Set (or reset) the base URI of a node, i.e. the value
of the xml:base attribute.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>cur
:</span></td><td>the
node being changed</td></tr><tr><td><span
class=“term”>uri
:</span></td><td>the
new base
URI</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNodeSetContent"/>xmlNodeSetContent ()</h3><pre class="programlisting">void xmlNodeSetContent (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> cur, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * content)<br/>
</pre><p>Replace the content of a node. NOTE: @content is
supposed to be a piece of XML CDATA, so it allows entity references, but
XML special chars need to be escaped first by using
xmlEncodeEntitiesReentrant() resp. xmlEncodeSpecialChars().</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>cur
:</span></td><td>the
node being modified</td></tr><tr><td><span
class=“term”>content
:</span></td><td>the
new value of the
content</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNodeSetContentLen"/>xmlNodeSetContentLen ()</h3><pre class="programlisting">void xmlNodeSetContentLen (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> cur, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * content, <br/> int len)<br/>
</pre><p>Replace the content of a node. NOTE: @content is
supposed to be a piece of XML CDATA, so it allows entity references, but
XML special chars need to be escaped first by using
xmlEncodeEntitiesReentrant() resp. xmlEncodeSpecialChars().</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>cur
:</span></td><td>the
node being modified</td></tr><tr><td><span
class=“term”>content
:</span></td><td>the
new value of the content</td></tr><tr><td><span
class=“term”>len
:</span></td><td>the
size of
@content</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNodeSetLang"/>xmlNodeSetLang ()</h3><pre class="programlisting">void xmlNodeSetLang (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> cur, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * lang)<br/>
</pre><p>Set the language of a node, i.e. the values of the
xml:lang attribute.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>cur
:</span></td><td>the
node being changed</td></tr><tr><td><span
class=“term”>lang
:</span></td><td>the
language
description</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNodeSetName"/>xmlNodeSetName ()</h3><pre class="programlisting">void xmlNodeSetName (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> cur, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name)<br/>
</pre><p>Set (or reset) the name of a node.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>cur
:</span></td><td>the
node being changed</td></tr><tr><td><span
class=“term”>name
:</span></td><td>the
new tag
name</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlNodeSetSpacePreserve"/>xmlNodeSetSpacePreserve ()</h3><pre class="programlisting">void xmlNodeSetSpacePreserve (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> cur, <br/> int val)<br/>
</pre><p>Set (or reset) the space preserving behaviour of a
node, i.e. the value of the xml:space attribute.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>cur
:</span></td><td>the
node being changed</td></tr><tr><td><span
class=“term”>val
:</span></td><td>the
xml:space value (“0”: default, 1:
“preserve”)</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlPreviousElementSibling"/>xmlPreviousElementSibling ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlPreviousElementSibling (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> node)<br/>
</pre><p>Finds the first closest previous sibling of the node
which is an element node. Note the handling of entities references is
different than in the W3C DOM element traversal spec since we don't
have back <a href=“libxml2-SAX.html#reference”>reference</a>
from entities content to entities references.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>node
:</span></td><td>the
current node</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
previous element sibling or NULL if not
available</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlReconciliateNs"/>xmlReconciliateNs ()</h3><pre class="programlisting">int xmlReconciliateNs (<a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc, <br/> <a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> tree)<br/>
</pre><p>This function checks that all the namespaces declared
within the given tree are properly declared. This is needed for example
after Copy or Cut and then paste operations. The subtree may still hold
pointers to namespace declarations outside the subtree or invalid/masked.
As much as possible the function try to reuse the existing namespaces found
in the new environment. If not possible the new namespaces are redeclared
on @tree at the top of the given subtree.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>tree
:</span></td><td>a
node defining the subtree to
reconciliate</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
number of namespace declarations created or -1 in case of
error.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlRemoveProp"/>xmlRemoveProp ()</h3><pre class="programlisting">int xmlRemoveProp (<a href="libxml2-tree.html#xmlAttrPtr">xmlAttrPtr</a> cur)<br/>
</pre><p>Unlink and free one attribute, all the content is
freed too Note this doesn't work for namespace definition
attributes</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>cur
:</span></td><td>an
<a
href=“libxml2-SAX.html#attribute”>attribute</a></td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>0
if success and -1 in case of
error.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlReplaceNode"/>xmlReplaceNode ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlReplaceNode (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> old, <br/> <a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> cur)<br/>
</pre><p>Unlink the old node from its current context, prune
the new one at the same place. If @cur was already inserted in a document
it is first unlinked from its existing context.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>old
:</span></td><td>the
old node</td></tr><tr><td><span
class=“term”>cur
:</span></td><td>the
node</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
@old
node</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlSaveFile"/>xmlSaveFile ()</h3><pre class="programlisting">int xmlSaveFile (const char * filename, <br/> <a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> cur)<br/>
</pre><p>Dump an XML document to a file. Will use compression
if compiled in and enabled. If @filename is “-” the stdout file is
used.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>filename
:</span></td><td>the
filename (or URL)</td></tr><tr><td><span
class=“term”>cur
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
number of bytes written or -1 in case of
failure.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlSaveFileEnc"/>xmlSaveFileEnc ()</h3><pre class="programlisting">int xmlSaveFileEnc (const char * filename, <br/> <a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> cur, <br/> const char * encoding)<br/>
</pre><p>Dump an XML document, converting it to the given
encoding</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>filename
:</span></td><td>the
filename (or URL)</td></tr><tr><td><span
class=“term”>cur
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>encoding
:</span></td><td>the
name of an encoding (or
NULL)</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
number of bytes written or -1 in case of
failure.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlSaveFileTo"/>xmlSaveFileTo ()</h3><pre class="programlisting">int xmlSaveFileTo (<a href="libxml2-tree.html#xmlOutputBufferPtr">xmlOutputBufferPtr</a> buf, <br/> <a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> cur, <br/> const char * encoding)<br/>
</pre><p>Dump an XML document to an I/O buffer. Warning ! This
call xmlOutputBufferClose() on buf which is not available after this
call.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>buf
:</span></td><td>an
output I/O buffer</td></tr><tr><td><span
class=“term”>cur
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>encoding
:</span></td><td>the
encoding if any assuming the I/O layer handles the
transcoding</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
number of bytes written or -1 in case of
failure.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlSaveFormatFile"/>xmlSaveFormatFile ()</h3><pre class="programlisting">int xmlSaveFormatFile (const char * filename, <br/> <a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> cur, <br/> int format)<br/>
</pre><p>Dump an XML document to a file. Will use compression
if compiled in and enabled. If @filename is “-” the stdout file is used. If
@format is set then the document will be indented on output. Note that
@format = 1 provide node indenting only if <a
href=“libxml2-globals.html#xmlIndentTreeOutput”>xmlIndentTreeOutput</a>
= 1 or xmlKeepBlanksDefault(0) was called</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>filename
:</span></td><td>the
filename (or URL)</td></tr><tr><td><span
class=“term”>cur
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>format
:</span></td><td>should
formatting spaces been
added</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
number of bytes written or -1 in case of
failure.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlSaveFormatFileEnc"/>xmlSaveFormatFileEnc ()</h3><pre class="programlisting">int xmlSaveFormatFileEnc (const char * filename, <br/> <a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> cur, <br/> const char * encoding, <br/> int format)<br/>
</pre><p>Dump an XML document to a file or an URL.</p>
<div class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>filename
:</span></td><td>the
filename or URL to output</td></tr><tr><td><span
class=“term”>cur
:</span></td><td>the
document being saved</td></tr><tr><td><span
class=“term”>encoding
:</span></td><td>the
name of the encoding to use or
NULL.</td></tr><tr><td><span
class=“term”>format
:</span></td><td>should
formatting spaces be
added.</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
number of bytes written or -1 in case of error. Note that @format = 1
provide node indenting only if <a
href=“libxml2-globals.html#xmlIndentTreeOutput”>xmlIndentTreeOutput</a>
= 1 or xmlKeepBlanksDefault(0) was
called</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlSaveFormatFileTo"/>xmlSaveFormatFileTo ()</h3><pre class="programlisting">int xmlSaveFormatFileTo (<a href="libxml2-tree.html#xmlOutputBufferPtr">xmlOutputBufferPtr</a> buf, <br/> <a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> cur, <br/> const char * encoding, <br/> int format)<br/>
</pre><p>Dump an XML document to an I/O buffer. Warning ! This
call xmlOutputBufferClose() on buf which is not available after this
call.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>buf
:</span></td><td>an
output I/O buffer</td></tr><tr><td><span
class=“term”>cur
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>encoding
:</span></td><td>the
encoding if any assuming the I/O layer handles the
transcoding</td></tr><tr><td><span
class=“term”>format
:</span></td><td>should
formatting spaces been
added</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
number of bytes written or -1 in case of
failure.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlSearchNs"/>xmlSearchNs ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNsPtr">xmlNsPtr</a> xmlSearchNs (<a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc, <br/> <a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> node, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * nameSpace)<br/>
</pre><p>Search a Ns registered under a given name space for a
document. recurse on the parents until it finds the defined namespace or
return NULL otherwise. @nameSpace can be NULL, this is a search for the
default namespace. We don't allow to cross entities boundaries. If you
don't declare the namespace within those you will be in troubles !!! A
warning is generated to cover this case.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>node
:</span></td><td>the
current node</td></tr><tr><td><span
class=“term”>nameSpace
:</span></td><td>the
namespace prefix</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
namespace pointer or
NULL.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlSearchNsByHref"/>xmlSearchNsByHref ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNsPtr">xmlNsPtr</a> xmlSearchNsByHref (<a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc, <br/> <a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> node, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * href)<br/>
</pre><p>Search a Ns aliasing a given URI. Recurse on the
parents until it finds the defined namespace or return NULL
otherwise.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>node
:</span></td><td>the
current node</td></tr><tr><td><span
class=“term”>href
:</span></td><td>the
namespace value</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
namespace pointer or
NULL.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlSetBufferAllocationScheme"/>xmlSetBufferAllocationScheme ()</h3><pre class="programlisting">void xmlSetBufferAllocationScheme (<a href="libxml2-tree.html#xmlBufferAllocationScheme">xmlBufferAllocationScheme</a> scheme)<br/>
</pre><p>Set the buffer allocation method. Types are <a
href=“libxml2-tree.html#XML_BUFFER_ALLOC_EXACT”>XML_BUFFER_ALLOC_EXACT</a>
- use exact sizes, keeps memory usage down <a
href=“libxml2-tree.html#XML_BUFFER_ALLOC_DOUBLEIT”>XML_BUFFER_ALLOC_DOUBLEIT</a>
- double buffer when extra needed, improves performance</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>scheme
:</span></td><td>allocation
method to
use</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlSetCompressMode"/>xmlSetCompressMode ()</h3><pre class="programlisting">void xmlSetCompressMode (int mode)<br/>
</pre><p>set the default compression mode used, ZLIB based
Correct values: 0 (uncompressed) to 9 (max compression)</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>mode
:</span></td><td>the
compression
ratio</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlSetDocCompressMode"/>xmlSetDocCompressMode ()</h3><pre class="programlisting">void xmlSetDocCompressMode (<a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc, <br/> int mode)<br/>
</pre><p>set the compression ratio for a document, ZLIB based
Correct values: 0 (uncompressed) to 9 (max compression)</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>mode
:</span></td><td>the
compression
ratio</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlSetListDoc"/>xmlSetListDoc ()</h3><pre class="programlisting">void xmlSetListDoc (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> list, <br/> <a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc)<br/>
</pre><p>update all nodes in the list to point to the right
document</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>list
:</span></td><td>the
first element</td></tr><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlSetNs"/>xmlSetNs ()</h3><pre class="programlisting">void xmlSetNs (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> node, <br/> <a href="libxml2-tree.html#xmlNsPtr">xmlNsPtr</a> ns)<br/>
</pre><p>Associate a namespace to a node, a
posteriori.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>node
:</span></td><td>a
node in the document</td></tr><tr><td><span
class=“term”>ns
:</span></td><td>a
namespace
pointer</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlSetNsProp"/>xmlSetNsProp ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlAttrPtr">xmlAttrPtr</a> xmlSetNsProp (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> node, <br/> <a href="libxml2-tree.html#xmlNsPtr">xmlNsPtr</a> ns, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * value)<br/>
</pre><p>Set (or reset) an <a
href=“libxml2-SAX.html#attribute”>attribute</a> carried by a node.
The ns structure must be in scope, this is not checked</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>node
:</span></td><td>the
node</td></tr><tr><td><span
class=“term”>ns
:</span></td><td>the
namespace definition</td></tr><tr><td><span
class=“term”>name
:</span></td><td>the
<a href=“libxml2-SAX.html#attribute”>attribute</a>
name</td></tr><tr><td><span
class=“term”>value
:</span></td><td>the
<a href=“libxml2-SAX.html#attribute”>attribute</a>
value</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
<a href=“libxml2-SAX.html#attribute”>attribute</a>
pointer.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlSetProp"/>xmlSetProp ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlAttrPtr">xmlAttrPtr</a> xmlSetProp (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> node, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * value)<br/>
</pre><p>Set (or reset) an <a
href=“libxml2-SAX.html#attribute”>attribute</a> carried by a node.
If @name has a prefix, then the corresponding namespace-binding will be
used, if in scope; it is an error it there's no such ns-binding for the
prefix in scope.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>node
:</span></td><td>the
node</td></tr><tr><td><span
class=“term”>name
:</span></td><td>the
<a href=“libxml2-SAX.html#attribute”>attribute</a> name (a
QName)</td></tr><tr><td><span
class=“term”>value
:</span></td><td>the
<a href=“libxml2-SAX.html#attribute”>attribute</a>
value</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
<a href=“libxml2-SAX.html#attribute”>attribute</a>
pointer.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlSetTreeDoc"/>xmlSetTreeDoc ()</h3><pre class="programlisting">void xmlSetTreeDoc (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> tree, <br/> <a href="libxml2-tree.html#xmlDocPtr">xmlDocPtr</a> doc)<br/>
</pre><p>update all nodes under the tree to point to the right
document</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>tree
:</span></td><td>the
top element</td></tr><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlSplitQName2"/>xmlSplitQName2 ()</h3><pre class="programlisting"><a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * xmlSplitQName2 (const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name, <br/> <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> ** prefix)<br/>
</pre><p>parse an XML qualified name string [NS 5] QName ::=
(Prefix ':')? LocalPart [NS 6] Prefix ::= NCName [NS 7] LocalPart
::= NCName</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>name
:</span></td><td>the
full QName</td></tr><tr><td><span
class=“term”>prefix
:</span></td><td>a
<a href=“libxml2-xmlstring.html#xmlChar”>xmlChar</a>
**</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>NULL
if the name doesn't have a prefix. Otherwise, returns the local part,
and prefix is updated to get the Prefix. Both the return value and the
prefix must be freed by the
caller.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlSplitQName3"/>xmlSplitQName3 ()</h3><pre class="programlisting">const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * xmlSplitQName3 (const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name, <br/> int * len)<br/>
</pre><p>parse an XML qualified name string,i</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>name
:</span></td><td>the
full QName</td></tr><tr><td><span
class=“term”>len
:</span></td><td>an
int *</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>NULL
if it is not a Qualified Name, otherwise, update len with the length in
byte of the prefix and return a pointer to the start of the name without
the
prefix</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlStringGetNodeList"/>xmlStringGetNodeList ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlStringGetNodeList (const <a href="libxml2-tree.html#xmlDoc">xmlDoc</a> * doc, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * value)<br/>
</pre><p>Parse the value string and build the node list
associated. Should produce a flat tree with only TEXTs and
ENTITY_REFs.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>value
:</span></td><td>the
value of the <a
href=“libxml2-SAX.html#attribute”>attribute</a></td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the first
child</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlStringLenGetNodeList"/>xmlStringLenGetNodeList ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlStringLenGetNodeList (const <a href="libxml2-tree.html#xmlDoc">xmlDoc</a> * doc, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * value, <br/> int len)<br/>
</pre><p>Parse the value string and build the node list
associated. Should produce a flat tree with only TEXTs and
ENTITY_REFs.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>doc
:</span></td><td>the
document</td></tr><tr><td><span
class=“term”>value
:</span></td><td>the
value of the text</td></tr><tr><td><span
class=“term”>len
:</span></td><td>the
length of the string
value</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>a
pointer to the first
child</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlTextConcat"/>xmlTextConcat ()</h3><pre class="programlisting">int xmlTextConcat (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> node, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * content, <br/> int len)<br/>
</pre><p>Concat the given string at the end of the existing
node content</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>node
:</span></td><td>the
node</td></tr><tr><td><span
class=“term”>content
:</span></td><td>the
content</td></tr><tr><td><span
class=“term”>len
:</span></td><td>@content
length</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>-1
in case of error, 0
otherwise</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlTextMerge"/>xmlTextMerge ()</h3><pre class="programlisting"><a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> xmlTextMerge (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> first, <br/> <a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> second)<br/>
</pre><p>Merge two text nodes into one</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>first
:</span></td><td>the
first text node</td></tr><tr><td><span
class=“term”>second
:</span></td><td>the
second text node being
merged</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>the
first text node
augmented</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlUnlinkNode"/>xmlUnlinkNode ()</h3><pre class="programlisting">void xmlUnlinkNode (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> cur)<br/>
</pre><p>Unlink a node from it's current context, the node
is not freed If one need to free the node, use xmlFreeNode() routine after
the unlink to discard it. Note that namespace nodes can't be unlinked
as they do not have pointer to their parent.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>cur
:</span></td><td>the
node</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlUnsetNsProp"/>xmlUnsetNsProp ()</h3><pre class="programlisting">int xmlUnsetNsProp (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> node, <br/> <a href="libxml2-tree.html#xmlNsPtr">xmlNsPtr</a> ns, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name)<br/>
</pre><p>Remove an <a
href=“libxml2-SAX.html#attribute”>attribute</a> carried by a
node.</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>node
:</span></td><td>the
node</td></tr><tr><td><span
class=“term”>ns
:</span></td><td>the
namespace definition</td></tr><tr><td><span
class=“term”>name
:</span></td><td>the
<a href=“libxml2-SAX.html#attribute”>attribute</a>
name</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>0
if successful, -1 if not
found</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlUnsetProp"/>xmlUnsetProp ()</h3><pre class="programlisting">int xmlUnsetProp (<a href="libxml2-tree.html#xmlNodePtr">xmlNodePtr</a> node, <br/> const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * name)<br/>
</pre><p>Remove an <a
href=“libxml2-SAX.html#attribute”>attribute</a> carried by a node.
This handles only attributes in no namespace.</p> <div
class=“variablelist”><table border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>node
:</span></td><td>the
node</td></tr><tr><td><span
class=“term”>name
:</span></td><td>the
<a href=“libxml2-SAX.html#attribute”>attribute</a>
name</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>0
if successful, -1 if not
found</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlValidateNCName"/>xmlValidateNCName ()</h3><pre class="programlisting">int xmlValidateNCName (const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * value, <br/> int space)<br/>
</pre><p>Check that a value conforms to the lexical space of
NCName</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>value
:</span></td><td>the
value to check</td></tr><tr><td><span
class=“term”>space
:</span></td><td>allow
spaces in front and end of the
string</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>0
if this validates, a positive error code number otherwise and -1 in case of
internal or API
error.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlValidateNMToken"/>xmlValidateNMToken ()</h3><pre class="programlisting">int xmlValidateNMToken (const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * value, <br/> int space)<br/>
</pre><p>Check that a value conforms to the lexical space of
NMToken</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>value
:</span></td><td>the
value to check</td></tr><tr><td><span
class=“term”>space
:</span></td><td>allow
spaces in front and end of the
string</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>0
if this validates, a positive error code number otherwise and -1 in case of
internal or API
error.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlValidateName"/>xmlValidateName ()</h3><pre class="programlisting">int xmlValidateName (const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * value, <br/> int space)<br/>
</pre><p>Check that a value conforms to the lexical space of
Name</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>value
:</span></td><td>the
value to check</td></tr><tr><td><span
class=“term”>space
:</span></td><td>allow
spaces in front and end of the
string</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>0
if this validates, a positive error code number otherwise and -1 in case of
internal or API
error.</td></tr></tbody></table></div></div>
<hr/> <div class="refsect2" lang="en"><h3><a name="xmlValidateQName"/>xmlValidateQName ()</h3><pre class="programlisting">int xmlValidateQName (const <a href="libxml2-xmlstring.html#xmlChar">xmlChar</a> * value, <br/> int space)<br/>
</pre><p>Check that a value conforms to the lexical space of
QName</p> <div class=“variablelist”><table
border=“0”><col
align=“left”/><tbody><tr><td><span
class=“term”>value
:</span></td><td>the
value to check</td></tr><tr><td><span
class=“term”>space
:</span></td><td>allow
spaces in front and end of the
string</td></tr><tr><td><span
class=“term”>Returns
:</span></td><td>0
if this validates, a positive error code number otherwise and -1 in case of
internal or API
error.</td></tr></tbody></table></div></div>
<hr/> </div> </div> </body>
</html>