blob: 3f00aa09a035d04ca0e3c7d82bd9326da930f730 [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/*
244 * Variables.
245 */
246extern xmlNsPtr baseDTD;
247extern int oldXMLWDcompatibility;/* maintain compatibility with old WD */
248extern int xmlIndentTreeOutput; /* try to indent the tree dumps */
249
250/*
Daniel Veillard16253641998-10-28 22:58:05 +0000251 * Creating/freeing new structures
Daniel Veillard260a68f1998-08-13 03:39:55 +0000252 */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000253xmlDtdPtr xmlCreateIntSubset(xmlDocPtr doc, const CHAR *name,
Daniel Veillard39a1f9a1999-01-17 19:11:59 +0000254 const CHAR *ExternalID, const CHAR *SystemID);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000255xmlDtdPtr xmlNewDtd(xmlDocPtr doc, const CHAR *name,
Daniel Veillard260a68f1998-08-13 03:39:55 +0000256 const CHAR *ExternalID, const CHAR *SystemID);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000257void xmlFreeDtd(xmlDtdPtr cur);
258xmlNsPtr xmlNewGlobalNs(xmlDocPtr doc, const CHAR *href, const CHAR *prefix);
259xmlNsPtr xmlNewNs(xmlNodePtr node, const CHAR *href, const CHAR *prefix);
260void xmlFreeNs(xmlNsPtr cur);
261xmlDocPtr xmlNewDoc(const CHAR *version);
262void xmlFreeDoc(xmlDocPtr cur);
263xmlAttrPtr xmlNewDocProp(xmlDocPtr doc, const CHAR *name,
Daniel Veillardccb09631998-10-27 06:21:04 +0000264 const CHAR *value);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000265xmlAttrPtr xmlNewProp(xmlNodePtr node, const CHAR *name,
Daniel Veillard260a68f1998-08-13 03:39:55 +0000266 const CHAR *value);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000267void xmlFreePropList(xmlAttrPtr cur);
268void xmlFreeProp(xmlAttrPtr cur);
269xmlAttrPtr xmlCopyProp(xmlAttrPtr cur);
270xmlAttrPtr xmlCopyPropList(xmlAttrPtr cur);
271xmlDtdPtr xmlCopyDtd(xmlDtdPtr dtd);
272xmlDocPtr xmlCopyDoc(xmlDocPtr doc, int recursive);
Daniel Veillard16253641998-10-28 22:58:05 +0000273
274/*
275 * Creating new nodes
276 */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000277xmlNodePtr xmlNewDocNode(xmlDocPtr doc, xmlNsPtr ns,
Daniel Veillard0bef1311998-10-14 02:36:47 +0000278 const CHAR *name, CHAR *content);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000279xmlNodePtr xmlNewNode(xmlNsPtr ns, const CHAR *name);
280xmlNodePtr xmlNewChild(xmlNodePtr parent, xmlNsPtr ns,
Daniel Veillard16253641998-10-28 22:58:05 +0000281 const CHAR *name, CHAR *content);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000282xmlNodePtr xmlNewDocText(xmlDocPtr doc, const CHAR *content);
283xmlNodePtr xmlNewText(const CHAR *content);
284xmlNodePtr xmlNewDocTextLen(xmlDocPtr doc, const CHAR *content, int len);
285xmlNodePtr xmlNewTextLen(const CHAR *content, int len);
Daniel Veillard517752b1999-04-05 12:20:10 +0000286xmlNodePtr xmlNewDocComment(xmlDocPtr doc, const CHAR *content);
287xmlNodePtr xmlNewComment(const CHAR *content);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000288xmlNodePtr xmlNewReference(xmlDocPtr doc, const CHAR *name);
289xmlNodePtr xmlCopyNode(xmlNodePtr node, int recursive);
290xmlNodePtr xmlCopyNodeList(xmlNodePtr node);
Daniel Veillard16253641998-10-28 22:58:05 +0000291
292/*
293 * Navigating
294 */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000295xmlNodePtr xmlGetLastChild(xmlNodePtr parent);
296int xmlNodeIsText(xmlNodePtr node);
Daniel Veillard16253641998-10-28 22:58:05 +0000297
298/*
299 * Changing the structure
300 */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000301xmlNodePtr xmlAddChild(xmlNodePtr parent, xmlNodePtr cur);
302void xmlUnlinkNode(xmlNodePtr cur);
Daniel Veillard16253641998-10-28 22:58:05 +0000303
Daniel Veillard1e346af1999-02-22 10:33:01 +0000304xmlNodePtr xmlTextMerge(xmlNodePtr first, xmlNodePtr second);
305void xmlTextConcat(xmlNodePtr node, const CHAR *content, int len);
Daniel Veillard16253641998-10-28 22:58:05 +0000306
Daniel Veillard1e346af1999-02-22 10:33:01 +0000307void xmlFreeNodeList(xmlNodePtr cur);
308void xmlFreeNode(xmlNodePtr cur);
Daniel Veillard16253641998-10-28 22:58:05 +0000309
310/*
311 * Namespaces
312 */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000313xmlNsPtr xmlSearchNs(xmlDocPtr doc, xmlNodePtr node,
Daniel Veillard260a68f1998-08-13 03:39:55 +0000314 const CHAR *nameSpace);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000315xmlNsPtr xmlSearchNsByHref(xmlDocPtr doc, xmlNodePtr node,
Daniel Veillard260a68f1998-08-13 03:39:55 +0000316 const CHAR *href);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000317void xmlSetNs(xmlNodePtr node, xmlNsPtr ns);
318xmlNsPtr xmlCopyNamespace(xmlNsPtr cur);
319xmlNsPtr xmlCopyNamespaceList(xmlNsPtr cur);
Daniel Veillard260a68f1998-08-13 03:39:55 +0000320
Daniel Veillard16253641998-10-28 22:58:05 +0000321/*
322 * Changing the content.
323 */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000324xmlAttrPtr xmlSetProp(xmlNodePtr node, const CHAR *name,
Daniel Veillard16253641998-10-28 22:58:05 +0000325 const CHAR *value);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000326CHAR *xmlGetProp(xmlNodePtr node, const CHAR *name);
327xmlNodePtr xmlStringGetNodeList(xmlDocPtr doc, const CHAR *value);
328xmlNodePtr xmlStringLenGetNodeList(xmlDocPtr doc, const CHAR *value,
Daniel Veillard16253641998-10-28 22:58:05 +0000329 int len);
Daniel Veillard1e346af1999-02-22 10:33:01 +0000330CHAR *xmlNodeListGetString(xmlDocPtr doc, xmlNodePtr list, int inLine);
331void xmlNodeSetContent(xmlNodePtr cur, const CHAR *content);
332void xmlNodeSetContentLen(xmlNodePtr cur, const CHAR *content, int len);
333void xmlNodeAddContent(xmlNodePtr cur, const CHAR *content);
334void xmlNodeAddContentLen(xmlNodePtr cur, const CHAR *content, int len);
335CHAR *xmlNodeGetContent(xmlNodePtr cur);
Daniel Veillard16253641998-10-28 22:58:05 +0000336
337/*
338 * Internal, don't use
339 */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000340void xmlBufferWriteCHAR(const CHAR *string);
341void xmlBufferWriteChar(const char *string);
Daniel Veillard260a68f1998-08-13 03:39:55 +0000342
Daniel Veillard16253641998-10-28 22:58:05 +0000343/*
344 * Saving
345 */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000346void xmlDocDumpMemory(xmlDocPtr cur, CHAR**mem, int *size);
347void xmlDocDump(FILE *f, xmlDocPtr cur);
Daniel Veillard151b1b01998-09-23 00:49:46 +0000348int xmlSaveFile(const char *filename, xmlDocPtr cur);
349
Daniel Veillard16253641998-10-28 22:58:05 +0000350/*
351 * Compression
352 */
Daniel Veillard1e346af1999-02-22 10:33:01 +0000353int xmlGetDocCompressMode (xmlDocPtr doc);
354void xmlSetDocCompressMode (xmlDocPtr doc, int mode);
355int xmlGetCompressMode(void);
356void xmlSetCompressMode(int mode);
Daniel Veillard260a68f1998-08-13 03:39:55 +0000357
358#ifdef __cplusplus
359}
360#endif
361
362#endif /* __XML_TREE_H__ */
363