1 | /*
|
---|
2 | * Summary: interfaces for tree manipulation
|
---|
3 | * Description: this module describes the structures found in an tree resulting
|
---|
4 | * from an XML or HTML parsing, as well as the API provided for
|
---|
5 | * various processing on that tree
|
---|
6 | *
|
---|
7 | * Copy: See Copyright for the status of this software.
|
---|
8 | *
|
---|
9 | * Author: Daniel Veillard
|
---|
10 | */
|
---|
11 |
|
---|
12 | #ifndef __XML_TREE_H__
|
---|
13 | #define __XML_TREE_H__
|
---|
14 |
|
---|
15 | #include <stdio.h>
|
---|
16 | #include <limits.h>
|
---|
17 | #include <libxml/xmlversion.h>
|
---|
18 | #include <libxml/xmlstring.h>
|
---|
19 |
|
---|
20 | #ifdef __cplusplus
|
---|
21 | extern "C" {
|
---|
22 | #endif
|
---|
23 |
|
---|
24 | /*
|
---|
25 | * Some of the basic types pointer to structures:
|
---|
26 | */
|
---|
27 | /* xmlIO.h */
|
---|
28 | typedef struct _xmlParserInputBuffer xmlParserInputBuffer;
|
---|
29 | typedef xmlParserInputBuffer *xmlParserInputBufferPtr;
|
---|
30 |
|
---|
31 | typedef struct _xmlOutputBuffer xmlOutputBuffer;
|
---|
32 | typedef xmlOutputBuffer *xmlOutputBufferPtr;
|
---|
33 |
|
---|
34 | /* parser.h */
|
---|
35 | typedef struct _xmlParserInput xmlParserInput;
|
---|
36 | typedef xmlParserInput *xmlParserInputPtr;
|
---|
37 |
|
---|
38 | typedef struct _xmlParserCtxt xmlParserCtxt;
|
---|
39 | typedef xmlParserCtxt *xmlParserCtxtPtr;
|
---|
40 |
|
---|
41 | typedef struct _xmlSAXLocator xmlSAXLocator;
|
---|
42 | typedef xmlSAXLocator *xmlSAXLocatorPtr;
|
---|
43 |
|
---|
44 | typedef struct _xmlSAXHandler xmlSAXHandler;
|
---|
45 | typedef xmlSAXHandler *xmlSAXHandlerPtr;
|
---|
46 |
|
---|
47 | /* entities.h */
|
---|
48 | typedef struct _xmlEntity xmlEntity;
|
---|
49 | typedef xmlEntity *xmlEntityPtr;
|
---|
50 |
|
---|
51 | /**
|
---|
52 | * BASE_BUFFER_SIZE:
|
---|
53 | *
|
---|
54 | * default buffer size 4000.
|
---|
55 | */
|
---|
56 | #define BASE_BUFFER_SIZE 4096
|
---|
57 |
|
---|
58 | /**
|
---|
59 | * LIBXML_NAMESPACE_DICT:
|
---|
60 | *
|
---|
61 | * Defines experimental behaviour:
|
---|
62 | * 1) xmlNs gets an additional field @context (a xmlDoc)
|
---|
63 | * 2) when creating a tree, xmlNs->href is stored in the dict of xmlDoc.
|
---|
64 | */
|
---|
65 | /* #define LIBXML_NAMESPACE_DICT */
|
---|
66 |
|
---|
67 | /**
|
---|
68 | * xmlBufferAllocationScheme:
|
---|
69 | *
|
---|
70 | * A buffer allocation scheme can be defined to either match exactly the
|
---|
71 | * need or double it's allocated size each time it is found too small.
|
---|
72 | */
|
---|
73 |
|
---|
74 | typedef enum {
|
---|
75 | XML_BUFFER_ALLOC_DOUBLEIT, /* double each time one need to grow */
|
---|
76 | XML_BUFFER_ALLOC_EXACT, /* grow only to the minimal size */
|
---|
77 | XML_BUFFER_ALLOC_IMMUTABLE, /* immutable buffer */
|
---|
78 | XML_BUFFER_ALLOC_IO, /* special allocation scheme used for I/O */
|
---|
79 | XML_BUFFER_ALLOC_HYBRID, /* exact up to a threshold, and doubleit thereafter */
|
---|
80 | XML_BUFFER_ALLOC_BOUNDED /* limit the upper size of the buffer */
|
---|
81 | } xmlBufferAllocationScheme;
|
---|
82 |
|
---|
83 | /**
|
---|
84 | * xmlBuffer:
|
---|
85 | *
|
---|
86 | * A buffer structure, this old construct is limited to 2GB and
|
---|
87 | * is being deprecated, use API with xmlBuf instead
|
---|
88 | */
|
---|
89 | typedef struct _xmlBuffer xmlBuffer;
|
---|
90 | typedef xmlBuffer *xmlBufferPtr;
|
---|
91 | struct _xmlBuffer {
|
---|
92 | xmlChar *content; /* The buffer content UTF8 */
|
---|
93 | unsigned int use; /* The buffer size used */
|
---|
94 | unsigned int size; /* The buffer size */
|
---|
95 | xmlBufferAllocationScheme alloc; /* The realloc method */
|
---|
96 | xmlChar *contentIO; /* in IO mode we may have a different base */
|
---|
97 | };
|
---|
98 |
|
---|
99 | /**
|
---|
100 | * xmlBuf:
|
---|
101 | *
|
---|
102 | * A buffer structure, new one, the actual structure internals are not public
|
---|
103 | */
|
---|
104 |
|
---|
105 | typedef struct _xmlBuf xmlBuf;
|
---|
106 |
|
---|
107 | /**
|
---|
108 | * xmlBufPtr:
|
---|
109 | *
|
---|
110 | * A pointer to a buffer structure, the actual structure internals are not
|
---|
111 | * public
|
---|
112 | */
|
---|
113 |
|
---|
114 | typedef xmlBuf *xmlBufPtr;
|
---|
115 |
|
---|
116 | /*
|
---|
117 | * A few public routines for xmlBuf. As those are expected to be used
|
---|
118 | * mostly internally the bulk of the routines are internal in buf.h
|
---|
119 | */
|
---|
120 | XMLPUBFUN xmlChar* XMLCALL xmlBufContent (const xmlBuf* buf);
|
---|
121 | XMLPUBFUN xmlChar* XMLCALL xmlBufEnd (xmlBufPtr buf);
|
---|
122 | XMLPUBFUN size_t XMLCALL xmlBufUse (const xmlBufPtr buf);
|
---|
123 | XMLPUBFUN size_t XMLCALL xmlBufShrink (xmlBufPtr buf, size_t len);
|
---|
124 |
|
---|
125 | /*
|
---|
126 | * LIBXML2_NEW_BUFFER:
|
---|
127 | *
|
---|
128 | * Macro used to express that the API use the new buffers for
|
---|
129 | * xmlParserInputBuffer and xmlOutputBuffer. The change was
|
---|
130 | * introduced in 2.9.0.
|
---|
131 | */
|
---|
132 | #define LIBXML2_NEW_BUFFER
|
---|
133 |
|
---|
134 | /**
|
---|
135 | * XML_XML_NAMESPACE:
|
---|
136 | *
|
---|
137 | * This is the namespace for the special xml: prefix predefined in the
|
---|
138 | * XML Namespace specification.
|
---|
139 | */
|
---|
140 | #define XML_XML_NAMESPACE \
|
---|
141 | (const xmlChar *) "http://www.w3.org/XML/1998/namespace"
|
---|
142 |
|
---|
143 | /**
|
---|
144 | * XML_XML_ID:
|
---|
145 | *
|
---|
146 | * This is the name for the special xml:id attribute
|
---|
147 | */
|
---|
148 | #define XML_XML_ID (const xmlChar *) "xml:id"
|
---|
149 |
|
---|
150 | /*
|
---|
151 | * The different element types carried by an XML tree.
|
---|
152 | *
|
---|
153 | * NOTE: This is synchronized with DOM Level1 values
|
---|
154 | * See http://www.w3.org/TR/REC-DOM-Level-1/
|
---|
155 | *
|
---|
156 | * Actually this had diverged a bit, and now XML_DOCUMENT_TYPE_NODE should
|
---|
157 | * be deprecated to use an XML_DTD_NODE.
|
---|
158 | */
|
---|
159 | typedef enum {
|
---|
160 | XML_ELEMENT_NODE= 1,
|
---|
161 | XML_ATTRIBUTE_NODE= 2,
|
---|
162 | XML_TEXT_NODE= 3,
|
---|
163 | XML_CDATA_SECTION_NODE= 4,
|
---|
164 | XML_ENTITY_REF_NODE= 5,
|
---|
165 | XML_ENTITY_NODE= 6,
|
---|
166 | XML_PI_NODE= 7,
|
---|
167 | XML_COMMENT_NODE= 8,
|
---|
168 | XML_DOCUMENT_NODE= 9,
|
---|
169 | XML_DOCUMENT_TYPE_NODE= 10,
|
---|
170 | XML_DOCUMENT_FRAG_NODE= 11,
|
---|
171 | XML_NOTATION_NODE= 12,
|
---|
172 | XML_HTML_DOCUMENT_NODE= 13,
|
---|
173 | XML_DTD_NODE= 14,
|
---|
174 | XML_ELEMENT_DECL= 15,
|
---|
175 | XML_ATTRIBUTE_DECL= 16,
|
---|
176 | XML_ENTITY_DECL= 17,
|
---|
177 | XML_NAMESPACE_DECL= 18,
|
---|
178 | XML_XINCLUDE_START= 19,
|
---|
179 | XML_XINCLUDE_END= 20
|
---|
180 | #ifdef LIBXML_DOCB_ENABLED
|
---|
181 | ,XML_DOCB_DOCUMENT_NODE= 21
|
---|
182 | #endif
|
---|
183 | } xmlElementType;
|
---|
184 |
|
---|
185 |
|
---|
186 | /**
|
---|
187 | * xmlNotation:
|
---|
188 | *
|
---|
189 | * A DTD Notation definition.
|
---|
190 | */
|
---|
191 |
|
---|
192 | typedef struct _xmlNotation xmlNotation;
|
---|
193 | typedef xmlNotation *xmlNotationPtr;
|
---|
194 | struct _xmlNotation {
|
---|
195 | const xmlChar *name; /* Notation name */
|
---|
196 | const xmlChar *PublicID; /* Public identifier, if any */
|
---|
197 | const xmlChar *SystemID; /* System identifier, if any */
|
---|
198 | };
|
---|
199 |
|
---|
200 | /**
|
---|
201 | * xmlAttributeType:
|
---|
202 | *
|
---|
203 | * A DTD Attribute type definition.
|
---|
204 | */
|
---|
205 |
|
---|
206 | typedef enum {
|
---|
207 | XML_ATTRIBUTE_CDATA = 1,
|
---|
208 | XML_ATTRIBUTE_ID,
|
---|
209 | XML_ATTRIBUTE_IDREF ,
|
---|
210 | XML_ATTRIBUTE_IDREFS,
|
---|
211 | XML_ATTRIBUTE_ENTITY,
|
---|
212 | XML_ATTRIBUTE_ENTITIES,
|
---|
213 | XML_ATTRIBUTE_NMTOKEN,
|
---|
214 | XML_ATTRIBUTE_NMTOKENS,
|
---|
215 | XML_ATTRIBUTE_ENUMERATION,
|
---|
216 | XML_ATTRIBUTE_NOTATION
|
---|
217 | } xmlAttributeType;
|
---|
218 |
|
---|
219 | /**
|
---|
220 | * xmlAttributeDefault:
|
---|
221 | *
|
---|
222 | * A DTD Attribute default definition.
|
---|
223 | */
|
---|
224 |
|
---|
225 | typedef enum {
|
---|
226 | XML_ATTRIBUTE_NONE = 1,
|
---|
227 | XML_ATTRIBUTE_REQUIRED,
|
---|
228 | XML_ATTRIBUTE_IMPLIED,
|
---|
229 | XML_ATTRIBUTE_FIXED
|
---|
230 | } xmlAttributeDefault;
|
---|
231 |
|
---|
232 | /**
|
---|
233 | * xmlEnumeration:
|
---|
234 | *
|
---|
235 | * List structure used when there is an enumeration in DTDs.
|
---|
236 | */
|
---|
237 |
|
---|
238 | typedef struct _xmlEnumeration xmlEnumeration;
|
---|
239 | typedef xmlEnumeration *xmlEnumerationPtr;
|
---|
240 | struct _xmlEnumeration {
|
---|
241 | struct _xmlEnumeration *next; /* next one */
|
---|
242 | const xmlChar *name; /* Enumeration name */
|
---|
243 | };
|
---|
244 |
|
---|
245 | /**
|
---|
246 | * xmlAttribute:
|
---|
247 | *
|
---|
248 | * An Attribute declaration in a DTD.
|
---|
249 | */
|
---|
250 |
|
---|
251 | typedef struct _xmlAttribute xmlAttribute;
|
---|
252 | typedef xmlAttribute *xmlAttributePtr;
|
---|
253 | struct _xmlAttribute {
|
---|
254 | void *_private; /* application data */
|
---|
255 | xmlElementType type; /* XML_ATTRIBUTE_DECL, must be second ! */
|
---|
256 | const xmlChar *name; /* Attribute name */
|
---|
257 | struct _xmlNode *children; /* NULL */
|
---|
258 | struct _xmlNode *last; /* NULL */
|
---|
259 | struct _xmlDtd *parent; /* -> DTD */
|
---|
260 | struct _xmlNode *next; /* next sibling link */
|
---|
261 | struct _xmlNode *prev; /* previous sibling link */
|
---|
262 | struct _xmlDoc *doc; /* the containing document */
|
---|
263 |
|
---|
264 | struct _xmlAttribute *nexth; /* next in hash table */
|
---|
265 | xmlAttributeType atype; /* The attribute type */
|
---|
266 | xmlAttributeDefault def; /* the default */
|
---|
267 | const xmlChar *defaultValue; /* or the default value */
|
---|
268 | xmlEnumerationPtr tree; /* or the enumeration tree if any */
|
---|
269 | const xmlChar *prefix; /* the namespace prefix if any */
|
---|
270 | const xmlChar *elem; /* Element holding the attribute */
|
---|
271 | };
|
---|
272 |
|
---|
273 | /**
|
---|
274 | * xmlElementContentType:
|
---|
275 | *
|
---|
276 | * Possible definitions of element content types.
|
---|
277 | */
|
---|
278 | typedef enum {
|
---|
279 | XML_ELEMENT_CONTENT_PCDATA = 1,
|
---|
280 | XML_ELEMENT_CONTENT_ELEMENT,
|
---|
281 | XML_ELEMENT_CONTENT_SEQ,
|
---|
282 | XML_ELEMENT_CONTENT_OR
|
---|
283 | } xmlElementContentType;
|
---|
284 |
|
---|
285 | /**
|
---|
286 | * xmlElementContentOccur:
|
---|
287 | *
|
---|
288 | * Possible definitions of element content occurrences.
|
---|
289 | */
|
---|
290 | typedef enum {
|
---|
291 | XML_ELEMENT_CONTENT_ONCE = 1,
|
---|
292 | XML_ELEMENT_CONTENT_OPT,
|
---|
293 | XML_ELEMENT_CONTENT_MULT,
|
---|
294 | XML_ELEMENT_CONTENT_PLUS
|
---|
295 | } xmlElementContentOccur;
|
---|
296 |
|
---|
297 | /**
|
---|
298 | * xmlElementContent:
|
---|
299 | *
|
---|
300 | * An XML Element content as stored after parsing an element definition
|
---|
301 | * in a DTD.
|
---|
302 | */
|
---|
303 |
|
---|
304 | typedef struct _xmlElementContent xmlElementContent;
|
---|
305 | typedef xmlElementContent *xmlElementContentPtr;
|
---|
306 | struct _xmlElementContent {
|
---|
307 | xmlElementContentType type; /* PCDATA, ELEMENT, SEQ or OR */
|
---|
308 | xmlElementContentOccur ocur; /* ONCE, OPT, MULT or PLUS */
|
---|
309 | const xmlChar *name; /* Element name */
|
---|
310 | struct _xmlElementContent *c1; /* first child */
|
---|
311 | struct _xmlElementContent *c2; /* second child */
|
---|
312 | struct _xmlElementContent *parent; /* parent */
|
---|
313 | const xmlChar *prefix; /* Namespace prefix */
|
---|
314 | };
|
---|
315 |
|
---|
316 | /**
|
---|
317 | * xmlElementTypeVal:
|
---|
318 | *
|
---|
319 | * The different possibilities for an element content type.
|
---|
320 | */
|
---|
321 |
|
---|
322 | typedef enum {
|
---|
323 | XML_ELEMENT_TYPE_UNDEFINED = 0,
|
---|
324 | XML_ELEMENT_TYPE_EMPTY = 1,
|
---|
325 | XML_ELEMENT_TYPE_ANY,
|
---|
326 | XML_ELEMENT_TYPE_MIXED,
|
---|
327 | XML_ELEMENT_TYPE_ELEMENT
|
---|
328 | } xmlElementTypeVal;
|
---|
329 |
|
---|
330 | #ifdef __cplusplus
|
---|
331 | }
|
---|
332 | #endif
|
---|
333 | #include <libxml/xmlregexp.h>
|
---|
334 | #ifdef __cplusplus
|
---|
335 | extern "C" {
|
---|
336 | #endif
|
---|
337 |
|
---|
338 | /**
|
---|
339 | * xmlElement:
|
---|
340 | *
|
---|
341 | * An XML Element declaration from a DTD.
|
---|
342 | */
|
---|
343 |
|
---|
344 | typedef struct _xmlElement xmlElement;
|
---|
345 | typedef xmlElement *xmlElementPtr;
|
---|
346 | struct _xmlElement {
|
---|
347 | void *_private; /* application data */
|
---|
348 | xmlElementType type; /* XML_ELEMENT_DECL, must be second ! */
|
---|
349 | const xmlChar *name; /* Element name */
|
---|
350 | struct _xmlNode *children; /* NULL */
|
---|
351 | struct _xmlNode *last; /* NULL */
|
---|
352 | struct _xmlDtd *parent; /* -> DTD */
|
---|
353 | struct _xmlNode *next; /* next sibling link */
|
---|
354 | struct _xmlNode *prev; /* previous sibling link */
|
---|
355 | struct _xmlDoc *doc; /* the containing document */
|
---|
356 |
|
---|
357 | xmlElementTypeVal etype; /* The type */
|
---|
358 | xmlElementContentPtr content; /* the allowed element content */
|
---|
359 | xmlAttributePtr attributes; /* List of the declared attributes */
|
---|
360 | const xmlChar *prefix; /* the namespace prefix if any */
|
---|
361 | #ifdef LIBXML_REGEXP_ENABLED
|
---|
362 | xmlRegexpPtr contModel; /* the validating regexp */
|
---|
363 | #else
|
---|
364 | void *contModel;
|
---|
365 | #endif
|
---|
366 | };
|
---|
367 |
|
---|
368 |
|
---|
369 | /**
|
---|
370 | * XML_LOCAL_NAMESPACE:
|
---|
371 | *
|
---|
372 | * A namespace declaration node.
|
---|
373 | */
|
---|
374 | #define XML_LOCAL_NAMESPACE XML_NAMESPACE_DECL
|
---|
375 | typedef xmlElementType xmlNsType;
|
---|
376 |
|
---|
377 | /**
|
---|
378 | * xmlNs:
|
---|
379 | *
|
---|
380 | * An XML namespace.
|
---|
381 | * Note that prefix == NULL is valid, it defines the default namespace
|
---|
382 | * within the subtree (until overridden).
|
---|
383 | *
|
---|
384 | * xmlNsType is unified with xmlElementType.
|
---|
385 | */
|
---|
386 |
|
---|
387 | typedef struct _xmlNs xmlNs;
|
---|
388 | typedef xmlNs *xmlNsPtr;
|
---|
389 | struct _xmlNs {
|
---|
390 | struct _xmlNs *next; /* next Ns link for this node */
|
---|
391 | xmlNsType type; /* global or local */
|
---|
392 | const xmlChar *href; /* URL for the namespace */
|
---|
393 | const xmlChar *prefix; /* prefix for the namespace */
|
---|
394 | void *_private; /* application data */
|
---|
395 | struct _xmlDoc *context; /* normally an xmlDoc */
|
---|
396 | };
|
---|
397 |
|
---|
398 | /**
|
---|
399 | * xmlDtd:
|
---|
400 | *
|
---|
401 | * An XML DTD, as defined by <!DOCTYPE ... There is actually one for
|
---|
402 | * the internal subset and for the external subset.
|
---|
403 | */
|
---|
404 | typedef struct _xmlDtd xmlDtd;
|
---|
405 | typedef xmlDtd *xmlDtdPtr;
|
---|
406 | struct _xmlDtd {
|
---|
407 | void *_private; /* application data */
|
---|
408 | xmlElementType type; /* XML_DTD_NODE, must be second ! */
|
---|
409 | const xmlChar *name; /* Name of the DTD */
|
---|
410 | struct _xmlNode *children; /* the value of the property link */
|
---|
411 | struct _xmlNode *last; /* last child link */
|
---|
412 | struct _xmlDoc *parent; /* child->parent link */
|
---|
413 | struct _xmlNode *next; /* next sibling link */
|
---|
414 | struct _xmlNode *prev; /* previous sibling link */
|
---|
415 | struct _xmlDoc *doc; /* the containing document */
|
---|
416 |
|
---|
417 | /* End of common part */
|
---|
418 | void *notations; /* Hash table for notations if any */
|
---|
419 | void *elements; /* Hash table for elements if any */
|
---|
420 | void *attributes; /* Hash table for attributes if any */
|
---|
421 | void *entities; /* Hash table for entities if any */
|
---|
422 | const xmlChar *ExternalID; /* External identifier for PUBLIC DTD */
|
---|
423 | const xmlChar *SystemID; /* URI for a SYSTEM or PUBLIC DTD */
|
---|
424 | void *pentities; /* Hash table for param entities if any */
|
---|
425 | };
|
---|
426 |
|
---|
427 | /**
|
---|
428 | * xmlAttr:
|
---|
429 | *
|
---|
430 | * An attribute on an XML node.
|
---|
431 | */
|
---|
432 | typedef struct _xmlAttr xmlAttr;
|
---|
433 | typedef xmlAttr *xmlAttrPtr;
|
---|
434 | struct _xmlAttr {
|
---|
435 | void *_private; /* application data */
|
---|
436 | xmlElementType type; /* XML_ATTRIBUTE_NODE, must be second ! */
|
---|
437 | const xmlChar *name; /* the name of the property */
|
---|
438 | struct _xmlNode *children; /* the value of the property */
|
---|
439 | struct _xmlNode *last; /* NULL */
|
---|
440 | struct _xmlNode *parent; /* child->parent link */
|
---|
441 | struct _xmlAttr *next; /* next sibling link */
|
---|
442 | struct _xmlAttr *prev; /* previous sibling link */
|
---|
443 | struct _xmlDoc *doc; /* the containing document */
|
---|
444 | xmlNs *ns; /* pointer to the associated namespace */
|
---|
445 | xmlAttributeType atype; /* the attribute type if validating */
|
---|
446 | void *psvi; /* for type/PSVI informations */
|
---|
447 | };
|
---|
448 |
|
---|
449 | /**
|
---|
450 | * xmlID:
|
---|
451 | *
|
---|
452 | * An XML ID instance.
|
---|
453 | */
|
---|
454 |
|
---|
455 | typedef struct _xmlID xmlID;
|
---|
456 | typedef xmlID *xmlIDPtr;
|
---|
457 | struct _xmlID {
|
---|
458 | struct _xmlID *next; /* next ID */
|
---|
459 | const xmlChar *value; /* The ID name */
|
---|
460 | xmlAttrPtr attr; /* The attribute holding it */
|
---|
461 | const xmlChar *name; /* The attribute if attr is not available */
|
---|
462 | int lineno; /* The line number if attr is not available */
|
---|
463 | struct _xmlDoc *doc; /* The document holding the ID */
|
---|
464 | };
|
---|
465 |
|
---|
466 | /**
|
---|
467 | * xmlRef:
|
---|
468 | *
|
---|
469 | * An XML IDREF instance.
|
---|
470 | */
|
---|
471 |
|
---|
472 | typedef struct _xmlRef xmlRef;
|
---|
473 | typedef xmlRef *xmlRefPtr;
|
---|
474 | struct _xmlRef {
|
---|
475 | struct _xmlRef *next; /* next Ref */
|
---|
476 | const xmlChar *value; /* The Ref name */
|
---|
477 | xmlAttrPtr attr; /* The attribute holding it */
|
---|
478 | const xmlChar *name; /* The attribute if attr is not available */
|
---|
479 | int lineno; /* The line number if attr is not available */
|
---|
480 | };
|
---|
481 |
|
---|
482 | /**
|
---|
483 | * xmlNode:
|
---|
484 | *
|
---|
485 | * A node in an XML tree.
|
---|
486 | */
|
---|
487 | typedef struct _xmlNode xmlNode;
|
---|
488 | typedef xmlNode *xmlNodePtr;
|
---|
489 | struct _xmlNode {
|
---|
490 | void *_private; /* application data */
|
---|
491 | xmlElementType type; /* type number, must be second ! */
|
---|
492 | const xmlChar *name; /* the name of the node, or the entity */
|
---|
493 | struct _xmlNode *children; /* parent->childs link */
|
---|
494 | struct _xmlNode *last; /* last child link */
|
---|
495 | struct _xmlNode *parent; /* child->parent link */
|
---|
496 | struct _xmlNode *next; /* next sibling link */
|
---|
497 | struct _xmlNode *prev; /* previous sibling link */
|
---|
498 | struct _xmlDoc *doc; /* the containing document */
|
---|
499 |
|
---|
500 | /* End of common part */
|
---|
501 | xmlNs *ns; /* pointer to the associated namespace */
|
---|
502 | xmlChar *content; /* the content */
|
---|
503 | struct _xmlAttr *properties;/* properties list */
|
---|
504 | xmlNs *nsDef; /* namespace definitions on this node */
|
---|
505 | void *psvi; /* for type/PSVI informations */
|
---|
506 | unsigned short line; /* line number */
|
---|
507 | unsigned short extra; /* extra data for XPath/XSLT */
|
---|
508 | };
|
---|
509 |
|
---|
510 | /**
|
---|
511 | * XML_GET_CONTENT:
|
---|
512 | *
|
---|
513 | * Macro to extract the content pointer of a node.
|
---|
514 | */
|
---|
515 | #define XML_GET_CONTENT(n) \
|
---|
516 | ((n)->type == XML_ELEMENT_NODE ? NULL : (n)->content)
|
---|
517 |
|
---|
518 | /**
|
---|
519 | * XML_GET_LINE:
|
---|
520 | *
|
---|
521 | * Macro to extract the line number of an element node.
|
---|
522 | */
|
---|
523 | #define XML_GET_LINE(n) \
|
---|
524 | (xmlGetLineNo(n))
|
---|
525 |
|
---|
526 | /**
|
---|
527 | * xmlDocProperty
|
---|
528 | *
|
---|
529 | * Set of properties of the document as found by the parser
|
---|
530 | * Some of them are linked to similary named xmlParserOption
|
---|
531 | */
|
---|
532 | typedef enum {
|
---|
533 | XML_DOC_WELLFORMED = 1<<0, /* document is XML well formed */
|
---|
534 | XML_DOC_NSVALID = 1<<1, /* document is Namespace valid */
|
---|
535 | XML_DOC_OLD10 = 1<<2, /* parsed with old XML-1.0 parser */
|
---|
536 | XML_DOC_DTDVALID = 1<<3, /* DTD validation was successful */
|
---|
537 | XML_DOC_XINCLUDE = 1<<4, /* XInclude substitution was done */
|
---|
538 | XML_DOC_USERBUILT = 1<<5, /* Document was built using the API
|
---|
539 | and not by parsing an instance */
|
---|
540 | XML_DOC_INTERNAL = 1<<6, /* built for internal processing */
|
---|
541 | XML_DOC_HTML = 1<<7 /* parsed or built HTML document */
|
---|
542 | } xmlDocProperties;
|
---|
543 |
|
---|
544 | /**
|
---|
545 | * xmlDoc:
|
---|
546 | *
|
---|
547 | * An XML document.
|
---|
548 | */
|
---|
549 | typedef struct _xmlDoc xmlDoc;
|
---|
550 | typedef xmlDoc *xmlDocPtr;
|
---|
551 | struct _xmlDoc {
|
---|
552 | void *_private; /* application data */
|
---|
553 | xmlElementType type; /* XML_DOCUMENT_NODE, must be second ! */
|
---|
554 | char *name; /* name/filename/URI of the document */
|
---|
555 | struct _xmlNode *children; /* the document tree */
|
---|
556 | struct _xmlNode *last; /* last child link */
|
---|
557 | struct _xmlNode *parent; /* child->parent link */
|
---|
558 | struct _xmlNode *next; /* next sibling link */
|
---|
559 | struct _xmlNode *prev; /* previous sibling link */
|
---|
560 | struct _xmlDoc *doc; /* autoreference to itself */
|
---|
561 |
|
---|
562 | /* End of common part */
|
---|
563 | int compression;/* level of zlib compression */
|
---|
564 | int standalone; /* standalone document (no external refs)
|
---|
565 | 1 if standalone="yes"
|
---|
566 | 0 if standalone="no"
|
---|
567 | -1 if there is no XML declaration
|
---|
568 | -2 if there is an XML declaration, but no
|
---|
569 | standalone attribute was specified */
|
---|
570 | struct _xmlDtd *intSubset; /* the document internal subset */
|
---|
571 | struct _xmlDtd *extSubset; /* the document external subset */
|
---|
572 | struct _xmlNs *oldNs; /* Global namespace, the old way */
|
---|
573 | const xmlChar *version; /* the XML version string */
|
---|
574 | const xmlChar *encoding; /* external initial encoding, if any */
|
---|
575 | void *ids; /* Hash table for ID attributes if any */
|
---|
576 | void *refs; /* Hash table for IDREFs attributes if any */
|
---|
577 | const xmlChar *URL; /* The URI for that document */
|
---|
578 | int charset; /* encoding of the in-memory content
|
---|
579 | actually an xmlCharEncoding */
|
---|
580 | struct _xmlDict *dict; /* dict used to allocate names or NULL */
|
---|
581 | void *psvi; /* for type/PSVI informations */
|
---|
582 | int parseFlags; /* set of xmlParserOption used to parse the
|
---|
583 | document */
|
---|
584 | int properties; /* set of xmlDocProperties for this document
|
---|
585 | set at the end of parsing */
|
---|
586 | };
|
---|
587 |
|
---|
588 |
|
---|
589 | typedef struct _xmlDOMWrapCtxt xmlDOMWrapCtxt;
|
---|
590 | typedef xmlDOMWrapCtxt *xmlDOMWrapCtxtPtr;
|
---|
591 |
|
---|
592 | /**
|
---|
593 | * xmlDOMWrapAcquireNsFunction:
|
---|
594 | * @ctxt: a DOM wrapper context
|
---|
595 | * @node: the context node (element or attribute)
|
---|
596 | * @nsName: the requested namespace name
|
---|
597 | * @nsPrefix: the requested namespace prefix
|
---|
598 | *
|
---|
599 | * A function called to acquire namespaces (xmlNs) from the wrapper.
|
---|
600 | *
|
---|
601 | * Returns an xmlNsPtr or NULL in case of an error.
|
---|
602 | */
|
---|
603 | typedef xmlNsPtr (*xmlDOMWrapAcquireNsFunction) (xmlDOMWrapCtxtPtr ctxt,
|
---|
604 | xmlNodePtr node,
|
---|
605 | const xmlChar *nsName,
|
---|
606 | const xmlChar *nsPrefix);
|
---|
607 |
|
---|
608 | /**
|
---|
609 | * xmlDOMWrapCtxt:
|
---|
610 | *
|
---|
611 | * Context for DOM wrapper-operations.
|
---|
612 | */
|
---|
613 | struct _xmlDOMWrapCtxt {
|
---|
614 | void * _private;
|
---|
615 | /*
|
---|
616 | * The type of this context, just in case we need specialized
|
---|
617 | * contexts in the future.
|
---|
618 | */
|
---|
619 | int type;
|
---|
620 | /*
|
---|
621 | * Internal namespace map used for various operations.
|
---|
622 | */
|
---|
623 | void * namespaceMap;
|
---|
624 | /*
|
---|
625 | * Use this one to acquire an xmlNsPtr intended for node->ns.
|
---|
626 | * (Note that this is not intended for elem->nsDef).
|
---|
627 | */
|
---|
628 | xmlDOMWrapAcquireNsFunction getNsForNodeFunc;
|
---|
629 | };
|
---|
630 |
|
---|
631 | /**
|
---|
632 | * xmlChildrenNode:
|
---|
633 | *
|
---|
634 | * Macro for compatibility naming layer with libxml1. Maps
|
---|
635 | * to "children."
|
---|
636 | */
|
---|
637 | #ifndef xmlChildrenNode
|
---|
638 | #define xmlChildrenNode children
|
---|
639 | #endif
|
---|
640 |
|
---|
641 | /**
|
---|
642 | * xmlRootNode:
|
---|
643 | *
|
---|
644 | * Macro for compatibility naming layer with libxml1. Maps
|
---|
645 | * to "children".
|
---|
646 | */
|
---|
647 | #ifndef xmlRootNode
|
---|
648 | #define xmlRootNode children
|
---|
649 | #endif
|
---|
650 |
|
---|
651 | /*
|
---|
652 | * Variables.
|
---|
653 | */
|
---|
654 |
|
---|
655 | /*
|
---|
656 | * Some helper functions
|
---|
657 | */
|
---|
658 | #if defined(LIBXML_TREE_ENABLED) || defined(LIBXML_XPATH_ENABLED) || \
|
---|
659 | defined(LIBXML_SCHEMAS_ENABLED) || defined(LIBXML_DEBUG_ENABLED) || \
|
---|
660 | defined (LIBXML_HTML_ENABLED) || defined(LIBXML_SAX1_ENABLED) || \
|
---|
661 | defined(LIBXML_HTML_ENABLED) || defined(LIBXML_WRITER_ENABLED) || \
|
---|
662 | defined(LIBXML_DOCB_ENABLED) || defined(LIBXML_LEGACY_ENABLED)
|
---|
663 | XMLPUBFUN int XMLCALL
|
---|
664 | xmlValidateNCName (const xmlChar *value,
|
---|
665 | int space);
|
---|
666 | #endif
|
---|
667 |
|
---|
668 | #if defined(LIBXML_TREE_ENABLED) || defined(LIBXML_SCHEMAS_ENABLED)
|
---|
669 | XMLPUBFUN int XMLCALL
|
---|
670 | xmlValidateQName (const xmlChar *value,
|
---|
671 | int space);
|
---|
672 | XMLPUBFUN int XMLCALL
|
---|
673 | xmlValidateName (const xmlChar *value,
|
---|
674 | int space);
|
---|
675 | XMLPUBFUN int XMLCALL
|
---|
676 | xmlValidateNMToken (const xmlChar *value,
|
---|
677 | int space);
|
---|
678 | #endif
|
---|
679 |
|
---|
680 | XMLPUBFUN xmlChar * XMLCALL
|
---|
681 | xmlBuildQName (const xmlChar *ncname,
|
---|
682 | const xmlChar *prefix,
|
---|
683 | xmlChar *memory,
|
---|
684 | int len);
|
---|
685 | XMLPUBFUN xmlChar * XMLCALL
|
---|
686 | xmlSplitQName2 (const xmlChar *name,
|
---|
687 | xmlChar **prefix);
|
---|
688 | XMLPUBFUN const xmlChar * XMLCALL
|
---|
689 | xmlSplitQName3 (const xmlChar *name,
|
---|
690 | int *len);
|
---|
691 |
|
---|
692 | /*
|
---|
693 | * Handling Buffers, the old ones see @xmlBuf for the new ones.
|
---|
694 | */
|
---|
695 |
|
---|
696 | XMLPUBFUN void XMLCALL
|
---|
697 | xmlSetBufferAllocationScheme(xmlBufferAllocationScheme scheme);
|
---|
698 | XMLPUBFUN xmlBufferAllocationScheme XMLCALL
|
---|
699 | xmlGetBufferAllocationScheme(void);
|
---|
700 |
|
---|
701 | XMLPUBFUN xmlBufferPtr XMLCALL
|
---|
702 | xmlBufferCreate (void);
|
---|
703 | XMLPUBFUN xmlBufferPtr XMLCALL
|
---|
704 | xmlBufferCreateSize (size_t size);
|
---|
705 | XMLPUBFUN xmlBufferPtr XMLCALL
|
---|
706 | xmlBufferCreateStatic (void *mem,
|
---|
707 | size_t size);
|
---|
708 | XMLPUBFUN int XMLCALL
|
---|
709 | xmlBufferResize (xmlBufferPtr buf,
|
---|
710 | unsigned int size);
|
---|
711 | XMLPUBFUN void XMLCALL
|
---|
712 | xmlBufferFree (xmlBufferPtr buf);
|
---|
713 | XMLPUBFUN int XMLCALL
|
---|
714 | xmlBufferDump (FILE *file,
|
---|
715 | xmlBufferPtr buf);
|
---|
716 | XMLPUBFUN int XMLCALL
|
---|
717 | xmlBufferAdd (xmlBufferPtr buf,
|
---|
718 | const xmlChar *str,
|
---|
719 | int len);
|
---|
720 | XMLPUBFUN int XMLCALL
|
---|
721 | xmlBufferAddHead (xmlBufferPtr buf,
|
---|
722 | const xmlChar *str,
|
---|
723 | int len);
|
---|
724 | XMLPUBFUN int XMLCALL
|
---|
725 | xmlBufferCat (xmlBufferPtr buf,
|
---|
726 | const xmlChar *str);
|
---|
727 | XMLPUBFUN int XMLCALL
|
---|
728 | xmlBufferCCat (xmlBufferPtr buf,
|
---|
729 | const char *str);
|
---|
730 | XMLPUBFUN int XMLCALL
|
---|
731 | xmlBufferShrink (xmlBufferPtr buf,
|
---|
732 | unsigned int len);
|
---|
733 | XMLPUBFUN int XMLCALL
|
---|
734 | xmlBufferGrow (xmlBufferPtr buf,
|
---|
735 | unsigned int len);
|
---|
736 | XMLPUBFUN void XMLCALL
|
---|
737 | xmlBufferEmpty (xmlBufferPtr buf);
|
---|
738 | XMLPUBFUN const xmlChar* XMLCALL
|
---|
739 | xmlBufferContent (const xmlBuffer *buf);
|
---|
740 | XMLPUBFUN xmlChar* XMLCALL
|
---|
741 | xmlBufferDetach (xmlBufferPtr buf);
|
---|
742 | XMLPUBFUN void XMLCALL
|
---|
743 | xmlBufferSetAllocationScheme(xmlBufferPtr buf,
|
---|
744 | xmlBufferAllocationScheme scheme);
|
---|
745 | XMLPUBFUN int XMLCALL
|
---|
746 | xmlBufferLength (const xmlBuffer *buf);
|
---|
747 |
|
---|
748 | /*
|
---|
749 | * Creating/freeing new structures.
|
---|
750 | */
|
---|
751 | XMLPUBFUN xmlDtdPtr XMLCALL
|
---|
752 | xmlCreateIntSubset (xmlDocPtr doc,
|
---|
753 | const xmlChar *name,
|
---|
754 | const xmlChar *ExternalID,
|
---|
755 | const xmlChar *SystemID);
|
---|
756 | XMLPUBFUN xmlDtdPtr XMLCALL
|
---|
757 | xmlNewDtd (xmlDocPtr doc,
|
---|
758 | const xmlChar *name,
|
---|
759 | const xmlChar *ExternalID,
|
---|
760 | const xmlChar *SystemID);
|
---|
761 | XMLPUBFUN xmlDtdPtr XMLCALL
|
---|
762 | xmlGetIntSubset (const xmlDoc *doc);
|
---|
763 | XMLPUBFUN void XMLCALL
|
---|
764 | xmlFreeDtd (xmlDtdPtr cur);
|
---|
765 | #ifdef LIBXML_LEGACY_ENABLED
|
---|
766 | XMLPUBFUN xmlNsPtr XMLCALL
|
---|
767 | xmlNewGlobalNs (xmlDocPtr doc,
|
---|
768 | const xmlChar *href,
|
---|
769 | const xmlChar *prefix);
|
---|
770 | #endif /* LIBXML_LEGACY_ENABLED */
|
---|
771 | XMLPUBFUN xmlNsPtr XMLCALL
|
---|
772 | xmlNewNs (xmlNodePtr node,
|
---|
773 | const xmlChar *href,
|
---|
774 | const xmlChar *prefix);
|
---|
775 | XMLPUBFUN void XMLCALL
|
---|
776 | xmlFreeNs (xmlNsPtr cur);
|
---|
777 | XMLPUBFUN void XMLCALL
|
---|
778 | xmlFreeNsList (xmlNsPtr cur);
|
---|
779 | XMLPUBFUN xmlDocPtr XMLCALL
|
---|
780 | xmlNewDoc (const xmlChar *version);
|
---|
781 | XMLPUBFUN void XMLCALL
|
---|
782 | xmlFreeDoc (xmlDocPtr cur);
|
---|
783 | XMLPUBFUN xmlAttrPtr XMLCALL
|
---|
784 | xmlNewDocProp (xmlDocPtr doc,
|
---|
785 | const xmlChar *name,
|
---|
786 | const xmlChar *value);
|
---|
787 | #if defined(LIBXML_TREE_ENABLED) || defined(LIBXML_HTML_ENABLED) || \
|
---|
788 | defined(LIBXML_SCHEMAS_ENABLED)
|
---|
789 | XMLPUBFUN xmlAttrPtr XMLCALL
|
---|
790 | xmlNewProp (xmlNodePtr node,
|
---|
791 | const xmlChar *name,
|
---|
792 | const xmlChar *value);
|
---|
793 | #endif
|
---|
794 | XMLPUBFUN xmlAttrPtr XMLCALL
|
---|
795 | xmlNewNsProp (xmlNodePtr node,
|
---|
796 | xmlNsPtr ns,
|
---|
797 | const xmlChar *name,
|
---|
798 | const xmlChar *value);
|
---|
799 | XMLPUBFUN xmlAttrPtr XMLCALL
|
---|
800 | xmlNewNsPropEatName (xmlNodePtr node,
|
---|
801 | xmlNsPtr ns,
|
---|
802 | xmlChar *name,
|
---|
803 | const xmlChar *value);
|
---|
804 | XMLPUBFUN void XMLCALL
|
---|
805 | xmlFreePropList (xmlAttrPtr cur);
|
---|
806 | XMLPUBFUN void XMLCALL
|
---|
807 | xmlFreeProp (xmlAttrPtr cur);
|
---|
808 | XMLPUBFUN xmlAttrPtr XMLCALL
|
---|
809 | xmlCopyProp (xmlNodePtr target,
|
---|
810 | xmlAttrPtr cur);
|
---|
811 | XMLPUBFUN xmlAttrPtr XMLCALL
|
---|
812 | xmlCopyPropList (xmlNodePtr target,
|
---|
813 | xmlAttrPtr cur);
|
---|
814 | #ifdef LIBXML_TREE_ENABLED
|
---|
815 | XMLPUBFUN xmlDtdPtr XMLCALL
|
---|
816 | xmlCopyDtd (xmlDtdPtr dtd);
|
---|
817 | #endif /* LIBXML_TREE_ENABLED */
|
---|
818 | #if defined(LIBXML_TREE_ENABLED) || defined(LIBXML_SCHEMAS_ENABLED)
|
---|
819 | XMLPUBFUN xmlDocPtr XMLCALL
|
---|
820 | xmlCopyDoc (xmlDocPtr doc,
|
---|
821 | int recursive);
|
---|
822 | #endif /* defined(LIBXML_TREE_ENABLED) || defined(LIBXML_SCHEMAS_ENABLED) */
|
---|
823 | /*
|
---|
824 | * Creating new nodes.
|
---|
825 | */
|
---|
826 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
827 | xmlNewDocNode (xmlDocPtr doc,
|
---|
828 | xmlNsPtr ns,
|
---|
829 | const xmlChar *name,
|
---|
830 | const xmlChar *content);
|
---|
831 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
832 | xmlNewDocNodeEatName (xmlDocPtr doc,
|
---|
833 | xmlNsPtr ns,
|
---|
834 | xmlChar *name,
|
---|
835 | const xmlChar *content);
|
---|
836 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
837 | xmlNewNode (xmlNsPtr ns,
|
---|
838 | const xmlChar *name);
|
---|
839 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
840 | xmlNewNodeEatName (xmlNsPtr ns,
|
---|
841 | xmlChar *name);
|
---|
842 | #if defined(LIBXML_TREE_ENABLED) || defined(LIBXML_SCHEMAS_ENABLED)
|
---|
843 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
844 | xmlNewChild (xmlNodePtr parent,
|
---|
845 | xmlNsPtr ns,
|
---|
846 | const xmlChar *name,
|
---|
847 | const xmlChar *content);
|
---|
848 | #endif
|
---|
849 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
850 | xmlNewDocText (const xmlDoc *doc,
|
---|
851 | const xmlChar *content);
|
---|
852 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
853 | xmlNewText (const xmlChar *content);
|
---|
854 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
855 | xmlNewDocPI (xmlDocPtr doc,
|
---|
856 | const xmlChar *name,
|
---|
857 | const xmlChar *content);
|
---|
858 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
859 | xmlNewPI (const xmlChar *name,
|
---|
860 | const xmlChar *content);
|
---|
861 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
862 | xmlNewDocTextLen (xmlDocPtr doc,
|
---|
863 | const xmlChar *content,
|
---|
864 | int len);
|
---|
865 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
866 | xmlNewTextLen (const xmlChar *content,
|
---|
867 | int len);
|
---|
868 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
869 | xmlNewDocComment (xmlDocPtr doc,
|
---|
870 | const xmlChar *content);
|
---|
871 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
872 | xmlNewComment (const xmlChar *content);
|
---|
873 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
874 | xmlNewCDataBlock (xmlDocPtr doc,
|
---|
875 | const xmlChar *content,
|
---|
876 | int len);
|
---|
877 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
878 | xmlNewCharRef (xmlDocPtr doc,
|
---|
879 | const xmlChar *name);
|
---|
880 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
881 | xmlNewReference (const xmlDoc *doc,
|
---|
882 | const xmlChar *name);
|
---|
883 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
884 | xmlCopyNode (xmlNodePtr node,
|
---|
885 | int recursive);
|
---|
886 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
887 | xmlDocCopyNode (xmlNodePtr node,
|
---|
888 | xmlDocPtr doc,
|
---|
889 | int recursive);
|
---|
890 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
891 | xmlDocCopyNodeList (xmlDocPtr doc,
|
---|
892 | xmlNodePtr node);
|
---|
893 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
894 | xmlCopyNodeList (xmlNodePtr node);
|
---|
895 | #ifdef LIBXML_TREE_ENABLED
|
---|
896 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
897 | xmlNewTextChild (xmlNodePtr parent,
|
---|
898 | xmlNsPtr ns,
|
---|
899 | const xmlChar *name,
|
---|
900 | const xmlChar *content);
|
---|
901 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
902 | xmlNewDocRawNode (xmlDocPtr doc,
|
---|
903 | xmlNsPtr ns,
|
---|
904 | const xmlChar *name,
|
---|
905 | const xmlChar *content);
|
---|
906 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
907 | xmlNewDocFragment (xmlDocPtr doc);
|
---|
908 | #endif /* LIBXML_TREE_ENABLED */
|
---|
909 |
|
---|
910 | /*
|
---|
911 | * Navigating.
|
---|
912 | */
|
---|
913 | XMLPUBFUN long XMLCALL
|
---|
914 | xmlGetLineNo (const xmlNode *node);
|
---|
915 | #if defined(LIBXML_TREE_ENABLED) || defined(LIBXML_DEBUG_ENABLED)
|
---|
916 | XMLPUBFUN xmlChar * XMLCALL
|
---|
917 | xmlGetNodePath (const xmlNode *node);
|
---|
918 | #endif /* defined(LIBXML_TREE_ENABLED) || defined(LIBXML_DEBUG_ENABLED) */
|
---|
919 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
920 | xmlDocGetRootElement (const xmlDoc *doc);
|
---|
921 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
922 | xmlGetLastChild (const xmlNode *parent);
|
---|
923 | XMLPUBFUN int XMLCALL
|
---|
924 | xmlNodeIsText (const xmlNode *node);
|
---|
925 | XMLPUBFUN int XMLCALL
|
---|
926 | xmlIsBlankNode (const xmlNode *node);
|
---|
927 |
|
---|
928 | /*
|
---|
929 | * Changing the structure.
|
---|
930 | */
|
---|
931 | #if defined(LIBXML_TREE_ENABLED) || defined(LIBXML_WRITER_ENABLED)
|
---|
932 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
933 | xmlDocSetRootElement (xmlDocPtr doc,
|
---|
934 | xmlNodePtr root);
|
---|
935 | #endif /* defined(LIBXML_TREE_ENABLED) || defined(LIBXML_WRITER_ENABLED) */
|
---|
936 | #ifdef LIBXML_TREE_ENABLED
|
---|
937 | XMLPUBFUN void XMLCALL
|
---|
938 | xmlNodeSetName (xmlNodePtr cur,
|
---|
939 | const xmlChar *name);
|
---|
940 | #endif /* LIBXML_TREE_ENABLED */
|
---|
941 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
942 | xmlAddChild (xmlNodePtr parent,
|
---|
943 | xmlNodePtr cur);
|
---|
944 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
945 | xmlAddChildList (xmlNodePtr parent,
|
---|
946 | xmlNodePtr cur);
|
---|
947 | #if defined(LIBXML_TREE_ENABLED) || defined(LIBXML_WRITER_ENABLED)
|
---|
948 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
949 | xmlReplaceNode (xmlNodePtr old,
|
---|
950 | xmlNodePtr cur);
|
---|
951 | #endif /* defined(LIBXML_TREE_ENABLED) || defined(LIBXML_WRITER_ENABLED) */
|
---|
952 | #if defined(LIBXML_TREE_ENABLED) || defined(LIBXML_HTML_ENABLED) || \
|
---|
953 | defined(LIBXML_SCHEMAS_ENABLED) || defined(LIBXML_XINCLUDE_ENABLED)
|
---|
954 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
955 | xmlAddPrevSibling (xmlNodePtr cur,
|
---|
956 | xmlNodePtr elem);
|
---|
957 | #endif /* LIBXML_TREE_ENABLED || LIBXML_HTML_ENABLED || LIBXML_SCHEMAS_ENABLED */
|
---|
958 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
959 | xmlAddSibling (xmlNodePtr cur,
|
---|
960 | xmlNodePtr elem);
|
---|
961 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
962 | xmlAddNextSibling (xmlNodePtr cur,
|
---|
963 | xmlNodePtr elem);
|
---|
964 | XMLPUBFUN void XMLCALL
|
---|
965 | xmlUnlinkNode (xmlNodePtr cur);
|
---|
966 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
967 | xmlTextMerge (xmlNodePtr first,
|
---|
968 | xmlNodePtr second);
|
---|
969 | XMLPUBFUN int XMLCALL
|
---|
970 | xmlTextConcat (xmlNodePtr node,
|
---|
971 | const xmlChar *content,
|
---|
972 | int len);
|
---|
973 | XMLPUBFUN void XMLCALL
|
---|
974 | xmlFreeNodeList (xmlNodePtr cur);
|
---|
975 | XMLPUBFUN void XMLCALL
|
---|
976 | xmlFreeNode (xmlNodePtr cur);
|
---|
977 | XMLPUBFUN void XMLCALL
|
---|
978 | xmlSetTreeDoc (xmlNodePtr tree,
|
---|
979 | xmlDocPtr doc);
|
---|
980 | XMLPUBFUN void XMLCALL
|
---|
981 | xmlSetListDoc (xmlNodePtr list,
|
---|
982 | xmlDocPtr doc);
|
---|
983 | /*
|
---|
984 | * Namespaces.
|
---|
985 | */
|
---|
986 | XMLPUBFUN xmlNsPtr XMLCALL
|
---|
987 | xmlSearchNs (xmlDocPtr doc,
|
---|
988 | xmlNodePtr node,
|
---|
989 | const xmlChar *nameSpace);
|
---|
990 | XMLPUBFUN xmlNsPtr XMLCALL
|
---|
991 | xmlSearchNsByHref (xmlDocPtr doc,
|
---|
992 | xmlNodePtr node,
|
---|
993 | const xmlChar *href);
|
---|
994 | #if defined(LIBXML_TREE_ENABLED) || defined(LIBXML_XPATH_ENABLED) || \
|
---|
995 | defined(LIBXML_SCHEMAS_ENABLED)
|
---|
996 | XMLPUBFUN xmlNsPtr * XMLCALL
|
---|
997 | xmlGetNsList (const xmlDoc *doc,
|
---|
998 | const xmlNode *node);
|
---|
999 | #endif /* defined(LIBXML_TREE_ENABLED) || defined(LIBXML_XPATH_ENABLED) */
|
---|
1000 |
|
---|
1001 | XMLPUBFUN void XMLCALL
|
---|
1002 | xmlSetNs (xmlNodePtr node,
|
---|
1003 | xmlNsPtr ns);
|
---|
1004 | XMLPUBFUN xmlNsPtr XMLCALL
|
---|
1005 | xmlCopyNamespace (xmlNsPtr cur);
|
---|
1006 | XMLPUBFUN xmlNsPtr XMLCALL
|
---|
1007 | xmlCopyNamespaceList (xmlNsPtr cur);
|
---|
1008 |
|
---|
1009 | /*
|
---|
1010 | * Changing the content.
|
---|
1011 | */
|
---|
1012 | #if defined(LIBXML_TREE_ENABLED) || defined(LIBXML_XINCLUDE_ENABLED) || \
|
---|
1013 | defined(LIBXML_SCHEMAS_ENABLED) || defined(LIBXML_HTML_ENABLED)
|
---|
1014 | XMLPUBFUN xmlAttrPtr XMLCALL
|
---|
1015 | xmlSetProp (xmlNodePtr node,
|
---|
1016 | const xmlChar *name,
|
---|
1017 | const xmlChar *value);
|
---|
1018 | XMLPUBFUN xmlAttrPtr XMLCALL
|
---|
1019 | xmlSetNsProp (xmlNodePtr node,
|
---|
1020 | xmlNsPtr ns,
|
---|
1021 | const xmlChar *name,
|
---|
1022 | const xmlChar *value);
|
---|
1023 | #endif /* defined(LIBXML_TREE_ENABLED) || defined(LIBXML_XINCLUDE_ENABLED) || \
|
---|
1024 | defined(LIBXML_SCHEMAS_ENABLED) || defined(LIBXML_HTML_ENABLED) */
|
---|
1025 | XMLPUBFUN xmlChar * XMLCALL
|
---|
1026 | xmlGetNoNsProp (const xmlNode *node,
|
---|
1027 | const xmlChar *name);
|
---|
1028 | XMLPUBFUN xmlChar * XMLCALL
|
---|
1029 | xmlGetProp (const xmlNode *node,
|
---|
1030 | const xmlChar *name);
|
---|
1031 | XMLPUBFUN xmlAttrPtr XMLCALL
|
---|
1032 | xmlHasProp (const xmlNode *node,
|
---|
1033 | const xmlChar *name);
|
---|
1034 | XMLPUBFUN xmlAttrPtr XMLCALL
|
---|
1035 | xmlHasNsProp (const xmlNode *node,
|
---|
1036 | const xmlChar *name,
|
---|
1037 | const xmlChar *nameSpace);
|
---|
1038 | XMLPUBFUN xmlChar * XMLCALL
|
---|
1039 | xmlGetNsProp (const xmlNode *node,
|
---|
1040 | const xmlChar *name,
|
---|
1041 | const xmlChar *nameSpace);
|
---|
1042 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
1043 | xmlStringGetNodeList (const xmlDoc *doc,
|
---|
1044 | const xmlChar *value);
|
---|
1045 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
1046 | xmlStringLenGetNodeList (const xmlDoc *doc,
|
---|
1047 | const xmlChar *value,
|
---|
1048 | int len);
|
---|
1049 | XMLPUBFUN xmlChar * XMLCALL
|
---|
1050 | xmlNodeListGetString (xmlDocPtr doc,
|
---|
1051 | const xmlNode *list,
|
---|
1052 | int inLine);
|
---|
1053 | #ifdef LIBXML_TREE_ENABLED
|
---|
1054 | XMLPUBFUN xmlChar * XMLCALL
|
---|
1055 | xmlNodeListGetRawString (const xmlDoc *doc,
|
---|
1056 | const xmlNode *list,
|
---|
1057 | int inLine);
|
---|
1058 | #endif /* LIBXML_TREE_ENABLED */
|
---|
1059 | XMLPUBFUN void XMLCALL
|
---|
1060 | xmlNodeSetContent (xmlNodePtr cur,
|
---|
1061 | const xmlChar *content);
|
---|
1062 | #ifdef LIBXML_TREE_ENABLED
|
---|
1063 | XMLPUBFUN void XMLCALL
|
---|
1064 | xmlNodeSetContentLen (xmlNodePtr cur,
|
---|
1065 | const xmlChar *content,
|
---|
1066 | int len);
|
---|
1067 | #endif /* LIBXML_TREE_ENABLED */
|
---|
1068 | XMLPUBFUN void XMLCALL
|
---|
1069 | xmlNodeAddContent (xmlNodePtr cur,
|
---|
1070 | const xmlChar *content);
|
---|
1071 | XMLPUBFUN void XMLCALL
|
---|
1072 | xmlNodeAddContentLen (xmlNodePtr cur,
|
---|
1073 | const xmlChar *content,
|
---|
1074 | int len);
|
---|
1075 | XMLPUBFUN xmlChar * XMLCALL
|
---|
1076 | xmlNodeGetContent (const xmlNode *cur);
|
---|
1077 |
|
---|
1078 | XMLPUBFUN int XMLCALL
|
---|
1079 | xmlNodeBufGetContent (xmlBufferPtr buffer,
|
---|
1080 | const xmlNode *cur);
|
---|
1081 | XMLPUBFUN int XMLCALL
|
---|
1082 | xmlBufGetNodeContent (xmlBufPtr buf,
|
---|
1083 | const xmlNode *cur);
|
---|
1084 |
|
---|
1085 | XMLPUBFUN xmlChar * XMLCALL
|
---|
1086 | xmlNodeGetLang (const xmlNode *cur);
|
---|
1087 | XMLPUBFUN int XMLCALL
|
---|
1088 | xmlNodeGetSpacePreserve (const xmlNode *cur);
|
---|
1089 | #ifdef LIBXML_TREE_ENABLED
|
---|
1090 | XMLPUBFUN void XMLCALL
|
---|
1091 | xmlNodeSetLang (xmlNodePtr cur,
|
---|
1092 | const xmlChar *lang);
|
---|
1093 | XMLPUBFUN void XMLCALL
|
---|
1094 | xmlNodeSetSpacePreserve (xmlNodePtr cur,
|
---|
1095 | int val);
|
---|
1096 | #endif /* LIBXML_TREE_ENABLED */
|
---|
1097 | XMLPUBFUN xmlChar * XMLCALL
|
---|
1098 | xmlNodeGetBase (const xmlDoc *doc,
|
---|
1099 | const xmlNode *cur);
|
---|
1100 | #if defined(LIBXML_TREE_ENABLED) || defined(LIBXML_XINCLUDE_ENABLED)
|
---|
1101 | XMLPUBFUN void XMLCALL
|
---|
1102 | xmlNodeSetBase (xmlNodePtr cur,
|
---|
1103 | const xmlChar *uri);
|
---|
1104 | #endif
|
---|
1105 |
|
---|
1106 | /*
|
---|
1107 | * Removing content.
|
---|
1108 | */
|
---|
1109 | XMLPUBFUN int XMLCALL
|
---|
1110 | xmlRemoveProp (xmlAttrPtr cur);
|
---|
1111 | #if defined(LIBXML_TREE_ENABLED) || defined(LIBXML_SCHEMAS_ENABLED)
|
---|
1112 | XMLPUBFUN int XMLCALL
|
---|
1113 | xmlUnsetNsProp (xmlNodePtr node,
|
---|
1114 | xmlNsPtr ns,
|
---|
1115 | const xmlChar *name);
|
---|
1116 | XMLPUBFUN int XMLCALL
|
---|
1117 | xmlUnsetProp (xmlNodePtr node,
|
---|
1118 | const xmlChar *name);
|
---|
1119 | #endif /* defined(LIBXML_TREE_ENABLED) || defined(LIBXML_SCHEMAS_ENABLED) */
|
---|
1120 |
|
---|
1121 | /*
|
---|
1122 | * Internal, don't use.
|
---|
1123 | */
|
---|
1124 | XMLPUBFUN void XMLCALL
|
---|
1125 | xmlBufferWriteCHAR (xmlBufferPtr buf,
|
---|
1126 | const xmlChar *string);
|
---|
1127 | XMLPUBFUN void XMLCALL
|
---|
1128 | xmlBufferWriteChar (xmlBufferPtr buf,
|
---|
1129 | const char *string);
|
---|
1130 | XMLPUBFUN void XMLCALL
|
---|
1131 | xmlBufferWriteQuotedString(xmlBufferPtr buf,
|
---|
1132 | const xmlChar *string);
|
---|
1133 |
|
---|
1134 | #ifdef LIBXML_OUTPUT_ENABLED
|
---|
1135 | XMLPUBFUN void xmlAttrSerializeTxtContent(xmlBufferPtr buf,
|
---|
1136 | xmlDocPtr doc,
|
---|
1137 | xmlAttrPtr attr,
|
---|
1138 | const xmlChar *string);
|
---|
1139 | #endif /* LIBXML_OUTPUT_ENABLED */
|
---|
1140 |
|
---|
1141 | #ifdef LIBXML_TREE_ENABLED
|
---|
1142 | /*
|
---|
1143 | * Namespace handling.
|
---|
1144 | */
|
---|
1145 | XMLPUBFUN int XMLCALL
|
---|
1146 | xmlReconciliateNs (xmlDocPtr doc,
|
---|
1147 | xmlNodePtr tree);
|
---|
1148 | #endif
|
---|
1149 |
|
---|
1150 | #ifdef LIBXML_OUTPUT_ENABLED
|
---|
1151 | /*
|
---|
1152 | * Saving.
|
---|
1153 | */
|
---|
1154 | XMLPUBFUN void XMLCALL
|
---|
1155 | xmlDocDumpFormatMemory (xmlDocPtr cur,
|
---|
1156 | xmlChar **mem,
|
---|
1157 | int *size,
|
---|
1158 | int format);
|
---|
1159 | XMLPUBFUN void XMLCALL
|
---|
1160 | xmlDocDumpMemory (xmlDocPtr cur,
|
---|
1161 | xmlChar **mem,
|
---|
1162 | int *size);
|
---|
1163 | XMLPUBFUN void XMLCALL
|
---|
1164 | xmlDocDumpMemoryEnc (xmlDocPtr out_doc,
|
---|
1165 | xmlChar **doc_txt_ptr,
|
---|
1166 | int * doc_txt_len,
|
---|
1167 | const char *txt_encoding);
|
---|
1168 | XMLPUBFUN void XMLCALL
|
---|
1169 | xmlDocDumpFormatMemoryEnc(xmlDocPtr out_doc,
|
---|
1170 | xmlChar **doc_txt_ptr,
|
---|
1171 | int * doc_txt_len,
|
---|
1172 | const char *txt_encoding,
|
---|
1173 | int format);
|
---|
1174 | XMLPUBFUN int XMLCALL
|
---|
1175 | xmlDocFormatDump (FILE *f,
|
---|
1176 | xmlDocPtr cur,
|
---|
1177 | int format);
|
---|
1178 | XMLPUBFUN int XMLCALL
|
---|
1179 | xmlDocDump (FILE *f,
|
---|
1180 | xmlDocPtr cur);
|
---|
1181 | XMLPUBFUN void XMLCALL
|
---|
1182 | xmlElemDump (FILE *f,
|
---|
1183 | xmlDocPtr doc,
|
---|
1184 | xmlNodePtr cur);
|
---|
1185 | XMLPUBFUN int XMLCALL
|
---|
1186 | xmlSaveFile (const char *filename,
|
---|
1187 | xmlDocPtr cur);
|
---|
1188 | XMLPUBFUN int XMLCALL
|
---|
1189 | xmlSaveFormatFile (const char *filename,
|
---|
1190 | xmlDocPtr cur,
|
---|
1191 | int format);
|
---|
1192 | XMLPUBFUN size_t XMLCALL
|
---|
1193 | xmlBufNodeDump (xmlBufPtr buf,
|
---|
1194 | xmlDocPtr doc,
|
---|
1195 | xmlNodePtr cur,
|
---|
1196 | int level,
|
---|
1197 | int format);
|
---|
1198 | XMLPUBFUN int XMLCALL
|
---|
1199 | xmlNodeDump (xmlBufferPtr buf,
|
---|
1200 | xmlDocPtr doc,
|
---|
1201 | xmlNodePtr cur,
|
---|
1202 | int level,
|
---|
1203 | int format);
|
---|
1204 |
|
---|
1205 | XMLPUBFUN int XMLCALL
|
---|
1206 | xmlSaveFileTo (xmlOutputBufferPtr buf,
|
---|
1207 | xmlDocPtr cur,
|
---|
1208 | const char *encoding);
|
---|
1209 | XMLPUBFUN int XMLCALL
|
---|
1210 | xmlSaveFormatFileTo (xmlOutputBufferPtr buf,
|
---|
1211 | xmlDocPtr cur,
|
---|
1212 | const char *encoding,
|
---|
1213 | int format);
|
---|
1214 | XMLPUBFUN void XMLCALL
|
---|
1215 | xmlNodeDumpOutput (xmlOutputBufferPtr buf,
|
---|
1216 | xmlDocPtr doc,
|
---|
1217 | xmlNodePtr cur,
|
---|
1218 | int level,
|
---|
1219 | int format,
|
---|
1220 | const char *encoding);
|
---|
1221 |
|
---|
1222 | XMLPUBFUN int XMLCALL
|
---|
1223 | xmlSaveFormatFileEnc (const char *filename,
|
---|
1224 | xmlDocPtr cur,
|
---|
1225 | const char *encoding,
|
---|
1226 | int format);
|
---|
1227 |
|
---|
1228 | XMLPUBFUN int XMLCALL
|
---|
1229 | xmlSaveFileEnc (const char *filename,
|
---|
1230 | xmlDocPtr cur,
|
---|
1231 | const char *encoding);
|
---|
1232 |
|
---|
1233 | #endif /* LIBXML_OUTPUT_ENABLED */
|
---|
1234 | /*
|
---|
1235 | * XHTML
|
---|
1236 | */
|
---|
1237 | XMLPUBFUN int XMLCALL
|
---|
1238 | xmlIsXHTML (const xmlChar *systemID,
|
---|
1239 | const xmlChar *publicID);
|
---|
1240 |
|
---|
1241 | /*
|
---|
1242 | * Compression.
|
---|
1243 | */
|
---|
1244 | XMLPUBFUN int XMLCALL
|
---|
1245 | xmlGetDocCompressMode (const xmlDoc *doc);
|
---|
1246 | XMLPUBFUN void XMLCALL
|
---|
1247 | xmlSetDocCompressMode (xmlDocPtr doc,
|
---|
1248 | int mode);
|
---|
1249 | XMLPUBFUN int XMLCALL
|
---|
1250 | xmlGetCompressMode (void);
|
---|
1251 | XMLPUBFUN void XMLCALL
|
---|
1252 | xmlSetCompressMode (int mode);
|
---|
1253 |
|
---|
1254 | /*
|
---|
1255 | * DOM-wrapper helper functions.
|
---|
1256 | */
|
---|
1257 | XMLPUBFUN xmlDOMWrapCtxtPtr XMLCALL
|
---|
1258 | xmlDOMWrapNewCtxt (void);
|
---|
1259 | XMLPUBFUN void XMLCALL
|
---|
1260 | xmlDOMWrapFreeCtxt (xmlDOMWrapCtxtPtr ctxt);
|
---|
1261 | XMLPUBFUN int XMLCALL
|
---|
1262 | xmlDOMWrapReconcileNamespaces(xmlDOMWrapCtxtPtr ctxt,
|
---|
1263 | xmlNodePtr elem,
|
---|
1264 | int options);
|
---|
1265 | XMLPUBFUN int XMLCALL
|
---|
1266 | xmlDOMWrapAdoptNode (xmlDOMWrapCtxtPtr ctxt,
|
---|
1267 | xmlDocPtr sourceDoc,
|
---|
1268 | xmlNodePtr node,
|
---|
1269 | xmlDocPtr destDoc,
|
---|
1270 | xmlNodePtr destParent,
|
---|
1271 | int options);
|
---|
1272 | XMLPUBFUN int XMLCALL
|
---|
1273 | xmlDOMWrapRemoveNode (xmlDOMWrapCtxtPtr ctxt,
|
---|
1274 | xmlDocPtr doc,
|
---|
1275 | xmlNodePtr node,
|
---|
1276 | int options);
|
---|
1277 | XMLPUBFUN int XMLCALL
|
---|
1278 | xmlDOMWrapCloneNode (xmlDOMWrapCtxtPtr ctxt,
|
---|
1279 | xmlDocPtr sourceDoc,
|
---|
1280 | xmlNodePtr node,
|
---|
1281 | xmlNodePtr *clonedNode,
|
---|
1282 | xmlDocPtr destDoc,
|
---|
1283 | xmlNodePtr destParent,
|
---|
1284 | int deep,
|
---|
1285 | int options);
|
---|
1286 |
|
---|
1287 | #ifdef LIBXML_TREE_ENABLED
|
---|
1288 | /*
|
---|
1289 | * 5 interfaces from DOM ElementTraversal, but different in entities
|
---|
1290 | * traversal.
|
---|
1291 | */
|
---|
1292 | XMLPUBFUN unsigned long XMLCALL
|
---|
1293 | xmlChildElementCount (xmlNodePtr parent);
|
---|
1294 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
1295 | xmlNextElementSibling (xmlNodePtr node);
|
---|
1296 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
1297 | xmlFirstElementChild (xmlNodePtr parent);
|
---|
1298 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
1299 | xmlLastElementChild (xmlNodePtr parent);
|
---|
1300 | XMLPUBFUN xmlNodePtr XMLCALL
|
---|
1301 | xmlPreviousElementSibling (xmlNodePtr node);
|
---|
1302 | #endif
|
---|
1303 | #ifdef __cplusplus
|
---|
1304 | }
|
---|
1305 | #endif
|
---|
1306 | #ifndef __XML_PARSER_H__
|
---|
1307 | #include <libxml/xmlmemory.h>
|
---|
1308 | #endif
|
---|
1309 |
|
---|
1310 | #endif /* __XML_TREE_H__ */
|
---|
1311 |
|
---|