blob: 5907e24f912f40c8135c8fbf3e884236ea2d80d0 [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 */
100 xmlAttributeType type; /* The type */
101 xmlAttributeDefault def; /* the default */
102 const CHAR *defaultValue;/* or the default value */
103 xmlEnumerationPtr tree; /* or the enumeration tree if any */
104} xmlAttribute;
105typedef xmlAttribute *xmlAttributePtr;
Daniel Veillard39a1f9a1999-01-17 19:11:59 +0000106
Daniel Veillard260a68f1998-08-13 03:39:55 +0000107/*
108 * a DTD Element definition.
109 */
Daniel Veillard1899e851999-02-01 12:18:54 +0000110typedef enum {
Daniel Veillard1e346af1999-02-22 10:33:01 +0000111 XML_ELEMENT_CONTENT_PCDATA = 1,
Daniel Veillard1899e851999-02-01 12:18:54 +0000112 XML_ELEMENT_CONTENT_ELEMENT,
113 XML_ELEMENT_CONTENT_SEQ,
114 XML_ELEMENT_CONTENT_OR
115} xmlElementContentType;
Daniel Veillard39a1f9a1999-01-17 19:11:59 +0000116
Daniel Veillard1899e851999-02-01 12:18:54 +0000117typedef enum {
Daniel Veillard1e346af1999-02-22 10:33:01 +0000118 XML_ELEMENT_CONTENT_ONCE = 1,
Daniel Veillard1899e851999-02-01 12:18:54 +0000119 XML_ELEMENT_CONTENT_OPT,
120 XML_ELEMENT_CONTENT_MULT,
121 XML_ELEMENT_CONTENT_PLUS
122} xmlElementContentOccur;
Daniel Veillard39a1f9a1999-01-17 19:11:59 +0000123
124typedef struct xmlElementContent {
Daniel Veillard1899e851999-02-01 12:18:54 +0000125 xmlElementContentType type; /* PCDATA, ELEMENT, SEQ or OR */
126 xmlElementContentOccur ocur; /* ONCE, OPT, MULT or PLUS */
127 const CHAR *name; /* Element name */
Daniel Veillard39a1f9a1999-01-17 19:11:59 +0000128 struct xmlElementContent *c1; /* first child */
129 struct xmlElementContent *c2; /* second child */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000130} xmlElementContent;
131typedef xmlElementContent *xmlElementContentPtr;
Daniel Veillard39a1f9a1999-01-17 19:11:59 +0000132
Daniel Veillard1899e851999-02-01 12:18:54 +0000133typedef enum {
Daniel Veillard1e346af1999-02-22 10:33:01 +0000134 XML_ELEMENT_TYPE_EMPTY = 1,
Daniel Veillard1899e851999-02-01 12:18:54 +0000135 XML_ELEMENT_TYPE_ANY,
136 XML_ELEMENT_TYPE_MIXED,
137 XML_ELEMENT_TYPE_ELEMENT
138} xmlElementTypeVal;
Daniel Veillard260a68f1998-08-13 03:39:55 +0000139
140typedef struct xmlElement {
Daniel Veillard1899e851999-02-01 12:18:54 +0000141 const CHAR *name; /* Element name */
142 xmlElementTypeVal type; /* The type */
Daniel Veillard39a1f9a1999-01-17 19:11:59 +0000143 xmlElementContentPtr content; /* the allowed element content */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000144} xmlElement;
145typedef xmlElement *xmlElementPtr;
Daniel Veillard260a68f1998-08-13 03:39:55 +0000146
147/*
148 * An XML namespace.
149 * Note that prefix == NULL is valid, it defines the default namespace
150 * within the subtree (until overriden).
151 */
152
Daniel Veillard1899e851999-02-01 12:18:54 +0000153typedef enum {
Daniel Veillard1e346af1999-02-22 10:33:01 +0000154 XML_GLOBAL_NAMESPACE = 1, /* old style global namespace */
Daniel Veillard1899e851999-02-01 12:18:54 +0000155 XML_LOCAL_NAMESPACE /* new style local scoping */
156} xmlNsType;
Daniel Veillard260a68f1998-08-13 03:39:55 +0000157
158typedef struct xmlNs {
159 struct xmlNs *next; /* next Ns link for this node */
Daniel Veillard1899e851999-02-01 12:18:54 +0000160 xmlNsType type; /* global or local */
Daniel Veillard260a68f1998-08-13 03:39:55 +0000161 const CHAR *href; /* URL for the namespace */
162 const CHAR *prefix; /* prefix for the namespace */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000163} xmlNs;
164typedef xmlNs *xmlNsPtr;
Daniel Veillard260a68f1998-08-13 03:39:55 +0000165
166/*
167 * An XML DtD, as defined by <!DOCTYPE.
168 */
169typedef struct xmlDtd {
170 const CHAR *name; /* Name of the DTD */
171 const CHAR *ExternalID; /* External identifier for PUBLIC DTD */
172 const CHAR *SystemID; /* URI for a SYSTEM or PUBLIC DTD */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000173 void *notations; /* Hash table for notations if any */
Daniel Veillard260a68f1998-08-13 03:39:55 +0000174 void *elements; /* Hash table for elements if any */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000175 void *attributes; /* Hash table for attributes if any */
Daniel Veillard260a68f1998-08-13 03:39:55 +0000176 void *entities; /* Hash table for entities if any */
177 /* struct xmlDtd *next; * next link for this document */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000178} xmlDtd;
179typedef xmlDtd *xmlDtdPtr;
Daniel Veillard260a68f1998-08-13 03:39:55 +0000180
181/*
182 * A attribute of an XML node.
183 */
184typedef struct xmlAttr {
Daniel Veillard27fb0751998-10-17 06:47:46 +0000185#ifndef XML_WITHOUT_CORBA
186 void *_private; /* for Corba, must be first ! */
187 void *vepv; /* for Corba, must be next ! */
188#endif
Daniel Veillardccb09631998-10-27 06:21:04 +0000189 xmlElementType type; /* XML_ATTRIBUTE_NODE, must be third ! */
Daniel Veillard260a68f1998-08-13 03:39:55 +0000190 struct xmlNode *node; /* attr->node link */
191 struct xmlAttr *next; /* parent->childs link */
192 const CHAR *name; /* the name of the property */
Daniel Veillardccb09631998-10-27 06:21:04 +0000193 struct xmlNode *val; /* the value of the property */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000194} xmlAttr;
195typedef xmlAttr *xmlAttrPtr;
Daniel Veillard260a68f1998-08-13 03:39:55 +0000196
197/*
198 * A node in an XML tree.
199 */
Daniel Veillard260a68f1998-08-13 03:39:55 +0000200typedef struct xmlNode {
Daniel Veillard27fb0751998-10-17 06:47:46 +0000201#ifndef XML_WITHOUT_CORBA
202 void *_private; /* for Corba, must be first ! */
203 void *vepv; /* for Corba, must be next ! */
204#endif
Daniel Veillardccb09631998-10-27 06:21:04 +0000205 xmlElementType type; /* type number in the DTD, must be third ! */
Daniel Veillard0bef1311998-10-14 02:36:47 +0000206 struct xmlDoc *doc; /* the containing document */
Daniel Veillard260a68f1998-08-13 03:39:55 +0000207 struct xmlNode *parent; /* child->parent link */
208 struct xmlNode *next; /* next sibling link */
Daniel Veillard0bef1311998-10-14 02:36:47 +0000209 struct xmlNode *prev; /* previous sibling link */
Daniel Veillard260a68f1998-08-13 03:39:55 +0000210 struct xmlNode *childs; /* parent->childs link */
Daniel Veillard39a1f9a1999-01-17 19:11:59 +0000211 struct xmlNode *last; /* last child link */
Daniel Veillard260a68f1998-08-13 03:39:55 +0000212 struct xmlAttr *properties; /* properties list */
Daniel Veillard260a68f1998-08-13 03:39:55 +0000213 const CHAR *name; /* the name of the node, or the entity */
214 xmlNs *ns; /* pointer to the associated namespace */
215 xmlNs *nsDef; /* namespace definitions on this node */
216 CHAR *content; /* the content */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000217} _xmlNode;
218typedef _xmlNode xmlNode;
219typedef _xmlNode *xmlNodePtr;
Daniel Veillard260a68f1998-08-13 03:39:55 +0000220
221/*
222 * An XML document.
223 */
224typedef struct xmlDoc {
Daniel Veillard27fb0751998-10-17 06:47:46 +0000225#ifndef XML_WITHOUT_CORBA
226 void *_private; /* for Corba, must be first ! */
227 void *vepv; /* for Corba, must be next ! */
228#endif
Daniel Veillardccb09631998-10-27 06:21:04 +0000229 xmlElementType type; /* XML_DOCUMENT_NODE, must be second ! */
Daniel Veillard260a68f1998-08-13 03:39:55 +0000230 char *name; /* name/filename/URI of the document */
231 const CHAR *version; /* the XML version string */
232 const CHAR *encoding; /* encoding, if any */
Daniel Veillard15a8df41998-09-24 19:15:06 +0000233 int compression;/* level of zlib compression */
Daniel Veillard260a68f1998-08-13 03:39:55 +0000234 int standalone; /* standalone document (no external refs) */
Daniel Veillard39a1f9a1999-01-17 19:11:59 +0000235 struct xmlDtd *intSubset; /* the document internal subset */
236 struct xmlDtd *extSubset; /* the document external subset */
Daniel Veillard260a68f1998-08-13 03:39:55 +0000237 struct xmlNs *oldNs; /* Global namespace, the old way */
Daniel Veillard260a68f1998-08-13 03:39:55 +0000238 struct xmlNode *root; /* the document tree */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000239} _xmlDoc;
240typedef _xmlDoc xmlDoc;
241typedef xmlDoc *xmlDocPtr;
Daniel Veillard260a68f1998-08-13 03:39:55 +0000242
243/*
Daniel Veillard5099ae81999-04-21 20:12:07 +0000244 * A buffer structure
245 */
246
247typedef struct xmlBuffer {
248 CHAR *content; /* The buffer content UTF8 */
249 unsigned int use; /* The buffer size used */
250 unsigned int size; /* The buffer size */
251} _xmlBuffer;
252typedef _xmlBuffer xmlBuffer;
253typedef xmlBuffer *xmlBufferPtr;
254
255/*
Daniel Veillard260a68f1998-08-13 03:39:55 +0000256 * Variables.
257 */
258extern xmlNsPtr baseDTD;
259extern int oldXMLWDcompatibility;/* maintain compatibility with old WD */
260extern int xmlIndentTreeOutput; /* try to indent the tree dumps */
261
262/*
Daniel Veillard5099ae81999-04-21 20:12:07 +0000263 * Handling Buffers.
264 */
265
266xmlBufferPtr xmlBufferCreate(void);
267void xmlBufferFree(xmlBufferPtr buf);
268int xmlBufferDump(FILE *file, xmlBufferPtr buf);
269void xmlBufferAdd(xmlBufferPtr buf, const CHAR *str, int len);
270void xmlBufferCat(xmlBufferPtr buf, const CHAR *str);
271void xmlBufferCCat(xmlBufferPtr buf, const char *str);
272
273/*
Daniel Veillard16253641998-10-28 22:58:05 +0000274 * Creating/freeing new structures
Daniel Veillard260a68f1998-08-13 03:39:55 +0000275 */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000276xmlDtdPtr xmlCreateIntSubset(xmlDocPtr doc, const CHAR *name,
Daniel Veillard39a1f9a1999-01-17 19:11:59 +0000277 const CHAR *ExternalID, const CHAR *SystemID);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000278xmlDtdPtr xmlNewDtd(xmlDocPtr doc, const CHAR *name,
Daniel Veillard260a68f1998-08-13 03:39:55 +0000279 const CHAR *ExternalID, const CHAR *SystemID);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000280void xmlFreeDtd(xmlDtdPtr cur);
281xmlNsPtr xmlNewGlobalNs(xmlDocPtr doc, const CHAR *href, const CHAR *prefix);
282xmlNsPtr xmlNewNs(xmlNodePtr node, const CHAR *href, const CHAR *prefix);
283void xmlFreeNs(xmlNsPtr cur);
284xmlDocPtr xmlNewDoc(const CHAR *version);
285void xmlFreeDoc(xmlDocPtr cur);
286xmlAttrPtr xmlNewDocProp(xmlDocPtr doc, const CHAR *name,
Daniel Veillardccb09631998-10-27 06:21:04 +0000287 const CHAR *value);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000288xmlAttrPtr xmlNewProp(xmlNodePtr node, const CHAR *name,
Daniel Veillard260a68f1998-08-13 03:39:55 +0000289 const CHAR *value);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000290void xmlFreePropList(xmlAttrPtr cur);
291void xmlFreeProp(xmlAttrPtr cur);
292xmlAttrPtr xmlCopyProp(xmlAttrPtr cur);
293xmlAttrPtr xmlCopyPropList(xmlAttrPtr cur);
294xmlDtdPtr xmlCopyDtd(xmlDtdPtr dtd);
295xmlDocPtr xmlCopyDoc(xmlDocPtr doc, int recursive);
Daniel Veillard16253641998-10-28 22:58:05 +0000296
297/*
298 * Creating new nodes
299 */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000300xmlNodePtr xmlNewDocNode(xmlDocPtr doc, xmlNsPtr ns,
Daniel Veillard0bef1311998-10-14 02:36:47 +0000301 const CHAR *name, CHAR *content);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000302xmlNodePtr xmlNewNode(xmlNsPtr ns, const CHAR *name);
303xmlNodePtr xmlNewChild(xmlNodePtr parent, xmlNsPtr ns,
Daniel Veillard16253641998-10-28 22:58:05 +0000304 const CHAR *name, CHAR *content);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000305xmlNodePtr xmlNewDocText(xmlDocPtr doc, const CHAR *content);
306xmlNodePtr xmlNewText(const CHAR *content);
307xmlNodePtr xmlNewDocTextLen(xmlDocPtr doc, const CHAR *content, int len);
308xmlNodePtr xmlNewTextLen(const CHAR *content, int len);
Daniel Veillard517752b1999-04-05 12:20:10 +0000309xmlNodePtr xmlNewDocComment(xmlDocPtr doc, const CHAR *content);
310xmlNodePtr xmlNewComment(const CHAR *content);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000311xmlNodePtr xmlNewReference(xmlDocPtr doc, const CHAR *name);
312xmlNodePtr xmlCopyNode(xmlNodePtr node, int recursive);
313xmlNodePtr xmlCopyNodeList(xmlNodePtr node);
Daniel Veillard16253641998-10-28 22:58:05 +0000314
315/*
316 * Navigating
317 */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000318xmlNodePtr xmlGetLastChild(xmlNodePtr parent);
319int xmlNodeIsText(xmlNodePtr node);
Daniel Veillard16253641998-10-28 22:58:05 +0000320
321/*
322 * Changing the structure
323 */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000324xmlNodePtr xmlAddChild(xmlNodePtr parent, xmlNodePtr cur);
325void xmlUnlinkNode(xmlNodePtr cur);
Daniel Veillard16253641998-10-28 22:58:05 +0000326
Daniel Veillard1e346af1999-02-22 10:33:01 +0000327xmlNodePtr xmlTextMerge(xmlNodePtr first, xmlNodePtr second);
328void xmlTextConcat(xmlNodePtr node, const CHAR *content, int len);
Daniel Veillard16253641998-10-28 22:58:05 +0000329
Daniel Veillard1e346af1999-02-22 10:33:01 +0000330void xmlFreeNodeList(xmlNodePtr cur);
331void xmlFreeNode(xmlNodePtr cur);
Daniel Veillard16253641998-10-28 22:58:05 +0000332
333/*
334 * Namespaces
335 */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000336xmlNsPtr xmlSearchNs(xmlDocPtr doc, xmlNodePtr node,
Daniel Veillard260a68f1998-08-13 03:39:55 +0000337 const CHAR *nameSpace);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000338xmlNsPtr xmlSearchNsByHref(xmlDocPtr doc, xmlNodePtr node,
Daniel Veillard260a68f1998-08-13 03:39:55 +0000339 const CHAR *href);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000340void xmlSetNs(xmlNodePtr node, xmlNsPtr ns);
341xmlNsPtr xmlCopyNamespace(xmlNsPtr cur);
342xmlNsPtr xmlCopyNamespaceList(xmlNsPtr cur);
Daniel Veillard260a68f1998-08-13 03:39:55 +0000343
Daniel Veillard16253641998-10-28 22:58:05 +0000344/*
345 * Changing the content.
346 */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000347xmlAttrPtr xmlSetProp(xmlNodePtr node, const CHAR *name,
Daniel Veillard16253641998-10-28 22:58:05 +0000348 const CHAR *value);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000349CHAR *xmlGetProp(xmlNodePtr node, const CHAR *name);
350xmlNodePtr xmlStringGetNodeList(xmlDocPtr doc, const CHAR *value);
351xmlNodePtr xmlStringLenGetNodeList(xmlDocPtr doc, const CHAR *value,
Daniel Veillard16253641998-10-28 22:58:05 +0000352 int len);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000353CHAR *xmlNodeListGetString(xmlDocPtr doc, xmlNodePtr list, int inLine);
354void xmlNodeSetContent(xmlNodePtr cur, const CHAR *content);
355void xmlNodeSetContentLen(xmlNodePtr cur, const CHAR *content, int len);
356void xmlNodeAddContent(xmlNodePtr cur, const CHAR *content);
357void xmlNodeAddContentLen(xmlNodePtr cur, const CHAR *content, int len);
358CHAR *xmlNodeGetContent(xmlNodePtr cur);
Daniel Veillard16253641998-10-28 22:58:05 +0000359
360/*
361 * Internal, don't use
362 */
Daniel Veillard5099ae81999-04-21 20:12:07 +0000363void xmlBufferWriteCHAR(xmlBufferPtr buf, const CHAR *string);
364void xmlBufferWriteChar(xmlBufferPtr buf, const char *string);
Daniel Veillard011b63c1999-06-02 17:44:04 +0000365void xmlBufferWriteQuotedString(xmlBufferPtr buf, const CHAR *string);
Daniel Veillard260a68f1998-08-13 03:39:55 +0000366
Daniel Veillard16253641998-10-28 22:58:05 +0000367/*
368 * Saving
369 */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000370void xmlDocDumpMemory(xmlDocPtr cur, CHAR**mem, int *size);
371void xmlDocDump(FILE *f, xmlDocPtr cur);
Daniel Veillard151b1b01998-09-23 00:49:46 +0000372int xmlSaveFile(const char *filename, xmlDocPtr cur);
373
Daniel Veillard16253641998-10-28 22:58:05 +0000374/*
375 * Compression
376 */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000377int xmlGetDocCompressMode (xmlDocPtr doc);
378void xmlSetDocCompressMode (xmlDocPtr doc, int mode);
379int xmlGetCompressMode(void);
380void xmlSetCompressMode(int mode);
Daniel Veillard260a68f1998-08-13 03:39:55 +0000381
382#ifdef __cplusplus
383}
384#endif
385
386#endif /* __XML_TREE_H__ */
387