blob: a627d92168fbe1d28e3cc014c52818c93f60bf17 [file] [log] [blame]
Daniel Veillard260a68f1998-08-13 03:39:55 +00001/*
2 * tree.h : describes the structures found in an tree resulting
3 * from an XML parsing.
4 *
5 * See Copyright for the status of this software.
6 *
Daniel Veillard39a1f9a1999-01-17 19:11:59 +00007 * Daniel.Veillard@w3.org
Daniel Veillard260a68f1998-08-13 03:39:55 +00008 */
9
10#ifndef __XML_TREE_H__
11#define __XML_TREE_H__
12
13
14#ifdef __cplusplus
15extern "C" {
16#endif
17
Daniel Veillard39a1f9a1999-01-17 19:11:59 +000018#include <stdio.h>
19
Daniel Veillard260a68f1998-08-13 03:39:55 +000020/*
Daniel Veillardccb09631998-10-27 06:21:04 +000021 * The different element types carried by an XML tree
22 *
23 * NOTE: This is synchronized with DOM Level1 values
24 * See http://www.w3.org/TR/REC-DOM-Level-1/
25 */
26typedef enum {
27 XML_ELEMENT_NODE= 1,
28 XML_ATTRIBUTE_NODE= 2,
29 XML_TEXT_NODE= 3,
30 XML_CDATA_SECTION_NODE= 4,
31 XML_ENTITY_REF_NODE= 5,
32 XML_ENTITY_NODE= 6,
33 XML_PI_NODE= 7,
34 XML_COMMENT_NODE= 8,
35 XML_DOCUMENT_NODE= 9,
36 XML_DOCUMENT_TYPE_NODE= 10,
37 XML_DOCUMENT_FRAG_NODE= 11,
38 XML_NOTATION_NODE= 12
39} xmlElementType;
40
41/*
Daniel Veillard0ba4d531998-11-01 19:34:31 +000042 * Size of an internal character representation.
43 *
44 * Currently we use 8bit chars internal representation for memory efficiency,
45 * but the parser is not tied to that, just define UNICODE to switch to
46 * a 16 bits internal representation. Note that with 8 bits wide
47 * CHARs one can still use UTF-8 to handle correctly non ISO-Latin
48 * input.
Daniel Veillard260a68f1998-08-13 03:39:55 +000049 */
50#ifdef UNICODE
51typedef unsigned short CHAR;
52#else
53typedef unsigned char CHAR;
54#endif
55
56/*
57 * a DTD Notation definition
Daniel Veillard260a68f1998-08-13 03:39:55 +000058 */
59
Daniel Veillard1e346af1999-02-22 10:33:01 +000060typedef struct xmlNotation {
61 const CHAR *name; /* Notation name */
62 const CHAR *PublicID; /* Public identifier, if any */
63 const CHAR *SystemID; /* System identifier, if any */
64} xmlNotation;
65typedef xmlNotation *xmlNotationPtr;
66
Daniel Veillard260a68f1998-08-13 03:39:55 +000067/*
68 * a DTD Attribute definition
Daniel Veillard260a68f1998-08-13 03:39:55 +000069 */
70
Daniel Veillard1e346af1999-02-22 10:33:01 +000071typedef enum {
72 XML_ATTRIBUTE_CDATA = 1,
73 XML_ATTRIBUTE_ID,
74 XML_ATTRIBUTE_IDREF ,
75 XML_ATTRIBUTE_IDREFS,
76 XML_ATTRIBUTE_ENTITY,
77 XML_ATTRIBUTE_ENTITIES,
78 XML_ATTRIBUTE_NMTOKEN,
79 XML_ATTRIBUTE_NMTOKENS,
80 XML_ATTRIBUTE_ENUMERATION,
81 XML_ATTRIBUTE_NOTATION
82} xmlAttributeType;
Daniel Veillard39a1f9a1999-01-17 19:11:59 +000083
Daniel Veillard1e346af1999-02-22 10:33:01 +000084typedef enum {
85 XML_ATTRIBUTE_NONE = 1,
86 XML_ATTRIBUTE_REQUIRED,
87 XML_ATTRIBUTE_IMPLIED,
88 XML_ATTRIBUTE_FIXED
89} xmlAttributeDefault;
90
91typedef struct xmlEnumeration {
92 struct xmlEnumeration *next; /* next one */
93 const CHAR *name; /* Enumeration name */
94} xmlEnumeration;
95typedef xmlEnumeration *xmlEnumerationPtr;
96
97typedef struct xmlAttribute {
98 const CHAR *elem; /* Element holding the attribute */
99 const CHAR *name; /* Attribute name */
Daniel Veillardb05deb71999-08-10 19:04:08 +0000100 struct xmlAttribute *next; /* list of attributes of an element */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000101 xmlAttributeType type; /* The type */
102 xmlAttributeDefault def; /* the default */
103 const CHAR *defaultValue;/* or the default value */
104 xmlEnumerationPtr tree; /* or the enumeration tree if any */
105} xmlAttribute;
106typedef xmlAttribute *xmlAttributePtr;
Daniel Veillard39a1f9a1999-01-17 19:11:59 +0000107
Daniel Veillard260a68f1998-08-13 03:39:55 +0000108/*
109 * a DTD Element definition.
110 */
Daniel Veillard1899e851999-02-01 12:18:54 +0000111typedef enum {
Daniel Veillard1e346af1999-02-22 10:33:01 +0000112 XML_ELEMENT_CONTENT_PCDATA = 1,
Daniel Veillard1899e851999-02-01 12:18:54 +0000113 XML_ELEMENT_CONTENT_ELEMENT,
114 XML_ELEMENT_CONTENT_SEQ,
115 XML_ELEMENT_CONTENT_OR
116} xmlElementContentType;
Daniel Veillard39a1f9a1999-01-17 19:11:59 +0000117
Daniel Veillard1899e851999-02-01 12:18:54 +0000118typedef enum {
Daniel Veillard1e346af1999-02-22 10:33:01 +0000119 XML_ELEMENT_CONTENT_ONCE = 1,
Daniel Veillard1899e851999-02-01 12:18:54 +0000120 XML_ELEMENT_CONTENT_OPT,
121 XML_ELEMENT_CONTENT_MULT,
122 XML_ELEMENT_CONTENT_PLUS
123} xmlElementContentOccur;
Daniel Veillard39a1f9a1999-01-17 19:11:59 +0000124
125typedef struct xmlElementContent {
Daniel Veillard1899e851999-02-01 12:18:54 +0000126 xmlElementContentType type; /* PCDATA, ELEMENT, SEQ or OR */
127 xmlElementContentOccur ocur; /* ONCE, OPT, MULT or PLUS */
128 const CHAR *name; /* Element name */
Daniel Veillard39a1f9a1999-01-17 19:11:59 +0000129 struct xmlElementContent *c1; /* first child */
130 struct xmlElementContent *c2; /* second child */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000131} xmlElementContent;
132typedef xmlElementContent *xmlElementContentPtr;
Daniel Veillard39a1f9a1999-01-17 19:11:59 +0000133
Daniel Veillard1899e851999-02-01 12:18:54 +0000134typedef enum {
Daniel Veillard1e346af1999-02-22 10:33:01 +0000135 XML_ELEMENT_TYPE_EMPTY = 1,
Daniel Veillard1899e851999-02-01 12:18:54 +0000136 XML_ELEMENT_TYPE_ANY,
137 XML_ELEMENT_TYPE_MIXED,
138 XML_ELEMENT_TYPE_ELEMENT
139} xmlElementTypeVal;
Daniel Veillard260a68f1998-08-13 03:39:55 +0000140
141typedef struct xmlElement {
Daniel Veillardb05deb71999-08-10 19:04:08 +0000142 const CHAR *name; /* Element name */
143 xmlElementTypeVal type; /* The type */
Daniel Veillard39a1f9a1999-01-17 19:11:59 +0000144 xmlElementContentPtr content; /* the allowed element content */
Daniel Veillardb05deb71999-08-10 19:04:08 +0000145 xmlAttributePtr attributes; /* List of the declared attributes */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000146} xmlElement;
147typedef xmlElement *xmlElementPtr;
Daniel Veillard260a68f1998-08-13 03:39:55 +0000148
149/*
150 * An XML namespace.
151 * Note that prefix == NULL is valid, it defines the default namespace
152 * within the subtree (until overriden).
153 */
154
Daniel Veillard1899e851999-02-01 12:18:54 +0000155typedef enum {
Daniel Veillard1e346af1999-02-22 10:33:01 +0000156 XML_GLOBAL_NAMESPACE = 1, /* old style global namespace */
Daniel Veillard1899e851999-02-01 12:18:54 +0000157 XML_LOCAL_NAMESPACE /* new style local scoping */
158} xmlNsType;
Daniel Veillard260a68f1998-08-13 03:39:55 +0000159
160typedef struct xmlNs {
161 struct xmlNs *next; /* next Ns link for this node */
Daniel Veillard1899e851999-02-01 12:18:54 +0000162 xmlNsType type; /* global or local */
Daniel Veillard260a68f1998-08-13 03:39:55 +0000163 const CHAR *href; /* URL for the namespace */
164 const CHAR *prefix; /* prefix for the namespace */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000165} xmlNs;
166typedef xmlNs *xmlNsPtr;
Daniel Veillard260a68f1998-08-13 03:39:55 +0000167
168/*
169 * An XML DtD, as defined by <!DOCTYPE.
170 */
171typedef struct xmlDtd {
172 const CHAR *name; /* Name of the DTD */
173 const CHAR *ExternalID; /* External identifier for PUBLIC DTD */
174 const CHAR *SystemID; /* URI for a SYSTEM or PUBLIC DTD */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000175 void *notations; /* Hash table for notations if any */
Daniel Veillard260a68f1998-08-13 03:39:55 +0000176 void *elements; /* Hash table for elements if any */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000177 void *attributes; /* Hash table for attributes if any */
Daniel Veillard260a68f1998-08-13 03:39:55 +0000178 void *entities; /* Hash table for entities if any */
179 /* struct xmlDtd *next; * next link for this document */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000180} xmlDtd;
181typedef xmlDtd *xmlDtdPtr;
Daniel Veillard260a68f1998-08-13 03:39:55 +0000182
183/*
184 * A attribute of an XML node.
185 */
186typedef struct xmlAttr {
Daniel Veillard27fb0751998-10-17 06:47:46 +0000187#ifndef XML_WITHOUT_CORBA
188 void *_private; /* for Corba, must be first ! */
189 void *vepv; /* for Corba, must be next ! */
190#endif
Daniel Veillardccb09631998-10-27 06:21:04 +0000191 xmlElementType type; /* XML_ATTRIBUTE_NODE, must be third ! */
Daniel Veillard260a68f1998-08-13 03:39:55 +0000192 struct xmlNode *node; /* attr->node link */
Daniel Veillardb05deb71999-08-10 19:04:08 +0000193 struct xmlAttr *next; /* attribute list link */
Daniel Veillard260a68f1998-08-13 03:39:55 +0000194 const CHAR *name; /* the name of the property */
Daniel Veillardccb09631998-10-27 06:21:04 +0000195 struct xmlNode *val; /* the value of the property */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000196} xmlAttr;
197typedef xmlAttr *xmlAttrPtr;
Daniel Veillard260a68f1998-08-13 03:39:55 +0000198
199/*
200 * A node in an XML tree.
201 */
Daniel Veillard260a68f1998-08-13 03:39:55 +0000202typedef struct xmlNode {
Daniel Veillard27fb0751998-10-17 06:47:46 +0000203#ifndef XML_WITHOUT_CORBA
204 void *_private; /* for Corba, must be first ! */
205 void *vepv; /* for Corba, must be next ! */
206#endif
Daniel Veillardccb09631998-10-27 06:21:04 +0000207 xmlElementType type; /* type number in the DTD, must be third ! */
Daniel Veillard0bef1311998-10-14 02:36:47 +0000208 struct xmlDoc *doc; /* the containing document */
Daniel Veillard260a68f1998-08-13 03:39:55 +0000209 struct xmlNode *parent; /* child->parent link */
210 struct xmlNode *next; /* next sibling link */
Daniel Veillard0bef1311998-10-14 02:36:47 +0000211 struct xmlNode *prev; /* previous sibling link */
Daniel Veillard260a68f1998-08-13 03:39:55 +0000212 struct xmlNode *childs; /* parent->childs link */
Daniel Veillard39a1f9a1999-01-17 19:11:59 +0000213 struct xmlNode *last; /* last child link */
Daniel Veillard260a68f1998-08-13 03:39:55 +0000214 struct xmlAttr *properties; /* properties list */
Daniel Veillard260a68f1998-08-13 03:39:55 +0000215 const CHAR *name; /* the name of the node, or the entity */
216 xmlNs *ns; /* pointer to the associated namespace */
217 xmlNs *nsDef; /* namespace definitions on this node */
218 CHAR *content; /* the content */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000219} _xmlNode;
220typedef _xmlNode xmlNode;
221typedef _xmlNode *xmlNodePtr;
Daniel Veillard260a68f1998-08-13 03:39:55 +0000222
223/*
224 * An XML document.
225 */
226typedef struct xmlDoc {
Daniel Veillard27fb0751998-10-17 06:47:46 +0000227#ifndef XML_WITHOUT_CORBA
228 void *_private; /* for Corba, must be first ! */
229 void *vepv; /* for Corba, must be next ! */
230#endif
Daniel Veillardccb09631998-10-27 06:21:04 +0000231 xmlElementType type; /* XML_DOCUMENT_NODE, must be second ! */
Daniel Veillard260a68f1998-08-13 03:39:55 +0000232 char *name; /* name/filename/URI of the document */
233 const CHAR *version; /* the XML version string */
234 const CHAR *encoding; /* encoding, if any */
Daniel Veillard15a8df41998-09-24 19:15:06 +0000235 int compression;/* level of zlib compression */
Daniel Veillard260a68f1998-08-13 03:39:55 +0000236 int standalone; /* standalone document (no external refs) */
Daniel Veillard39a1f9a1999-01-17 19:11:59 +0000237 struct xmlDtd *intSubset; /* the document internal subset */
238 struct xmlDtd *extSubset; /* the document external subset */
Daniel Veillard260a68f1998-08-13 03:39:55 +0000239 struct xmlNs *oldNs; /* Global namespace, the old way */
Daniel Veillard260a68f1998-08-13 03:39:55 +0000240 struct xmlNode *root; /* the document tree */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000241} _xmlDoc;
242typedef _xmlDoc xmlDoc;
243typedef xmlDoc *xmlDocPtr;
Daniel Veillard260a68f1998-08-13 03:39:55 +0000244
245/*
Daniel Veillard5099ae81999-04-21 20:12:07 +0000246 * A buffer structure
247 */
248
249typedef struct xmlBuffer {
250 CHAR *content; /* The buffer content UTF8 */
251 unsigned int use; /* The buffer size used */
252 unsigned int size; /* The buffer size */
253} _xmlBuffer;
254typedef _xmlBuffer xmlBuffer;
255typedef xmlBuffer *xmlBufferPtr;
256
257/*
Daniel Veillard260a68f1998-08-13 03:39:55 +0000258 * Variables.
259 */
260extern xmlNsPtr baseDTD;
261extern int oldXMLWDcompatibility;/* maintain compatibility with old WD */
262extern int xmlIndentTreeOutput; /* try to indent the tree dumps */
263
264/*
Daniel Veillard5099ae81999-04-21 20:12:07 +0000265 * Handling Buffers.
266 */
267
268xmlBufferPtr xmlBufferCreate(void);
269void xmlBufferFree(xmlBufferPtr buf);
270int xmlBufferDump(FILE *file, xmlBufferPtr buf);
271void xmlBufferAdd(xmlBufferPtr buf, const CHAR *str, int len);
272void xmlBufferCat(xmlBufferPtr buf, const CHAR *str);
273void xmlBufferCCat(xmlBufferPtr buf, const char *str);
Daniel Veillarde2d034d1999-07-27 19:52:06 +0000274int xmlBufferShrink(xmlBufferPtr buf, int len);
275void xmlBufferEmpty(xmlBufferPtr buf);
Daniel Veillard5099ae81999-04-21 20:12:07 +0000276
277/*
Daniel Veillard16253641998-10-28 22:58:05 +0000278 * Creating/freeing new structures
Daniel Veillard260a68f1998-08-13 03:39:55 +0000279 */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000280xmlDtdPtr xmlCreateIntSubset(xmlDocPtr doc, const CHAR *name,
Daniel Veillard39a1f9a1999-01-17 19:11:59 +0000281 const CHAR *ExternalID, const CHAR *SystemID);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000282xmlDtdPtr xmlNewDtd(xmlDocPtr doc, const CHAR *name,
Daniel Veillard260a68f1998-08-13 03:39:55 +0000283 const CHAR *ExternalID, const CHAR *SystemID);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000284void xmlFreeDtd(xmlDtdPtr cur);
285xmlNsPtr xmlNewGlobalNs(xmlDocPtr doc, const CHAR *href, const CHAR *prefix);
286xmlNsPtr xmlNewNs(xmlNodePtr node, const CHAR *href, const CHAR *prefix);
287void xmlFreeNs(xmlNsPtr cur);
288xmlDocPtr xmlNewDoc(const CHAR *version);
289void xmlFreeDoc(xmlDocPtr cur);
290xmlAttrPtr xmlNewDocProp(xmlDocPtr doc, const CHAR *name,
Daniel Veillardccb09631998-10-27 06:21:04 +0000291 const CHAR *value);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000292xmlAttrPtr xmlNewProp(xmlNodePtr node, const CHAR *name,
Daniel Veillard260a68f1998-08-13 03:39:55 +0000293 const CHAR *value);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000294void xmlFreePropList(xmlAttrPtr cur);
295void xmlFreeProp(xmlAttrPtr cur);
296xmlAttrPtr xmlCopyProp(xmlAttrPtr cur);
297xmlAttrPtr xmlCopyPropList(xmlAttrPtr cur);
298xmlDtdPtr xmlCopyDtd(xmlDtdPtr dtd);
299xmlDocPtr xmlCopyDoc(xmlDocPtr doc, int recursive);
Daniel Veillard16253641998-10-28 22:58:05 +0000300
301/*
302 * Creating new nodes
303 */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000304xmlNodePtr xmlNewDocNode(xmlDocPtr doc, xmlNsPtr ns,
Daniel Veillard15b75af1999-07-26 16:42:37 +0000305 const CHAR *name, const CHAR *content);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000306xmlNodePtr xmlNewNode(xmlNsPtr ns, const CHAR *name);
307xmlNodePtr xmlNewChild(xmlNodePtr parent, xmlNsPtr ns,
Daniel Veillard15b75af1999-07-26 16:42:37 +0000308 const CHAR *name, const CHAR *content);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000309xmlNodePtr xmlNewDocText(xmlDocPtr doc, const CHAR *content);
310xmlNodePtr xmlNewText(const CHAR *content);
311xmlNodePtr xmlNewDocTextLen(xmlDocPtr doc, const CHAR *content, int len);
312xmlNodePtr xmlNewTextLen(const CHAR *content, int len);
Daniel Veillard517752b1999-04-05 12:20:10 +0000313xmlNodePtr xmlNewDocComment(xmlDocPtr doc, const CHAR *content);
314xmlNodePtr xmlNewComment(const CHAR *content);
Daniel Veillardb05deb71999-08-10 19:04:08 +0000315xmlNodePtr xmlNewCDataBlock(xmlDocPtr doc, const CHAR *content, int len);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000316xmlNodePtr xmlNewReference(xmlDocPtr doc, const CHAR *name);
317xmlNodePtr xmlCopyNode(xmlNodePtr node, int recursive);
318xmlNodePtr xmlCopyNodeList(xmlNodePtr node);
Daniel Veillard16253641998-10-28 22:58:05 +0000319
320/*
321 * Navigating
322 */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000323xmlNodePtr xmlGetLastChild(xmlNodePtr parent);
324int xmlNodeIsText(xmlNodePtr node);
Daniel Veillard16253641998-10-28 22:58:05 +0000325
326/*
327 * Changing the structure
328 */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000329xmlNodePtr xmlAddChild(xmlNodePtr parent, xmlNodePtr cur);
330void xmlUnlinkNode(xmlNodePtr cur);
Daniel Veillard16253641998-10-28 22:58:05 +0000331
Daniel Veillard1e346af1999-02-22 10:33:01 +0000332xmlNodePtr xmlTextMerge(xmlNodePtr first, xmlNodePtr second);
333void xmlTextConcat(xmlNodePtr node, const CHAR *content, int len);
Daniel Veillard16253641998-10-28 22:58:05 +0000334
Daniel Veillard1e346af1999-02-22 10:33:01 +0000335void xmlFreeNodeList(xmlNodePtr cur);
336void xmlFreeNode(xmlNodePtr cur);
Daniel Veillard16253641998-10-28 22:58:05 +0000337
338/*
339 * Namespaces
340 */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000341xmlNsPtr xmlSearchNs(xmlDocPtr doc, xmlNodePtr node,
Daniel Veillard260a68f1998-08-13 03:39:55 +0000342 const CHAR *nameSpace);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000343xmlNsPtr xmlSearchNsByHref(xmlDocPtr doc, xmlNodePtr node,
Daniel Veillard260a68f1998-08-13 03:39:55 +0000344 const CHAR *href);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000345void xmlSetNs(xmlNodePtr node, xmlNsPtr ns);
346xmlNsPtr xmlCopyNamespace(xmlNsPtr cur);
347xmlNsPtr xmlCopyNamespaceList(xmlNsPtr cur);
Daniel Veillard260a68f1998-08-13 03:39:55 +0000348
Daniel Veillard16253641998-10-28 22:58:05 +0000349/*
350 * Changing the content.
351 */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000352xmlAttrPtr xmlSetProp(xmlNodePtr node, const CHAR *name,
Daniel Veillard16253641998-10-28 22:58:05 +0000353 const CHAR *value);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000354CHAR *xmlGetProp(xmlNodePtr node, const CHAR *name);
355xmlNodePtr xmlStringGetNodeList(xmlDocPtr doc, const CHAR *value);
356xmlNodePtr xmlStringLenGetNodeList(xmlDocPtr doc, const CHAR *value,
Daniel Veillard16253641998-10-28 22:58:05 +0000357 int len);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000358CHAR *xmlNodeListGetString(xmlDocPtr doc, xmlNodePtr list, int inLine);
359void xmlNodeSetContent(xmlNodePtr cur, const CHAR *content);
360void xmlNodeSetContentLen(xmlNodePtr cur, const CHAR *content, int len);
361void xmlNodeAddContent(xmlNodePtr cur, const CHAR *content);
362void xmlNodeAddContentLen(xmlNodePtr cur, const CHAR *content, int len);
363CHAR *xmlNodeGetContent(xmlNodePtr cur);
Daniel Veillard16253641998-10-28 22:58:05 +0000364
365/*
366 * Internal, don't use
367 */
Daniel Veillard5099ae81999-04-21 20:12:07 +0000368void xmlBufferWriteCHAR(xmlBufferPtr buf, const CHAR *string);
369void xmlBufferWriteChar(xmlBufferPtr buf, const char *string);
Daniel Veillard011b63c1999-06-02 17:44:04 +0000370void xmlBufferWriteQuotedString(xmlBufferPtr buf, const CHAR *string);
Daniel Veillard260a68f1998-08-13 03:39:55 +0000371
Daniel Veillard16253641998-10-28 22:58:05 +0000372/*
373 * Saving
374 */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000375void xmlDocDumpMemory(xmlDocPtr cur, CHAR**mem, int *size);
376void xmlDocDump(FILE *f, xmlDocPtr cur);
Daniel Veillard151b1b01998-09-23 00:49:46 +0000377int xmlSaveFile(const char *filename, xmlDocPtr cur);
378
Daniel Veillard16253641998-10-28 22:58:05 +0000379/*
380 * Compression
381 */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000382int xmlGetDocCompressMode (xmlDocPtr doc);
383void xmlSetDocCompressMode (xmlDocPtr doc, int mode);
384int xmlGetCompressMode(void);
385void xmlSetCompressMode(int mode);
Daniel Veillard260a68f1998-08-13 03:39:55 +0000386
387#ifdef __cplusplus
388}
389#endif
390
391#endif /* __XML_TREE_H__ */
392