mirror of https://github.com/axmolengine/axmol.git
Add libxml2 build for Emscripten.
This commit is contained in:
parent
056ff5b5e6
commit
9033dd011e
|
@ -1 +1 @@
|
||||||
5c5788a6ae997dd37a5fc170e3eb60612160e54e
|
a07f9014b2792e1b41b84e6e082ecb0464188ce3
|
|
@ -0,0 +1 @@
|
||||||
|
3479ea8c3cfcd19980319232ae02da5c4ee4fdc6
|
|
@ -0,0 +1,96 @@
|
||||||
|
/*
|
||||||
|
* Summary: old DocBook SGML parser
|
||||||
|
* Description: interface for a DocBook SGML non-verifying parser
|
||||||
|
* This code is DEPRECATED, and should not be used anymore.
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __DOCB_PARSER_H__
|
||||||
|
#define __DOCB_PARSER_H__
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
|
||||||
|
#ifdef LIBXML_DOCB_ENABLED
|
||||||
|
|
||||||
|
#include <libxml/parser.h>
|
||||||
|
#include <libxml/parserInternals.h>
|
||||||
|
|
||||||
|
#ifndef IN_LIBXML
|
||||||
|
#ifdef __GNUC__
|
||||||
|
#warning "The DOCBparser module has been deprecated in libxml2-2.6.0"
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Most of the back-end structures from XML and SGML are shared.
|
||||||
|
*/
|
||||||
|
typedef xmlParserCtxt docbParserCtxt;
|
||||||
|
typedef xmlParserCtxtPtr docbParserCtxtPtr;
|
||||||
|
typedef xmlSAXHandler docbSAXHandler;
|
||||||
|
typedef xmlSAXHandlerPtr docbSAXHandlerPtr;
|
||||||
|
typedef xmlParserInput docbParserInput;
|
||||||
|
typedef xmlParserInputPtr docbParserInputPtr;
|
||||||
|
typedef xmlDocPtr docbDocPtr;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* There is only few public functions.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
docbEncodeEntities(unsigned char *out,
|
||||||
|
int *outlen,
|
||||||
|
const unsigned char *in,
|
||||||
|
int *inlen, int quoteChar);
|
||||||
|
|
||||||
|
XMLPUBFUN docbDocPtr XMLCALL
|
||||||
|
docbSAXParseDoc (xmlChar *cur,
|
||||||
|
const char *encoding,
|
||||||
|
docbSAXHandlerPtr sax,
|
||||||
|
void *userData);
|
||||||
|
XMLPUBFUN docbDocPtr XMLCALL
|
||||||
|
docbParseDoc (xmlChar *cur,
|
||||||
|
const char *encoding);
|
||||||
|
XMLPUBFUN docbDocPtr XMLCALL
|
||||||
|
docbSAXParseFile (const char *filename,
|
||||||
|
const char *encoding,
|
||||||
|
docbSAXHandlerPtr sax,
|
||||||
|
void *userData);
|
||||||
|
XMLPUBFUN docbDocPtr XMLCALL
|
||||||
|
docbParseFile (const char *filename,
|
||||||
|
const char *encoding);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Interfaces for the Push mode.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
docbFreeParserCtxt (docbParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN docbParserCtxtPtr XMLCALL
|
||||||
|
docbCreatePushParserCtxt(docbSAXHandlerPtr sax,
|
||||||
|
void *user_data,
|
||||||
|
const char *chunk,
|
||||||
|
int size,
|
||||||
|
const char *filename,
|
||||||
|
xmlCharEncoding enc);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
docbParseChunk (docbParserCtxtPtr ctxt,
|
||||||
|
const char *chunk,
|
||||||
|
int size,
|
||||||
|
int terminate);
|
||||||
|
XMLPUBFUN docbParserCtxtPtr XMLCALL
|
||||||
|
docbCreateFileParserCtxt(const char *filename,
|
||||||
|
const char *encoding);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
docbParseDocument (docbParserCtxtPtr ctxt);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* LIBXML_DOCB_ENABLED */
|
||||||
|
|
||||||
|
#endif /* __DOCB_PARSER_H__ */
|
|
@ -0,0 +1,305 @@
|
||||||
|
/*
|
||||||
|
* Summary: interface for an HTML 4.0 non-verifying parser
|
||||||
|
* Description: this module implements an HTML 4.0 non-verifying parser
|
||||||
|
* with API compatible with the XML parser ones. It should
|
||||||
|
* be able to parse "real world" HTML, even if severely
|
||||||
|
* broken from a specification point of view.
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __HTML_PARSER_H__
|
||||||
|
#define __HTML_PARSER_H__
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
#include <libxml/parser.h>
|
||||||
|
|
||||||
|
#ifdef LIBXML_HTML_ENABLED
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Most of the back-end structures from XML and HTML are shared.
|
||||||
|
*/
|
||||||
|
typedef xmlParserCtxt htmlParserCtxt;
|
||||||
|
typedef xmlParserCtxtPtr htmlParserCtxtPtr;
|
||||||
|
typedef xmlParserNodeInfo htmlParserNodeInfo;
|
||||||
|
typedef xmlSAXHandler htmlSAXHandler;
|
||||||
|
typedef xmlSAXHandlerPtr htmlSAXHandlerPtr;
|
||||||
|
typedef xmlParserInput htmlParserInput;
|
||||||
|
typedef xmlParserInputPtr htmlParserInputPtr;
|
||||||
|
typedef xmlDocPtr htmlDocPtr;
|
||||||
|
typedef xmlNodePtr htmlNodePtr;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Internal description of an HTML element, representing HTML 4.01
|
||||||
|
* and XHTML 1.0 (which share the same structure).
|
||||||
|
*/
|
||||||
|
typedef struct _htmlElemDesc htmlElemDesc;
|
||||||
|
typedef htmlElemDesc *htmlElemDescPtr;
|
||||||
|
struct _htmlElemDesc {
|
||||||
|
const char *name; /* The tag name */
|
||||||
|
char startTag; /* Whether the start tag can be implied */
|
||||||
|
char endTag; /* Whether the end tag can be implied */
|
||||||
|
char saveEndTag; /* Whether the end tag should be saved */
|
||||||
|
char empty; /* Is this an empty element ? */
|
||||||
|
char depr; /* Is this a deprecated element ? */
|
||||||
|
char dtd; /* 1: only in Loose DTD, 2: only Frameset one */
|
||||||
|
char isinline; /* is this a block 0 or inline 1 element */
|
||||||
|
const char *desc; /* the description */
|
||||||
|
|
||||||
|
/* NRK Jan.2003
|
||||||
|
* New fields encapsulating HTML structure
|
||||||
|
*
|
||||||
|
* Bugs:
|
||||||
|
* This is a very limited representation. It fails to tell us when
|
||||||
|
* an element *requires* subelements (we only have whether they're
|
||||||
|
* allowed or not), and it doesn't tell us where CDATA and PCDATA
|
||||||
|
* are allowed. Some element relationships are not fully represented:
|
||||||
|
* these are flagged with the word MODIFIER
|
||||||
|
*/
|
||||||
|
const char** subelts; /* allowed sub-elements of this element */
|
||||||
|
const char* defaultsubelt; /* subelement for suggested auto-repair
|
||||||
|
if necessary or NULL */
|
||||||
|
const char** attrs_opt; /* Optional Attributes */
|
||||||
|
const char** attrs_depr; /* Additional deprecated attributes */
|
||||||
|
const char** attrs_req; /* Required attributes */
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Internal description of an HTML entity.
|
||||||
|
*/
|
||||||
|
typedef struct _htmlEntityDesc htmlEntityDesc;
|
||||||
|
typedef htmlEntityDesc *htmlEntityDescPtr;
|
||||||
|
struct _htmlEntityDesc {
|
||||||
|
unsigned int value; /* the UNICODE value for the character */
|
||||||
|
const char *name; /* The entity name */
|
||||||
|
const char *desc; /* the description */
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* There is only few public functions.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN const htmlElemDesc * XMLCALL
|
||||||
|
htmlTagLookup (const xmlChar *tag);
|
||||||
|
XMLPUBFUN const htmlEntityDesc * XMLCALL
|
||||||
|
htmlEntityLookup(const xmlChar *name);
|
||||||
|
XMLPUBFUN const htmlEntityDesc * XMLCALL
|
||||||
|
htmlEntityValueLookup(unsigned int value);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
htmlIsAutoClosed(htmlDocPtr doc,
|
||||||
|
htmlNodePtr elem);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
htmlAutoCloseTag(htmlDocPtr doc,
|
||||||
|
const xmlChar *name,
|
||||||
|
htmlNodePtr elem);
|
||||||
|
XMLPUBFUN const htmlEntityDesc * XMLCALL
|
||||||
|
htmlParseEntityRef(htmlParserCtxtPtr ctxt,
|
||||||
|
const xmlChar **str);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
htmlParseCharRef(htmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
htmlParseElement(htmlParserCtxtPtr ctxt);
|
||||||
|
|
||||||
|
XMLPUBFUN htmlParserCtxtPtr XMLCALL
|
||||||
|
htmlNewParserCtxt(void);
|
||||||
|
|
||||||
|
XMLPUBFUN htmlParserCtxtPtr XMLCALL
|
||||||
|
htmlCreateMemoryParserCtxt(const char *buffer,
|
||||||
|
int size);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
htmlParseDocument(htmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN htmlDocPtr XMLCALL
|
||||||
|
htmlSAXParseDoc (xmlChar *cur,
|
||||||
|
const char *encoding,
|
||||||
|
htmlSAXHandlerPtr sax,
|
||||||
|
void *userData);
|
||||||
|
XMLPUBFUN htmlDocPtr XMLCALL
|
||||||
|
htmlParseDoc (xmlChar *cur,
|
||||||
|
const char *encoding);
|
||||||
|
XMLPUBFUN htmlDocPtr XMLCALL
|
||||||
|
htmlSAXParseFile(const char *filename,
|
||||||
|
const char *encoding,
|
||||||
|
htmlSAXHandlerPtr sax,
|
||||||
|
void *userData);
|
||||||
|
XMLPUBFUN htmlDocPtr XMLCALL
|
||||||
|
htmlParseFile (const char *filename,
|
||||||
|
const char *encoding);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
UTF8ToHtml (unsigned char *out,
|
||||||
|
int *outlen,
|
||||||
|
const unsigned char *in,
|
||||||
|
int *inlen);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
htmlEncodeEntities(unsigned char *out,
|
||||||
|
int *outlen,
|
||||||
|
const unsigned char *in,
|
||||||
|
int *inlen, int quoteChar);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
htmlIsScriptAttribute(const xmlChar *name);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
htmlHandleOmittedElem(int val);
|
||||||
|
|
||||||
|
#ifdef LIBXML_PUSH_ENABLED
|
||||||
|
/**
|
||||||
|
* Interfaces for the Push mode.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN htmlParserCtxtPtr XMLCALL
|
||||||
|
htmlCreatePushParserCtxt(htmlSAXHandlerPtr sax,
|
||||||
|
void *user_data,
|
||||||
|
const char *chunk,
|
||||||
|
int size,
|
||||||
|
const char *filename,
|
||||||
|
xmlCharEncoding enc);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
htmlParseChunk (htmlParserCtxtPtr ctxt,
|
||||||
|
const char *chunk,
|
||||||
|
int size,
|
||||||
|
int terminate);
|
||||||
|
#endif /* LIBXML_PUSH_ENABLED */
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
htmlFreeParserCtxt (htmlParserCtxtPtr ctxt);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* New set of simpler/more flexible APIs
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* xmlParserOption:
|
||||||
|
*
|
||||||
|
* This is the set of XML parser options that can be passed down
|
||||||
|
* to the xmlReadDoc() and similar calls.
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
HTML_PARSE_RECOVER = 1<<0, /* Relaxed parsing */
|
||||||
|
HTML_PARSE_NODEFDTD = 1<<2, /* do not default a doctype if not found */
|
||||||
|
HTML_PARSE_NOERROR = 1<<5, /* suppress error reports */
|
||||||
|
HTML_PARSE_NOWARNING= 1<<6, /* suppress warning reports */
|
||||||
|
HTML_PARSE_PEDANTIC = 1<<7, /* pedantic error reporting */
|
||||||
|
HTML_PARSE_NOBLANKS = 1<<8, /* remove blank nodes */
|
||||||
|
HTML_PARSE_NONET = 1<<11,/* Forbid network access */
|
||||||
|
HTML_PARSE_NOIMPLIED= 1<<13,/* Do not add implied html/body... elements */
|
||||||
|
HTML_PARSE_COMPACT = 1<<16 /* compact small text nodes */
|
||||||
|
} htmlParserOption;
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
htmlCtxtReset (htmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
htmlCtxtUseOptions (htmlParserCtxtPtr ctxt,
|
||||||
|
int options);
|
||||||
|
XMLPUBFUN htmlDocPtr XMLCALL
|
||||||
|
htmlReadDoc (const xmlChar *cur,
|
||||||
|
const char *URL,
|
||||||
|
const char *encoding,
|
||||||
|
int options);
|
||||||
|
XMLPUBFUN htmlDocPtr XMLCALL
|
||||||
|
htmlReadFile (const char *URL,
|
||||||
|
const char *encoding,
|
||||||
|
int options);
|
||||||
|
XMLPUBFUN htmlDocPtr XMLCALL
|
||||||
|
htmlReadMemory (const char *buffer,
|
||||||
|
int size,
|
||||||
|
const char *URL,
|
||||||
|
const char *encoding,
|
||||||
|
int options);
|
||||||
|
XMLPUBFUN htmlDocPtr XMLCALL
|
||||||
|
htmlReadFd (int fd,
|
||||||
|
const char *URL,
|
||||||
|
const char *encoding,
|
||||||
|
int options);
|
||||||
|
XMLPUBFUN htmlDocPtr XMLCALL
|
||||||
|
htmlReadIO (xmlInputReadCallback ioread,
|
||||||
|
xmlInputCloseCallback ioclose,
|
||||||
|
void *ioctx,
|
||||||
|
const char *URL,
|
||||||
|
const char *encoding,
|
||||||
|
int options);
|
||||||
|
XMLPUBFUN htmlDocPtr XMLCALL
|
||||||
|
htmlCtxtReadDoc (xmlParserCtxtPtr ctxt,
|
||||||
|
const xmlChar *cur,
|
||||||
|
const char *URL,
|
||||||
|
const char *encoding,
|
||||||
|
int options);
|
||||||
|
XMLPUBFUN htmlDocPtr XMLCALL
|
||||||
|
htmlCtxtReadFile (xmlParserCtxtPtr ctxt,
|
||||||
|
const char *filename,
|
||||||
|
const char *encoding,
|
||||||
|
int options);
|
||||||
|
XMLPUBFUN htmlDocPtr XMLCALL
|
||||||
|
htmlCtxtReadMemory (xmlParserCtxtPtr ctxt,
|
||||||
|
const char *buffer,
|
||||||
|
int size,
|
||||||
|
const char *URL,
|
||||||
|
const char *encoding,
|
||||||
|
int options);
|
||||||
|
XMLPUBFUN htmlDocPtr XMLCALL
|
||||||
|
htmlCtxtReadFd (xmlParserCtxtPtr ctxt,
|
||||||
|
int fd,
|
||||||
|
const char *URL,
|
||||||
|
const char *encoding,
|
||||||
|
int options);
|
||||||
|
XMLPUBFUN htmlDocPtr XMLCALL
|
||||||
|
htmlCtxtReadIO (xmlParserCtxtPtr ctxt,
|
||||||
|
xmlInputReadCallback ioread,
|
||||||
|
xmlInputCloseCallback ioclose,
|
||||||
|
void *ioctx,
|
||||||
|
const char *URL,
|
||||||
|
const char *encoding,
|
||||||
|
int options);
|
||||||
|
|
||||||
|
/* NRK/Jan2003: further knowledge of HTML structure
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
HTML_NA = 0 , /* something we don't check at all */
|
||||||
|
HTML_INVALID = 0x1 ,
|
||||||
|
HTML_DEPRECATED = 0x2 ,
|
||||||
|
HTML_VALID = 0x4 ,
|
||||||
|
HTML_REQUIRED = 0xc /* VALID bit set so ( & HTML_VALID ) is TRUE */
|
||||||
|
} htmlStatus ;
|
||||||
|
|
||||||
|
/* Using htmlElemDesc rather than name here, to emphasise the fact
|
||||||
|
that otherwise there's a lookup overhead
|
||||||
|
*/
|
||||||
|
XMLPUBFUN htmlStatus XMLCALL htmlAttrAllowed(const htmlElemDesc*, const xmlChar*, int) ;
|
||||||
|
XMLPUBFUN int XMLCALL htmlElementAllowedHere(const htmlElemDesc*, const xmlChar*) ;
|
||||||
|
XMLPUBFUN htmlStatus XMLCALL htmlElementStatusHere(const htmlElemDesc*, const htmlElemDesc*) ;
|
||||||
|
XMLPUBFUN htmlStatus XMLCALL htmlNodeStatus(const htmlNodePtr, int) ;
|
||||||
|
/**
|
||||||
|
* htmlDefaultSubelement:
|
||||||
|
* @elt: HTML element
|
||||||
|
*
|
||||||
|
* Returns the default subelement for this element
|
||||||
|
*/
|
||||||
|
#define htmlDefaultSubelement(elt) elt->defaultsubelt
|
||||||
|
/**
|
||||||
|
* htmlElementAllowedHereDesc:
|
||||||
|
* @parent: HTML parent element
|
||||||
|
* @elt: HTML element
|
||||||
|
*
|
||||||
|
* Checks whether an HTML element description may be a
|
||||||
|
* direct child of the specified element.
|
||||||
|
*
|
||||||
|
* Returns 1 if allowed; 0 otherwise.
|
||||||
|
*/
|
||||||
|
#define htmlElementAllowedHereDesc(parent,elt) \
|
||||||
|
htmlElementAllowedHere((parent), (elt)->name)
|
||||||
|
/**
|
||||||
|
* htmlRequiredAttrs:
|
||||||
|
* @elt: HTML element
|
||||||
|
*
|
||||||
|
* Returns the attributes required for the specified element.
|
||||||
|
*/
|
||||||
|
#define htmlRequiredAttrs(elt) (elt)->attrs_req
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* LIBXML_HTML_ENABLED */
|
||||||
|
#endif /* __HTML_PARSER_H__ */
|
|
@ -0,0 +1,147 @@
|
||||||
|
/*
|
||||||
|
* Summary: specific APIs to process HTML tree, especially serialization
|
||||||
|
* Description: this module implements a few function needed to process
|
||||||
|
* tree in an HTML specific way.
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __HTML_TREE_H__
|
||||||
|
#define __HTML_TREE_H__
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
#include <libxml/tree.h>
|
||||||
|
#include <libxml/HTMLparser.h>
|
||||||
|
|
||||||
|
#ifdef LIBXML_HTML_ENABLED
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* HTML_TEXT_NODE:
|
||||||
|
*
|
||||||
|
* Macro. A text node in a HTML document is really implemented
|
||||||
|
* the same way as a text node in an XML document.
|
||||||
|
*/
|
||||||
|
#define HTML_TEXT_NODE XML_TEXT_NODE
|
||||||
|
/**
|
||||||
|
* HTML_ENTITY_REF_NODE:
|
||||||
|
*
|
||||||
|
* Macro. An entity reference in a HTML document is really implemented
|
||||||
|
* the same way as an entity reference in an XML document.
|
||||||
|
*/
|
||||||
|
#define HTML_ENTITY_REF_NODE XML_ENTITY_REF_NODE
|
||||||
|
/**
|
||||||
|
* HTML_COMMENT_NODE:
|
||||||
|
*
|
||||||
|
* Macro. A comment in a HTML document is really implemented
|
||||||
|
* the same way as a comment in an XML document.
|
||||||
|
*/
|
||||||
|
#define HTML_COMMENT_NODE XML_COMMENT_NODE
|
||||||
|
/**
|
||||||
|
* HTML_PRESERVE_NODE:
|
||||||
|
*
|
||||||
|
* Macro. A preserved node in a HTML document is really implemented
|
||||||
|
* the same way as a CDATA section in an XML document.
|
||||||
|
*/
|
||||||
|
#define HTML_PRESERVE_NODE XML_CDATA_SECTION_NODE
|
||||||
|
/**
|
||||||
|
* HTML_PI_NODE:
|
||||||
|
*
|
||||||
|
* Macro. A processing instruction in a HTML document is really implemented
|
||||||
|
* the same way as a processing instruction in an XML document.
|
||||||
|
*/
|
||||||
|
#define HTML_PI_NODE XML_PI_NODE
|
||||||
|
|
||||||
|
XMLPUBFUN htmlDocPtr XMLCALL
|
||||||
|
htmlNewDoc (const xmlChar *URI,
|
||||||
|
const xmlChar *ExternalID);
|
||||||
|
XMLPUBFUN htmlDocPtr XMLCALL
|
||||||
|
htmlNewDocNoDtD (const xmlChar *URI,
|
||||||
|
const xmlChar *ExternalID);
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
htmlGetMetaEncoding (htmlDocPtr doc);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
htmlSetMetaEncoding (htmlDocPtr doc,
|
||||||
|
const xmlChar *encoding);
|
||||||
|
#ifdef LIBXML_OUTPUT_ENABLED
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
htmlDocDumpMemory (xmlDocPtr cur,
|
||||||
|
xmlChar **mem,
|
||||||
|
int *size);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
htmlDocDumpMemoryFormat (xmlDocPtr cur,
|
||||||
|
xmlChar **mem,
|
||||||
|
int *size,
|
||||||
|
int format);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
htmlDocDump (FILE *f,
|
||||||
|
xmlDocPtr cur);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
htmlSaveFile (const char *filename,
|
||||||
|
xmlDocPtr cur);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
htmlNodeDump (xmlBufferPtr buf,
|
||||||
|
xmlDocPtr doc,
|
||||||
|
xmlNodePtr cur);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
htmlNodeDumpFile (FILE *out,
|
||||||
|
xmlDocPtr doc,
|
||||||
|
xmlNodePtr cur);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
htmlNodeDumpFileFormat (FILE *out,
|
||||||
|
xmlDocPtr doc,
|
||||||
|
xmlNodePtr cur,
|
||||||
|
const char *encoding,
|
||||||
|
int format);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
htmlSaveFileEnc (const char *filename,
|
||||||
|
xmlDocPtr cur,
|
||||||
|
const char *encoding);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
htmlSaveFileFormat (const char *filename,
|
||||||
|
xmlDocPtr cur,
|
||||||
|
const char *encoding,
|
||||||
|
int format);
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
htmlNodeDumpFormatOutput(xmlOutputBufferPtr buf,
|
||||||
|
xmlDocPtr doc,
|
||||||
|
xmlNodePtr cur,
|
||||||
|
const char *encoding,
|
||||||
|
int format);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
htmlDocContentDumpOutput(xmlOutputBufferPtr buf,
|
||||||
|
xmlDocPtr cur,
|
||||||
|
const char *encoding);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
htmlDocContentDumpFormatOutput(xmlOutputBufferPtr buf,
|
||||||
|
xmlDocPtr cur,
|
||||||
|
const char *encoding,
|
||||||
|
int format);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
htmlNodeDumpOutput (xmlOutputBufferPtr buf,
|
||||||
|
xmlDocPtr doc,
|
||||||
|
xmlNodePtr cur,
|
||||||
|
const char *encoding);
|
||||||
|
|
||||||
|
#endif /* LIBXML_OUTPUT_ENABLED */
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
htmlIsBooleanAttr (const xmlChar *name);
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* LIBXML_HTML_ENABLED */
|
||||||
|
|
||||||
|
#endif /* __HTML_TREE_H__ */
|
||||||
|
|
|
@ -0,0 +1,173 @@
|
||||||
|
/*
|
||||||
|
* Summary: Old SAX version 1 handler, deprecated
|
||||||
|
* Description: DEPRECATED set of SAX version 1 interfaces used to
|
||||||
|
* build the DOM tree.
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef __XML_SAX_H__
|
||||||
|
#define __XML_SAX_H__
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
#include <libxml/parser.h>
|
||||||
|
#include <libxml/xlink.h>
|
||||||
|
|
||||||
|
#ifdef LIBXML_LEGACY_ENABLED
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
getPublicId (void *ctx);
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
getSystemId (void *ctx);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
setDocumentLocator (void *ctx,
|
||||||
|
xmlSAXLocatorPtr loc);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
getLineNumber (void *ctx);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
getColumnNumber (void *ctx);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
isStandalone (void *ctx);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
hasInternalSubset (void *ctx);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
hasExternalSubset (void *ctx);
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
internalSubset (void *ctx,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *ExternalID,
|
||||||
|
const xmlChar *SystemID);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
externalSubset (void *ctx,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *ExternalID,
|
||||||
|
const xmlChar *SystemID);
|
||||||
|
XMLPUBFUN xmlEntityPtr XMLCALL
|
||||||
|
getEntity (void *ctx,
|
||||||
|
const xmlChar *name);
|
||||||
|
XMLPUBFUN xmlEntityPtr XMLCALL
|
||||||
|
getParameterEntity (void *ctx,
|
||||||
|
const xmlChar *name);
|
||||||
|
XMLPUBFUN xmlParserInputPtr XMLCALL
|
||||||
|
resolveEntity (void *ctx,
|
||||||
|
const xmlChar *publicId,
|
||||||
|
const xmlChar *systemId);
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
entityDecl (void *ctx,
|
||||||
|
const xmlChar *name,
|
||||||
|
int type,
|
||||||
|
const xmlChar *publicId,
|
||||||
|
const xmlChar *systemId,
|
||||||
|
xmlChar *content);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
attributeDecl (void *ctx,
|
||||||
|
const xmlChar *elem,
|
||||||
|
const xmlChar *fullname,
|
||||||
|
int type,
|
||||||
|
int def,
|
||||||
|
const xmlChar *defaultValue,
|
||||||
|
xmlEnumerationPtr tree);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
elementDecl (void *ctx,
|
||||||
|
const xmlChar *name,
|
||||||
|
int type,
|
||||||
|
xmlElementContentPtr content);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
notationDecl (void *ctx,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *publicId,
|
||||||
|
const xmlChar *systemId);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
unparsedEntityDecl (void *ctx,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *publicId,
|
||||||
|
const xmlChar *systemId,
|
||||||
|
const xmlChar *notationName);
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
startDocument (void *ctx);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
endDocument (void *ctx);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
attribute (void *ctx,
|
||||||
|
const xmlChar *fullname,
|
||||||
|
const xmlChar *value);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
startElement (void *ctx,
|
||||||
|
const xmlChar *fullname,
|
||||||
|
const xmlChar **atts);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
endElement (void *ctx,
|
||||||
|
const xmlChar *name);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
reference (void *ctx,
|
||||||
|
const xmlChar *name);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
characters (void *ctx,
|
||||||
|
const xmlChar *ch,
|
||||||
|
int len);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
ignorableWhitespace (void *ctx,
|
||||||
|
const xmlChar *ch,
|
||||||
|
int len);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
processingInstruction (void *ctx,
|
||||||
|
const xmlChar *target,
|
||||||
|
const xmlChar *data);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
globalNamespace (void *ctx,
|
||||||
|
const xmlChar *href,
|
||||||
|
const xmlChar *prefix);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
setNamespace (void *ctx,
|
||||||
|
const xmlChar *name);
|
||||||
|
XMLPUBFUN xmlNsPtr XMLCALL
|
||||||
|
getNamespace (void *ctx);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
checkNamespace (void *ctx,
|
||||||
|
xmlChar *nameSpace);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
namespaceDecl (void *ctx,
|
||||||
|
const xmlChar *href,
|
||||||
|
const xmlChar *prefix);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
comment (void *ctx,
|
||||||
|
const xmlChar *value);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
cdataBlock (void *ctx,
|
||||||
|
const xmlChar *value,
|
||||||
|
int len);
|
||||||
|
|
||||||
|
#ifdef LIBXML_SAX1_ENABLED
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
initxmlDefaultSAXHandler (xmlSAXHandlerV1 *hdlr,
|
||||||
|
int warning);
|
||||||
|
#ifdef LIBXML_HTML_ENABLED
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
inithtmlDefaultSAXHandler (xmlSAXHandlerV1 *hdlr);
|
||||||
|
#endif
|
||||||
|
#ifdef LIBXML_DOCB_ENABLED
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
initdocbDefaultSAXHandler (xmlSAXHandlerV1 *hdlr);
|
||||||
|
#endif
|
||||||
|
#endif /* LIBXML_SAX1_ENABLED */
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* LIBXML_LEGACY_ENABLED */
|
||||||
|
|
||||||
|
#endif /* __XML_SAX_H__ */
|
|
@ -0,0 +1,176 @@
|
||||||
|
/*
|
||||||
|
* Summary: SAX2 parser interface used to build the DOM tree
|
||||||
|
* Description: those are the default SAX2 interfaces used by
|
||||||
|
* the library when building DOM tree.
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef __XML_SAX2_H__
|
||||||
|
#define __XML_SAX2_H__
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
#include <libxml/parser.h>
|
||||||
|
#include <libxml/xlink.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlSAX2GetPublicId (void *ctx);
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlSAX2GetSystemId (void *ctx);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSAX2SetDocumentLocator (void *ctx,
|
||||||
|
xmlSAXLocatorPtr loc);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSAX2GetLineNumber (void *ctx);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSAX2GetColumnNumber (void *ctx);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSAX2IsStandalone (void *ctx);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSAX2HasInternalSubset (void *ctx);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSAX2HasExternalSubset (void *ctx);
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSAX2InternalSubset (void *ctx,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *ExternalID,
|
||||||
|
const xmlChar *SystemID);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSAX2ExternalSubset (void *ctx,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *ExternalID,
|
||||||
|
const xmlChar *SystemID);
|
||||||
|
XMLPUBFUN xmlEntityPtr XMLCALL
|
||||||
|
xmlSAX2GetEntity (void *ctx,
|
||||||
|
const xmlChar *name);
|
||||||
|
XMLPUBFUN xmlEntityPtr XMLCALL
|
||||||
|
xmlSAX2GetParameterEntity (void *ctx,
|
||||||
|
const xmlChar *name);
|
||||||
|
XMLPUBFUN xmlParserInputPtr XMLCALL
|
||||||
|
xmlSAX2ResolveEntity (void *ctx,
|
||||||
|
const xmlChar *publicId,
|
||||||
|
const xmlChar *systemId);
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSAX2EntityDecl (void *ctx,
|
||||||
|
const xmlChar *name,
|
||||||
|
int type,
|
||||||
|
const xmlChar *publicId,
|
||||||
|
const xmlChar *systemId,
|
||||||
|
xmlChar *content);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSAX2AttributeDecl (void *ctx,
|
||||||
|
const xmlChar *elem,
|
||||||
|
const xmlChar *fullname,
|
||||||
|
int type,
|
||||||
|
int def,
|
||||||
|
const xmlChar *defaultValue,
|
||||||
|
xmlEnumerationPtr tree);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSAX2ElementDecl (void *ctx,
|
||||||
|
const xmlChar *name,
|
||||||
|
int type,
|
||||||
|
xmlElementContentPtr content);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSAX2NotationDecl (void *ctx,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *publicId,
|
||||||
|
const xmlChar *systemId);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSAX2UnparsedEntityDecl (void *ctx,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *publicId,
|
||||||
|
const xmlChar *systemId,
|
||||||
|
const xmlChar *notationName);
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSAX2StartDocument (void *ctx);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSAX2EndDocument (void *ctx);
|
||||||
|
#if defined(LIBXML_SAX1_ENABLED) || defined(LIBXML_HTML_ENABLED) || defined(LIBXML_WRITER_ENABLED) || defined(LIBXML_DOCB_ENABLED)
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSAX2StartElement (void *ctx,
|
||||||
|
const xmlChar *fullname,
|
||||||
|
const xmlChar **atts);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSAX2EndElement (void *ctx,
|
||||||
|
const xmlChar *name);
|
||||||
|
#endif /* LIBXML_SAX1_ENABLED or LIBXML_HTML_ENABLED */
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSAX2StartElementNs (void *ctx,
|
||||||
|
const xmlChar *localname,
|
||||||
|
const xmlChar *prefix,
|
||||||
|
const xmlChar *URI,
|
||||||
|
int nb_namespaces,
|
||||||
|
const xmlChar **namespaces,
|
||||||
|
int nb_attributes,
|
||||||
|
int nb_defaulted,
|
||||||
|
const xmlChar **attributes);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSAX2EndElementNs (void *ctx,
|
||||||
|
const xmlChar *localname,
|
||||||
|
const xmlChar *prefix,
|
||||||
|
const xmlChar *URI);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSAX2Reference (void *ctx,
|
||||||
|
const xmlChar *name);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSAX2Characters (void *ctx,
|
||||||
|
const xmlChar *ch,
|
||||||
|
int len);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSAX2IgnorableWhitespace (void *ctx,
|
||||||
|
const xmlChar *ch,
|
||||||
|
int len);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSAX2ProcessingInstruction (void *ctx,
|
||||||
|
const xmlChar *target,
|
||||||
|
const xmlChar *data);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSAX2Comment (void *ctx,
|
||||||
|
const xmlChar *value);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSAX2CDataBlock (void *ctx,
|
||||||
|
const xmlChar *value,
|
||||||
|
int len);
|
||||||
|
|
||||||
|
#ifdef LIBXML_SAX1_ENABLED
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSAXDefaultVersion (int version);
|
||||||
|
#endif /* LIBXML_SAX1_ENABLED */
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSAXVersion (xmlSAXHandler *hdlr,
|
||||||
|
int version);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSAX2InitDefaultSAXHandler (xmlSAXHandler *hdlr,
|
||||||
|
int warning);
|
||||||
|
#ifdef LIBXML_HTML_ENABLED
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSAX2InitHtmlDefaultSAXHandler(xmlSAXHandler *hdlr);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
htmlDefaultSAXHandlerInit (void);
|
||||||
|
#endif
|
||||||
|
#ifdef LIBXML_DOCB_ENABLED
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSAX2InitDocbDefaultSAXHandler(xmlSAXHandler *hdlr);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
docbDefaultSAXHandlerInit (void);
|
||||||
|
#endif
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlDefaultSAXHandlerInit (void);
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif /* __XML_SAX2_H__ */
|
|
@ -0,0 +1,126 @@
|
||||||
|
/*
|
||||||
|
* Summary: Provide Canonical XML and Exclusive XML Canonicalization
|
||||||
|
* Description: the c14n modules provides a
|
||||||
|
*
|
||||||
|
* "Canonical XML" implementation
|
||||||
|
* http://www.w3.org/TR/xml-c14n
|
||||||
|
*
|
||||||
|
* and an
|
||||||
|
*
|
||||||
|
* "Exclusive XML Canonicalization" implementation
|
||||||
|
* http://www.w3.org/TR/xml-exc-c14n
|
||||||
|
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Aleksey Sanin <aleksey@aleksey.com>
|
||||||
|
*/
|
||||||
|
#ifndef __XML_C14N_H__
|
||||||
|
#define __XML_C14N_H__
|
||||||
|
#ifdef LIBXML_C14N_ENABLED
|
||||||
|
#ifdef LIBXML_OUTPUT_ENABLED
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif /* __cplusplus */
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
#include <libxml/tree.h>
|
||||||
|
#include <libxml/xpath.h>
|
||||||
|
|
||||||
|
/*
|
||||||
|
* XML Canonicazation
|
||||||
|
* http://www.w3.org/TR/xml-c14n
|
||||||
|
*
|
||||||
|
* Exclusive XML Canonicazation
|
||||||
|
* http://www.w3.org/TR/xml-exc-c14n
|
||||||
|
*
|
||||||
|
* Canonical form of an XML document could be created if and only if
|
||||||
|
* a) default attributes (if any) are added to all nodes
|
||||||
|
* b) all character and parsed entity references are resolved
|
||||||
|
* In order to achive this in libxml2 the document MUST be loaded with
|
||||||
|
* following global setings:
|
||||||
|
*
|
||||||
|
* xmlLoadExtDtdDefaultValue = XML_DETECT_IDS | XML_COMPLETE_ATTRS;
|
||||||
|
* xmlSubstituteEntitiesDefault(1);
|
||||||
|
*
|
||||||
|
* or corresponding parser context setting:
|
||||||
|
* xmlParserCtxtPtr ctxt;
|
||||||
|
*
|
||||||
|
* ...
|
||||||
|
* ctxt->loadsubset = XML_DETECT_IDS | XML_COMPLETE_ATTRS;
|
||||||
|
* ctxt->replaceEntities = 1;
|
||||||
|
* ...
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* xmlC14NMode:
|
||||||
|
*
|
||||||
|
* Predefined values for C14N modes
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
XML_C14N_1_0 = 0, /* Origianal C14N 1.0 spec */
|
||||||
|
XML_C14N_EXCLUSIVE_1_0 = 1, /* Exclusive C14N 1.0 spec */
|
||||||
|
XML_C14N_1_1 = 2 /* C14N 1.1 spec */
|
||||||
|
} xmlC14NMode;
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlC14NDocSaveTo (xmlDocPtr doc,
|
||||||
|
xmlNodeSetPtr nodes,
|
||||||
|
int mode, /* a xmlC14NMode */
|
||||||
|
xmlChar **inclusive_ns_prefixes,
|
||||||
|
int with_comments,
|
||||||
|
xmlOutputBufferPtr buf);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlC14NDocDumpMemory (xmlDocPtr doc,
|
||||||
|
xmlNodeSetPtr nodes,
|
||||||
|
int mode, /* a xmlC14NMode */
|
||||||
|
xmlChar **inclusive_ns_prefixes,
|
||||||
|
int with_comments,
|
||||||
|
xmlChar **doc_txt_ptr);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlC14NDocSave (xmlDocPtr doc,
|
||||||
|
xmlNodeSetPtr nodes,
|
||||||
|
int mode, /* a xmlC14NMode */
|
||||||
|
xmlChar **inclusive_ns_prefixes,
|
||||||
|
int with_comments,
|
||||||
|
const char* filename,
|
||||||
|
int compression);
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This is the core C14N function
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* xmlC14NIsVisibleCallback:
|
||||||
|
* @user_data: user data
|
||||||
|
* @node: the curent node
|
||||||
|
* @parent: the parent node
|
||||||
|
*
|
||||||
|
* Signature for a C14N callback on visible nodes
|
||||||
|
*
|
||||||
|
* Returns 1 if the node should be included
|
||||||
|
*/
|
||||||
|
typedef int (*xmlC14NIsVisibleCallback) (void* user_data,
|
||||||
|
xmlNodePtr node,
|
||||||
|
xmlNodePtr parent);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlC14NExecute (xmlDocPtr doc,
|
||||||
|
xmlC14NIsVisibleCallback is_visible_callback,
|
||||||
|
void* user_data,
|
||||||
|
int mode, /* a xmlC14NMode */
|
||||||
|
xmlChar **inclusive_ns_prefixes,
|
||||||
|
int with_comments,
|
||||||
|
xmlOutputBufferPtr buf);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif /* __cplusplus */
|
||||||
|
|
||||||
|
#endif /* LIBXML_OUTPUT_ENABLED */
|
||||||
|
#endif /* LIBXML_C14N_ENABLED */
|
||||||
|
#endif /* __XML_C14N_H__ */
|
||||||
|
|
|
@ -0,0 +1,182 @@
|
||||||
|
/**
|
||||||
|
* Summary: interfaces to the Catalog handling system
|
||||||
|
* Description: the catalog module implements the support for
|
||||||
|
* XML Catalogs and SGML catalogs
|
||||||
|
*
|
||||||
|
* SGML Open Technical Resolution TR9401:1997.
|
||||||
|
* http://www.jclark.com/sp/catalog.htm
|
||||||
|
*
|
||||||
|
* XML Catalogs Working Draft 06 August 2001
|
||||||
|
* http://www.oasis-open.org/committees/entity/spec-2001-08-06.html
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_CATALOG_H__
|
||||||
|
#define __XML_CATALOG_H__
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
#include <libxml/xmlstring.h>
|
||||||
|
#include <libxml/tree.h>
|
||||||
|
|
||||||
|
#ifdef LIBXML_CATALOG_ENABLED
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* XML_CATALOGS_NAMESPACE:
|
||||||
|
*
|
||||||
|
* The namespace for the XML Catalogs elements.
|
||||||
|
*/
|
||||||
|
#define XML_CATALOGS_NAMESPACE \
|
||||||
|
(const xmlChar *) "urn:oasis:names:tc:entity:xmlns:xml:catalog"
|
||||||
|
/**
|
||||||
|
* XML_CATALOG_PI:
|
||||||
|
*
|
||||||
|
* The specific XML Catalog Processing Instuction name.
|
||||||
|
*/
|
||||||
|
#define XML_CATALOG_PI \
|
||||||
|
(const xmlChar *) "oasis-xml-catalog"
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The API is voluntarily limited to general cataloging.
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
XML_CATA_PREFER_NONE = 0,
|
||||||
|
XML_CATA_PREFER_PUBLIC = 1,
|
||||||
|
XML_CATA_PREFER_SYSTEM
|
||||||
|
} xmlCatalogPrefer;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
XML_CATA_ALLOW_NONE = 0,
|
||||||
|
XML_CATA_ALLOW_GLOBAL = 1,
|
||||||
|
XML_CATA_ALLOW_DOCUMENT = 2,
|
||||||
|
XML_CATA_ALLOW_ALL = 3
|
||||||
|
} xmlCatalogAllow;
|
||||||
|
|
||||||
|
typedef struct _xmlCatalog xmlCatalog;
|
||||||
|
typedef xmlCatalog *xmlCatalogPtr;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Operations on a given catalog.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlCatalogPtr XMLCALL
|
||||||
|
xmlNewCatalog (int sgml);
|
||||||
|
XMLPUBFUN xmlCatalogPtr XMLCALL
|
||||||
|
xmlLoadACatalog (const char *filename);
|
||||||
|
XMLPUBFUN xmlCatalogPtr XMLCALL
|
||||||
|
xmlLoadSGMLSuperCatalog (const char *filename);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlConvertSGMLCatalog (xmlCatalogPtr catal);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlACatalogAdd (xmlCatalogPtr catal,
|
||||||
|
const xmlChar *type,
|
||||||
|
const xmlChar *orig,
|
||||||
|
const xmlChar *replace);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlACatalogRemove (xmlCatalogPtr catal,
|
||||||
|
const xmlChar *value);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlACatalogResolve (xmlCatalogPtr catal,
|
||||||
|
const xmlChar *pubID,
|
||||||
|
const xmlChar *sysID);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlACatalogResolveSystem(xmlCatalogPtr catal,
|
||||||
|
const xmlChar *sysID);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlACatalogResolvePublic(xmlCatalogPtr catal,
|
||||||
|
const xmlChar *pubID);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlACatalogResolveURI (xmlCatalogPtr catal,
|
||||||
|
const xmlChar *URI);
|
||||||
|
#ifdef LIBXML_OUTPUT_ENABLED
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlACatalogDump (xmlCatalogPtr catal,
|
||||||
|
FILE *out);
|
||||||
|
#endif /* LIBXML_OUTPUT_ENABLED */
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlFreeCatalog (xmlCatalogPtr catal);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlCatalogIsEmpty (xmlCatalogPtr catal);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Global operations.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlInitializeCatalog (void);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlLoadCatalog (const char *filename);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlLoadCatalogs (const char *paths);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlCatalogCleanup (void);
|
||||||
|
#ifdef LIBXML_OUTPUT_ENABLED
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlCatalogDump (FILE *out);
|
||||||
|
#endif /* LIBXML_OUTPUT_ENABLED */
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlCatalogResolve (const xmlChar *pubID,
|
||||||
|
const xmlChar *sysID);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlCatalogResolveSystem (const xmlChar *sysID);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlCatalogResolvePublic (const xmlChar *pubID);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlCatalogResolveURI (const xmlChar *URI);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlCatalogAdd (const xmlChar *type,
|
||||||
|
const xmlChar *orig,
|
||||||
|
const xmlChar *replace);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlCatalogRemove (const xmlChar *value);
|
||||||
|
XMLPUBFUN xmlDocPtr XMLCALL
|
||||||
|
xmlParseCatalogFile (const char *filename);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlCatalogConvert (void);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Strictly minimal interfaces for per-document catalogs used
|
||||||
|
* by the parser.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlCatalogFreeLocal (void *catalogs);
|
||||||
|
XMLPUBFUN void * XMLCALL
|
||||||
|
xmlCatalogAddLocal (void *catalogs,
|
||||||
|
const xmlChar *URL);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlCatalogLocalResolve (void *catalogs,
|
||||||
|
const xmlChar *pubID,
|
||||||
|
const xmlChar *sysID);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlCatalogLocalResolveURI(void *catalogs,
|
||||||
|
const xmlChar *URI);
|
||||||
|
/*
|
||||||
|
* Preference settings.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlCatalogSetDebug (int level);
|
||||||
|
XMLPUBFUN xmlCatalogPrefer XMLCALL
|
||||||
|
xmlCatalogSetDefaultPrefer(xmlCatalogPrefer prefer);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlCatalogSetDefaults (xmlCatalogAllow allow);
|
||||||
|
XMLPUBFUN xmlCatalogAllow XMLCALL
|
||||||
|
xmlCatalogGetDefaults (void);
|
||||||
|
|
||||||
|
|
||||||
|
/* DEPRECATED interfaces */
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlCatalogGetSystem (const xmlChar *sysID);
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlCatalogGetPublic (const xmlChar *pubID);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif /* LIBXML_CATALOG_ENABLED */
|
||||||
|
#endif /* __XML_CATALOG_H__ */
|
|
@ -0,0 +1,230 @@
|
||||||
|
/*
|
||||||
|
* Summary: Unicode character range checking
|
||||||
|
* Description: this module exports interfaces for the character
|
||||||
|
* range validation APIs
|
||||||
|
*
|
||||||
|
* This file is automatically generated from the cvs source
|
||||||
|
* definition files using the genChRanges.py Python script
|
||||||
|
*
|
||||||
|
* Generation date: Mon Mar 27 11:09:48 2006
|
||||||
|
* Sources: chvalid.def
|
||||||
|
* Author: William Brack <wbrack@mmm.com.hk>
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_CHVALID_H__
|
||||||
|
#define __XML_CHVALID_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
#include <libxml/xmlstring.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Define our typedefs and structures
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
typedef struct _xmlChSRange xmlChSRange;
|
||||||
|
typedef xmlChSRange *xmlChSRangePtr;
|
||||||
|
struct _xmlChSRange {
|
||||||
|
unsigned short low;
|
||||||
|
unsigned short high;
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef struct _xmlChLRange xmlChLRange;
|
||||||
|
typedef xmlChLRange *xmlChLRangePtr;
|
||||||
|
struct _xmlChLRange {
|
||||||
|
unsigned int low;
|
||||||
|
unsigned int high;
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef struct _xmlChRangeGroup xmlChRangeGroup;
|
||||||
|
typedef xmlChRangeGroup *xmlChRangeGroupPtr;
|
||||||
|
struct _xmlChRangeGroup {
|
||||||
|
int nbShortRange;
|
||||||
|
int nbLongRange;
|
||||||
|
const xmlChSRange *shortRange; /* points to an array of ranges */
|
||||||
|
const xmlChLRange *longRange;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Range checking routine
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlCharInRange(unsigned int val, const xmlChRangeGroup *group);
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlIsBaseChar_ch:
|
||||||
|
* @c: char to validate
|
||||||
|
*
|
||||||
|
* Automatically generated by genChRanges.py
|
||||||
|
*/
|
||||||
|
#define xmlIsBaseChar_ch(c) (((0x41 <= (c)) && ((c) <= 0x5a)) || \
|
||||||
|
((0x61 <= (c)) && ((c) <= 0x7a)) || \
|
||||||
|
((0xc0 <= (c)) && ((c) <= 0xd6)) || \
|
||||||
|
((0xd8 <= (c)) && ((c) <= 0xf6)) || \
|
||||||
|
(0xf8 <= (c)))
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlIsBaseCharQ:
|
||||||
|
* @c: char to validate
|
||||||
|
*
|
||||||
|
* Automatically generated by genChRanges.py
|
||||||
|
*/
|
||||||
|
#define xmlIsBaseCharQ(c) (((c) < 0x100) ? \
|
||||||
|
xmlIsBaseChar_ch((c)) : \
|
||||||
|
xmlCharInRange((c), &xmlIsBaseCharGroup))
|
||||||
|
|
||||||
|
XMLPUBVAR const xmlChRangeGroup xmlIsBaseCharGroup;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlIsBlank_ch:
|
||||||
|
* @c: char to validate
|
||||||
|
*
|
||||||
|
* Automatically generated by genChRanges.py
|
||||||
|
*/
|
||||||
|
#define xmlIsBlank_ch(c) (((c) == 0x20) || \
|
||||||
|
((0x9 <= (c)) && ((c) <= 0xa)) || \
|
||||||
|
((c) == 0xd))
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlIsBlankQ:
|
||||||
|
* @c: char to validate
|
||||||
|
*
|
||||||
|
* Automatically generated by genChRanges.py
|
||||||
|
*/
|
||||||
|
#define xmlIsBlankQ(c) (((c) < 0x100) ? \
|
||||||
|
xmlIsBlank_ch((c)) : 0)
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlIsChar_ch:
|
||||||
|
* @c: char to validate
|
||||||
|
*
|
||||||
|
* Automatically generated by genChRanges.py
|
||||||
|
*/
|
||||||
|
#define xmlIsChar_ch(c) (((0x9 <= (c)) && ((c) <= 0xa)) || \
|
||||||
|
((c) == 0xd) || \
|
||||||
|
(0x20 <= (c)))
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlIsCharQ:
|
||||||
|
* @c: char to validate
|
||||||
|
*
|
||||||
|
* Automatically generated by genChRanges.py
|
||||||
|
*/
|
||||||
|
#define xmlIsCharQ(c) (((c) < 0x100) ? \
|
||||||
|
xmlIsChar_ch((c)) :\
|
||||||
|
(((0x100 <= (c)) && ((c) <= 0xd7ff)) || \
|
||||||
|
((0xe000 <= (c)) && ((c) <= 0xfffd)) || \
|
||||||
|
((0x10000 <= (c)) && ((c) <= 0x10ffff))))
|
||||||
|
|
||||||
|
XMLPUBVAR const xmlChRangeGroup xmlIsCharGroup;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlIsCombiningQ:
|
||||||
|
* @c: char to validate
|
||||||
|
*
|
||||||
|
* Automatically generated by genChRanges.py
|
||||||
|
*/
|
||||||
|
#define xmlIsCombiningQ(c) (((c) < 0x100) ? \
|
||||||
|
0 : \
|
||||||
|
xmlCharInRange((c), &xmlIsCombiningGroup))
|
||||||
|
|
||||||
|
XMLPUBVAR const xmlChRangeGroup xmlIsCombiningGroup;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlIsDigit_ch:
|
||||||
|
* @c: char to validate
|
||||||
|
*
|
||||||
|
* Automatically generated by genChRanges.py
|
||||||
|
*/
|
||||||
|
#define xmlIsDigit_ch(c) (((0x30 <= (c)) && ((c) <= 0x39)))
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlIsDigitQ:
|
||||||
|
* @c: char to validate
|
||||||
|
*
|
||||||
|
* Automatically generated by genChRanges.py
|
||||||
|
*/
|
||||||
|
#define xmlIsDigitQ(c) (((c) < 0x100) ? \
|
||||||
|
xmlIsDigit_ch((c)) : \
|
||||||
|
xmlCharInRange((c), &xmlIsDigitGroup))
|
||||||
|
|
||||||
|
XMLPUBVAR const xmlChRangeGroup xmlIsDigitGroup;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlIsExtender_ch:
|
||||||
|
* @c: char to validate
|
||||||
|
*
|
||||||
|
* Automatically generated by genChRanges.py
|
||||||
|
*/
|
||||||
|
#define xmlIsExtender_ch(c) (((c) == 0xb7))
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlIsExtenderQ:
|
||||||
|
* @c: char to validate
|
||||||
|
*
|
||||||
|
* Automatically generated by genChRanges.py
|
||||||
|
*/
|
||||||
|
#define xmlIsExtenderQ(c) (((c) < 0x100) ? \
|
||||||
|
xmlIsExtender_ch((c)) : \
|
||||||
|
xmlCharInRange((c), &xmlIsExtenderGroup))
|
||||||
|
|
||||||
|
XMLPUBVAR const xmlChRangeGroup xmlIsExtenderGroup;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlIsIdeographicQ:
|
||||||
|
* @c: char to validate
|
||||||
|
*
|
||||||
|
* Automatically generated by genChRanges.py
|
||||||
|
*/
|
||||||
|
#define xmlIsIdeographicQ(c) (((c) < 0x100) ? \
|
||||||
|
0 :\
|
||||||
|
(((0x4e00 <= (c)) && ((c) <= 0x9fa5)) || \
|
||||||
|
((c) == 0x3007) || \
|
||||||
|
((0x3021 <= (c)) && ((c) <= 0x3029))))
|
||||||
|
|
||||||
|
XMLPUBVAR const xmlChRangeGroup xmlIsIdeographicGroup;
|
||||||
|
XMLPUBVAR const unsigned char xmlIsPubidChar_tab[256];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlIsPubidChar_ch:
|
||||||
|
* @c: char to validate
|
||||||
|
*
|
||||||
|
* Automatically generated by genChRanges.py
|
||||||
|
*/
|
||||||
|
#define xmlIsPubidChar_ch(c) (xmlIsPubidChar_tab[(c)])
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlIsPubidCharQ:
|
||||||
|
* @c: char to validate
|
||||||
|
*
|
||||||
|
* Automatically generated by genChRanges.py
|
||||||
|
*/
|
||||||
|
#define xmlIsPubidCharQ(c) (((c) < 0x100) ? \
|
||||||
|
xmlIsPubidChar_ch((c)) : 0)
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlIsBaseChar(unsigned int ch);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlIsBlank(unsigned int ch);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlIsChar(unsigned int ch);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlIsCombining(unsigned int ch);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlIsDigit(unsigned int ch);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlIsExtender(unsigned int ch);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlIsIdeographic(unsigned int ch);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlIsPubidChar(unsigned int ch);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif /* __XML_CHVALID_H__ */
|
|
@ -0,0 +1,217 @@
|
||||||
|
/*
|
||||||
|
* Summary: Tree debugging APIs
|
||||||
|
* Description: Interfaces to a set of routines used for debugging the tree
|
||||||
|
* produced by the XML parser.
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __DEBUG_XML__
|
||||||
|
#define __DEBUG_XML__
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
#include <libxml/tree.h>
|
||||||
|
|
||||||
|
#ifdef LIBXML_DEBUG_ENABLED
|
||||||
|
|
||||||
|
#include <libxml/xpath.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The standard Dump routines.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlDebugDumpString (FILE *output,
|
||||||
|
const xmlChar *str);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlDebugDumpAttr (FILE *output,
|
||||||
|
xmlAttrPtr attr,
|
||||||
|
int depth);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlDebugDumpAttrList (FILE *output,
|
||||||
|
xmlAttrPtr attr,
|
||||||
|
int depth);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlDebugDumpOneNode (FILE *output,
|
||||||
|
xmlNodePtr node,
|
||||||
|
int depth);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlDebugDumpNode (FILE *output,
|
||||||
|
xmlNodePtr node,
|
||||||
|
int depth);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlDebugDumpNodeList (FILE *output,
|
||||||
|
xmlNodePtr node,
|
||||||
|
int depth);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlDebugDumpDocumentHead(FILE *output,
|
||||||
|
xmlDocPtr doc);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlDebugDumpDocument (FILE *output,
|
||||||
|
xmlDocPtr doc);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlDebugDumpDTD (FILE *output,
|
||||||
|
xmlDtdPtr dtd);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlDebugDumpEntities (FILE *output,
|
||||||
|
xmlDocPtr doc);
|
||||||
|
|
||||||
|
/****************************************************************
|
||||||
|
* *
|
||||||
|
* Checking routines *
|
||||||
|
* *
|
||||||
|
****************************************************************/
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlDebugCheckDocument (FILE * output,
|
||||||
|
xmlDocPtr doc);
|
||||||
|
|
||||||
|
/****************************************************************
|
||||||
|
* *
|
||||||
|
* XML shell helpers *
|
||||||
|
* *
|
||||||
|
****************************************************************/
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlLsOneNode (FILE *output, xmlNodePtr node);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlLsCountNode (xmlNodePtr node);
|
||||||
|
|
||||||
|
XMLPUBFUN const char * XMLCALL
|
||||||
|
xmlBoolToText (int boolval);
|
||||||
|
|
||||||
|
/****************************************************************
|
||||||
|
* *
|
||||||
|
* The XML shell related structures and functions *
|
||||||
|
* *
|
||||||
|
****************************************************************/
|
||||||
|
|
||||||
|
#ifdef LIBXML_XPATH_ENABLED
|
||||||
|
/**
|
||||||
|
* xmlShellReadlineFunc:
|
||||||
|
* @prompt: a string prompt
|
||||||
|
*
|
||||||
|
* This is a generic signature for the XML shell input function.
|
||||||
|
*
|
||||||
|
* Returns a string which will be freed by the Shell.
|
||||||
|
*/
|
||||||
|
typedef char * (* xmlShellReadlineFunc)(char *prompt);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlShellCtxt:
|
||||||
|
*
|
||||||
|
* A debugging shell context.
|
||||||
|
* TODO: add the defined function tables.
|
||||||
|
*/
|
||||||
|
typedef struct _xmlShellCtxt xmlShellCtxt;
|
||||||
|
typedef xmlShellCtxt *xmlShellCtxtPtr;
|
||||||
|
struct _xmlShellCtxt {
|
||||||
|
char *filename;
|
||||||
|
xmlDocPtr doc;
|
||||||
|
xmlNodePtr node;
|
||||||
|
xmlXPathContextPtr pctxt;
|
||||||
|
int loaded;
|
||||||
|
FILE *output;
|
||||||
|
xmlShellReadlineFunc input;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlShellCmd:
|
||||||
|
* @ctxt: a shell context
|
||||||
|
* @arg: a string argument
|
||||||
|
* @node: a first node
|
||||||
|
* @node2: a second node
|
||||||
|
*
|
||||||
|
* This is a generic signature for the XML shell functions.
|
||||||
|
*
|
||||||
|
* Returns an int, negative returns indicating errors.
|
||||||
|
*/
|
||||||
|
typedef int (* xmlShellCmd) (xmlShellCtxtPtr ctxt,
|
||||||
|
char *arg,
|
||||||
|
xmlNodePtr node,
|
||||||
|
xmlNodePtr node2);
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlShellPrintXPathError (int errorType,
|
||||||
|
const char *arg);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlShellPrintXPathResult(xmlXPathObjectPtr list);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlShellList (xmlShellCtxtPtr ctxt,
|
||||||
|
char *arg,
|
||||||
|
xmlNodePtr node,
|
||||||
|
xmlNodePtr node2);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlShellBase (xmlShellCtxtPtr ctxt,
|
||||||
|
char *arg,
|
||||||
|
xmlNodePtr node,
|
||||||
|
xmlNodePtr node2);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlShellDir (xmlShellCtxtPtr ctxt,
|
||||||
|
char *arg,
|
||||||
|
xmlNodePtr node,
|
||||||
|
xmlNodePtr node2);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlShellLoad (xmlShellCtxtPtr ctxt,
|
||||||
|
char *filename,
|
||||||
|
xmlNodePtr node,
|
||||||
|
xmlNodePtr node2);
|
||||||
|
#ifdef LIBXML_OUTPUT_ENABLED
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlShellPrintNode (xmlNodePtr node);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlShellCat (xmlShellCtxtPtr ctxt,
|
||||||
|
char *arg,
|
||||||
|
xmlNodePtr node,
|
||||||
|
xmlNodePtr node2);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlShellWrite (xmlShellCtxtPtr ctxt,
|
||||||
|
char *filename,
|
||||||
|
xmlNodePtr node,
|
||||||
|
xmlNodePtr node2);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlShellSave (xmlShellCtxtPtr ctxt,
|
||||||
|
char *filename,
|
||||||
|
xmlNodePtr node,
|
||||||
|
xmlNodePtr node2);
|
||||||
|
#endif /* LIBXML_OUTPUT_ENABLED */
|
||||||
|
#ifdef LIBXML_VALID_ENABLED
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlShellValidate (xmlShellCtxtPtr ctxt,
|
||||||
|
char *dtd,
|
||||||
|
xmlNodePtr node,
|
||||||
|
xmlNodePtr node2);
|
||||||
|
#endif /* LIBXML_VALID_ENABLED */
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlShellDu (xmlShellCtxtPtr ctxt,
|
||||||
|
char *arg,
|
||||||
|
xmlNodePtr tree,
|
||||||
|
xmlNodePtr node2);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlShellPwd (xmlShellCtxtPtr ctxt,
|
||||||
|
char *buffer,
|
||||||
|
xmlNodePtr node,
|
||||||
|
xmlNodePtr node2);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The Shell interface.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlShell (xmlDocPtr doc,
|
||||||
|
char *filename,
|
||||||
|
xmlShellReadlineFunc input,
|
||||||
|
FILE *output);
|
||||||
|
|
||||||
|
#endif /* LIBXML_XPATH_ENABLED */
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* LIBXML_DEBUG_ENABLED */
|
||||||
|
#endif /* __DEBUG_XML__ */
|
|
@ -0,0 +1,69 @@
|
||||||
|
/*
|
||||||
|
* Summary: string dictionnary
|
||||||
|
* Description: dictionary of reusable strings, just used to avoid allocation
|
||||||
|
* and freeing operations.
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_DICT_H__
|
||||||
|
#define __XML_DICT_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
#include <libxml/tree.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The dictionnary.
|
||||||
|
*/
|
||||||
|
typedef struct _xmlDict xmlDict;
|
||||||
|
typedef xmlDict *xmlDictPtr;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Constructor and destructor.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlDictPtr XMLCALL
|
||||||
|
xmlDictCreate (void);
|
||||||
|
XMLPUBFUN xmlDictPtr XMLCALL
|
||||||
|
xmlDictCreateSub(xmlDictPtr sub);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlDictReference(xmlDictPtr dict);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlDictFree (xmlDictPtr dict);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Lookup of entry in the dictionnary.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlDictLookup (xmlDictPtr dict,
|
||||||
|
const xmlChar *name,
|
||||||
|
int len);
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlDictExists (xmlDictPtr dict,
|
||||||
|
const xmlChar *name,
|
||||||
|
int len);
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlDictQLookup (xmlDictPtr dict,
|
||||||
|
const xmlChar *prefix,
|
||||||
|
const xmlChar *name);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlDictOwns (xmlDictPtr dict,
|
||||||
|
const xmlChar *str);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlDictSize (xmlDictPtr dict);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Cleanup function
|
||||||
|
*/
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlDictCleanup (void);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif /* ! __XML_DICT_H__ */
|
|
@ -0,0 +1,240 @@
|
||||||
|
/*
|
||||||
|
* Summary: interface for the encoding conversion functions
|
||||||
|
* Description: interface for the encoding conversion functions needed for
|
||||||
|
* XML basic encoding and iconv() support.
|
||||||
|
*
|
||||||
|
* Related specs are
|
||||||
|
* rfc2044 (UTF-8 and UTF-16) F. Yergeau Alis Technologies
|
||||||
|
* [ISO-10646] UTF-8 and UTF-16 in Annexes
|
||||||
|
* [ISO-8859-1] ISO Latin-1 characters codes.
|
||||||
|
* [UNICODE] The Unicode Consortium, "The Unicode Standard --
|
||||||
|
* Worldwide Character Encoding -- Version 1.0", Addison-
|
||||||
|
* Wesley, Volume 1, 1991, Volume 2, 1992. UTF-8 is
|
||||||
|
* described in Unicode Technical Report #4.
|
||||||
|
* [US-ASCII] Coded Character Set--7-bit American Standard Code for
|
||||||
|
* Information Interchange, ANSI X3.4-1986.
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_CHAR_ENCODING_H__
|
||||||
|
#define __XML_CHAR_ENCODING_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
|
||||||
|
#ifdef LIBXML_ICONV_ENABLED
|
||||||
|
#include <iconv.h>
|
||||||
|
#endif
|
||||||
|
#ifdef LIBXML_ICU_ENABLED
|
||||||
|
#include <unicode/ucnv.h>
|
||||||
|
#endif
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* xmlCharEncoding:
|
||||||
|
*
|
||||||
|
* Predefined values for some standard encodings.
|
||||||
|
* Libxml does not do beforehand translation on UTF8 and ISOLatinX.
|
||||||
|
* It also supports ASCII, ISO-8859-1, and UTF16 (LE and BE) by default.
|
||||||
|
*
|
||||||
|
* Anything else would have to be translated to UTF8 before being
|
||||||
|
* given to the parser itself. The BOM for UTF16 and the encoding
|
||||||
|
* declaration are looked at and a converter is looked for at that
|
||||||
|
* point. If not found the parser stops here as asked by the XML REC. A
|
||||||
|
* converter can be registered by the user using xmlRegisterCharEncodingHandler
|
||||||
|
* but the current form doesn't allow stateful transcoding (a serious
|
||||||
|
* problem agreed !). If iconv has been found it will be used
|
||||||
|
* automatically and allow stateful transcoding, the simplest is then
|
||||||
|
* to be sure to enable iconv and to provide iconv libs for the encoding
|
||||||
|
* support needed.
|
||||||
|
*
|
||||||
|
* Note that the generic "UTF-16" is not a predefined value. Instead, only
|
||||||
|
* the specific UTF-16LE and UTF-16BE are present.
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
XML_CHAR_ENCODING_ERROR= -1, /* No char encoding detected */
|
||||||
|
XML_CHAR_ENCODING_NONE= 0, /* No char encoding detected */
|
||||||
|
XML_CHAR_ENCODING_UTF8= 1, /* UTF-8 */
|
||||||
|
XML_CHAR_ENCODING_UTF16LE= 2, /* UTF-16 little endian */
|
||||||
|
XML_CHAR_ENCODING_UTF16BE= 3, /* UTF-16 big endian */
|
||||||
|
XML_CHAR_ENCODING_UCS4LE= 4, /* UCS-4 little endian */
|
||||||
|
XML_CHAR_ENCODING_UCS4BE= 5, /* UCS-4 big endian */
|
||||||
|
XML_CHAR_ENCODING_EBCDIC= 6, /* EBCDIC uh! */
|
||||||
|
XML_CHAR_ENCODING_UCS4_2143=7, /* UCS-4 unusual ordering */
|
||||||
|
XML_CHAR_ENCODING_UCS4_3412=8, /* UCS-4 unusual ordering */
|
||||||
|
XML_CHAR_ENCODING_UCS2= 9, /* UCS-2 */
|
||||||
|
XML_CHAR_ENCODING_8859_1= 10,/* ISO-8859-1 ISO Latin 1 */
|
||||||
|
XML_CHAR_ENCODING_8859_2= 11,/* ISO-8859-2 ISO Latin 2 */
|
||||||
|
XML_CHAR_ENCODING_8859_3= 12,/* ISO-8859-3 */
|
||||||
|
XML_CHAR_ENCODING_8859_4= 13,/* ISO-8859-4 */
|
||||||
|
XML_CHAR_ENCODING_8859_5= 14,/* ISO-8859-5 */
|
||||||
|
XML_CHAR_ENCODING_8859_6= 15,/* ISO-8859-6 */
|
||||||
|
XML_CHAR_ENCODING_8859_7= 16,/* ISO-8859-7 */
|
||||||
|
XML_CHAR_ENCODING_8859_8= 17,/* ISO-8859-8 */
|
||||||
|
XML_CHAR_ENCODING_8859_9= 18,/* ISO-8859-9 */
|
||||||
|
XML_CHAR_ENCODING_2022_JP= 19,/* ISO-2022-JP */
|
||||||
|
XML_CHAR_ENCODING_SHIFT_JIS=20,/* Shift_JIS */
|
||||||
|
XML_CHAR_ENCODING_EUC_JP= 21,/* EUC-JP */
|
||||||
|
XML_CHAR_ENCODING_ASCII= 22 /* pure ASCII */
|
||||||
|
} xmlCharEncoding;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlCharEncodingInputFunc:
|
||||||
|
* @out: a pointer to an array of bytes to store the UTF-8 result
|
||||||
|
* @outlen: the length of @out
|
||||||
|
* @in: a pointer to an array of chars in the original encoding
|
||||||
|
* @inlen: the length of @in
|
||||||
|
*
|
||||||
|
* Take a block of chars in the original encoding and try to convert
|
||||||
|
* it to an UTF-8 block of chars out.
|
||||||
|
*
|
||||||
|
* Returns the number of bytes written, -1 if lack of space, or -2
|
||||||
|
* if the transcoding failed.
|
||||||
|
* The value of @inlen after return is the number of octets consumed
|
||||||
|
* if the return value is positive, else unpredictiable.
|
||||||
|
* The value of @outlen after return is the number of octets consumed.
|
||||||
|
*/
|
||||||
|
typedef int (* xmlCharEncodingInputFunc)(unsigned char *out, int *outlen,
|
||||||
|
const unsigned char *in, int *inlen);
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlCharEncodingOutputFunc:
|
||||||
|
* @out: a pointer to an array of bytes to store the result
|
||||||
|
* @outlen: the length of @out
|
||||||
|
* @in: a pointer to an array of UTF-8 chars
|
||||||
|
* @inlen: the length of @in
|
||||||
|
*
|
||||||
|
* Take a block of UTF-8 chars in and try to convert it to another
|
||||||
|
* encoding.
|
||||||
|
* Note: a first call designed to produce heading info is called with
|
||||||
|
* in = NULL. If stateful this should also initialize the encoder state.
|
||||||
|
*
|
||||||
|
* Returns the number of bytes written, -1 if lack of space, or -2
|
||||||
|
* if the transcoding failed.
|
||||||
|
* The value of @inlen after return is the number of octets consumed
|
||||||
|
* if the return value is positive, else unpredictiable.
|
||||||
|
* The value of @outlen after return is the number of octets produced.
|
||||||
|
*/
|
||||||
|
typedef int (* xmlCharEncodingOutputFunc)(unsigned char *out, int *outlen,
|
||||||
|
const unsigned char *in, int *inlen);
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Block defining the handlers for non UTF-8 encodings.
|
||||||
|
* If iconv is supported, there are two extra fields.
|
||||||
|
*/
|
||||||
|
#ifdef LIBXML_ICU_ENABLED
|
||||||
|
struct _uconv_t {
|
||||||
|
UConverter *uconv; /* for conversion between an encoding and UTF-16 */
|
||||||
|
UConverter *utf8; /* for conversion between UTF-8 and UTF-16 */
|
||||||
|
};
|
||||||
|
typedef struct _uconv_t uconv_t;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef struct _xmlCharEncodingHandler xmlCharEncodingHandler;
|
||||||
|
typedef xmlCharEncodingHandler *xmlCharEncodingHandlerPtr;
|
||||||
|
struct _xmlCharEncodingHandler {
|
||||||
|
char *name;
|
||||||
|
xmlCharEncodingInputFunc input;
|
||||||
|
xmlCharEncodingOutputFunc output;
|
||||||
|
#ifdef LIBXML_ICONV_ENABLED
|
||||||
|
iconv_t iconv_in;
|
||||||
|
iconv_t iconv_out;
|
||||||
|
#endif /* LIBXML_ICONV_ENABLED */
|
||||||
|
#ifdef LIBXML_ICU_ENABLED
|
||||||
|
uconv_t *uconv_in;
|
||||||
|
uconv_t *uconv_out;
|
||||||
|
#endif /* LIBXML_ICU_ENABLED */
|
||||||
|
};
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#include <libxml/tree.h>
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Interfaces for encoding handlers.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlInitCharEncodingHandlers (void);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlCleanupCharEncodingHandlers (void);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlRegisterCharEncodingHandler (xmlCharEncodingHandlerPtr handler);
|
||||||
|
XMLPUBFUN xmlCharEncodingHandlerPtr XMLCALL
|
||||||
|
xmlGetCharEncodingHandler (xmlCharEncoding enc);
|
||||||
|
XMLPUBFUN xmlCharEncodingHandlerPtr XMLCALL
|
||||||
|
xmlFindCharEncodingHandler (const char *name);
|
||||||
|
XMLPUBFUN xmlCharEncodingHandlerPtr XMLCALL
|
||||||
|
xmlNewCharEncodingHandler (const char *name,
|
||||||
|
xmlCharEncodingInputFunc input,
|
||||||
|
xmlCharEncodingOutputFunc output);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Interfaces for encoding names and aliases.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlAddEncodingAlias (const char *name,
|
||||||
|
const char *alias);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlDelEncodingAlias (const char *alias);
|
||||||
|
XMLPUBFUN const char * XMLCALL
|
||||||
|
xmlGetEncodingAlias (const char *alias);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlCleanupEncodingAliases (void);
|
||||||
|
XMLPUBFUN xmlCharEncoding XMLCALL
|
||||||
|
xmlParseCharEncoding (const char *name);
|
||||||
|
XMLPUBFUN const char * XMLCALL
|
||||||
|
xmlGetCharEncodingName (xmlCharEncoding enc);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Interfaces directly used by the parsers.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlCharEncoding XMLCALL
|
||||||
|
xmlDetectCharEncoding (const unsigned char *in,
|
||||||
|
int len);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlCharEncOutFunc (xmlCharEncodingHandler *handler,
|
||||||
|
xmlBufferPtr out,
|
||||||
|
xmlBufferPtr in);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlCharEncInFunc (xmlCharEncodingHandler *handler,
|
||||||
|
xmlBufferPtr out,
|
||||||
|
xmlBufferPtr in);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlCharEncFirstLine (xmlCharEncodingHandler *handler,
|
||||||
|
xmlBufferPtr out,
|
||||||
|
xmlBufferPtr in);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlCharEncCloseFunc (xmlCharEncodingHandler *handler);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Export a few useful functions
|
||||||
|
*/
|
||||||
|
#ifdef LIBXML_OUTPUT_ENABLED
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
UTF8Toisolat1 (unsigned char *out,
|
||||||
|
int *outlen,
|
||||||
|
const unsigned char *in,
|
||||||
|
int *inlen);
|
||||||
|
#endif /* LIBXML_OUTPUT_ENABLED */
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
isolat1ToUTF8 (unsigned char *out,
|
||||||
|
int *outlen,
|
||||||
|
const unsigned char *in,
|
||||||
|
int *inlen);
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* __XML_CHAR_ENCODING_H__ */
|
|
@ -0,0 +1,150 @@
|
||||||
|
/*
|
||||||
|
* Summary: interface for the XML entities handling
|
||||||
|
* Description: this module provides some of the entity API needed
|
||||||
|
* for the parser and applications.
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_ENTITIES_H__
|
||||||
|
#define __XML_ENTITIES_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
#include <libxml/tree.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The different valid entity types.
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
XML_INTERNAL_GENERAL_ENTITY = 1,
|
||||||
|
XML_EXTERNAL_GENERAL_PARSED_ENTITY = 2,
|
||||||
|
XML_EXTERNAL_GENERAL_UNPARSED_ENTITY = 3,
|
||||||
|
XML_INTERNAL_PARAMETER_ENTITY = 4,
|
||||||
|
XML_EXTERNAL_PARAMETER_ENTITY = 5,
|
||||||
|
XML_INTERNAL_PREDEFINED_ENTITY = 6
|
||||||
|
} xmlEntityType;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* An unit of storage for an entity, contains the string, the value
|
||||||
|
* and the linkind data needed for the linking in the hash table.
|
||||||
|
*/
|
||||||
|
|
||||||
|
struct _xmlEntity {
|
||||||
|
void *_private; /* application data */
|
||||||
|
xmlElementType type; /* XML_ENTITY_DECL, must be second ! */
|
||||||
|
const xmlChar *name; /* Entity name */
|
||||||
|
struct _xmlNode *children; /* First child link */
|
||||||
|
struct _xmlNode *last; /* Last child link */
|
||||||
|
struct _xmlDtd *parent; /* -> DTD */
|
||||||
|
struct _xmlNode *next; /* next sibling link */
|
||||||
|
struct _xmlNode *prev; /* previous sibling link */
|
||||||
|
struct _xmlDoc *doc; /* the containing document */
|
||||||
|
|
||||||
|
xmlChar *orig; /* content without ref substitution */
|
||||||
|
xmlChar *content; /* content or ndata if unparsed */
|
||||||
|
int length; /* the content length */
|
||||||
|
xmlEntityType etype; /* The entity type */
|
||||||
|
const xmlChar *ExternalID; /* External identifier for PUBLIC */
|
||||||
|
const xmlChar *SystemID; /* URI for a SYSTEM or PUBLIC Entity */
|
||||||
|
|
||||||
|
struct _xmlEntity *nexte; /* unused */
|
||||||
|
const xmlChar *URI; /* the full URI as computed */
|
||||||
|
int owner; /* does the entity own the childrens */
|
||||||
|
int checked; /* was the entity content checked */
|
||||||
|
/* this is also used to count entites
|
||||||
|
* references done from that entity */
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* All entities are stored in an hash table.
|
||||||
|
* There is 2 separate hash tables for global and parameter entities.
|
||||||
|
*/
|
||||||
|
|
||||||
|
typedef struct _xmlHashTable xmlEntitiesTable;
|
||||||
|
typedef xmlEntitiesTable *xmlEntitiesTablePtr;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* External functions:
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifdef LIBXML_LEGACY_ENABLED
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlInitializePredefinedEntities (void);
|
||||||
|
#endif /* LIBXML_LEGACY_ENABLED */
|
||||||
|
|
||||||
|
XMLPUBFUN xmlEntityPtr XMLCALL
|
||||||
|
xmlNewEntity (xmlDocPtr doc,
|
||||||
|
const xmlChar *name,
|
||||||
|
int type,
|
||||||
|
const xmlChar *ExternalID,
|
||||||
|
const xmlChar *SystemID,
|
||||||
|
const xmlChar *content);
|
||||||
|
XMLPUBFUN xmlEntityPtr XMLCALL
|
||||||
|
xmlAddDocEntity (xmlDocPtr doc,
|
||||||
|
const xmlChar *name,
|
||||||
|
int type,
|
||||||
|
const xmlChar *ExternalID,
|
||||||
|
const xmlChar *SystemID,
|
||||||
|
const xmlChar *content);
|
||||||
|
XMLPUBFUN xmlEntityPtr XMLCALL
|
||||||
|
xmlAddDtdEntity (xmlDocPtr doc,
|
||||||
|
const xmlChar *name,
|
||||||
|
int type,
|
||||||
|
const xmlChar *ExternalID,
|
||||||
|
const xmlChar *SystemID,
|
||||||
|
const xmlChar *content);
|
||||||
|
XMLPUBFUN xmlEntityPtr XMLCALL
|
||||||
|
xmlGetPredefinedEntity (const xmlChar *name);
|
||||||
|
XMLPUBFUN xmlEntityPtr XMLCALL
|
||||||
|
xmlGetDocEntity (xmlDocPtr doc,
|
||||||
|
const xmlChar *name);
|
||||||
|
XMLPUBFUN xmlEntityPtr XMLCALL
|
||||||
|
xmlGetDtdEntity (xmlDocPtr doc,
|
||||||
|
const xmlChar *name);
|
||||||
|
XMLPUBFUN xmlEntityPtr XMLCALL
|
||||||
|
xmlGetParameterEntity (xmlDocPtr doc,
|
||||||
|
const xmlChar *name);
|
||||||
|
#ifdef LIBXML_LEGACY_ENABLED
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlEncodeEntities (xmlDocPtr doc,
|
||||||
|
const xmlChar *input);
|
||||||
|
#endif /* LIBXML_LEGACY_ENABLED */
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlEncodeEntitiesReentrant(xmlDocPtr doc,
|
||||||
|
const xmlChar *input);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlEncodeSpecialChars (xmlDocPtr doc,
|
||||||
|
const xmlChar *input);
|
||||||
|
XMLPUBFUN xmlEntitiesTablePtr XMLCALL
|
||||||
|
xmlCreateEntitiesTable (void);
|
||||||
|
#ifdef LIBXML_TREE_ENABLED
|
||||||
|
XMLPUBFUN xmlEntitiesTablePtr XMLCALL
|
||||||
|
xmlCopyEntitiesTable (xmlEntitiesTablePtr table);
|
||||||
|
#endif /* LIBXML_TREE_ENABLED */
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlFreeEntitiesTable (xmlEntitiesTablePtr table);
|
||||||
|
#ifdef LIBXML_OUTPUT_ENABLED
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlDumpEntitiesTable (xmlBufferPtr buf,
|
||||||
|
xmlEntitiesTablePtr table);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlDumpEntityDecl (xmlBufferPtr buf,
|
||||||
|
xmlEntityPtr ent);
|
||||||
|
#endif /* LIBXML_OUTPUT_ENABLED */
|
||||||
|
#ifdef LIBXML_LEGACY_ENABLED
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlCleanupPredefinedEntities(void);
|
||||||
|
#endif /* LIBXML_LEGACY_ENABLED */
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
# endif /* __XML_ENTITIES_H__ */
|
|
@ -0,0 +1,502 @@
|
||||||
|
/*
|
||||||
|
* Summary: interface for all global variables of the library
|
||||||
|
* Description: all the global variables and thread handling for
|
||||||
|
* those variables is handled by this module.
|
||||||
|
*
|
||||||
|
* The bottom of this file is automatically generated by build_glob.py
|
||||||
|
* based on the description file global.data
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Gary Pennington <Gary.Pennington@uk.sun.com>, Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_GLOBALS_H
|
||||||
|
#define __XML_GLOBALS_H
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
#include <libxml/parser.h>
|
||||||
|
#include <libxml/xmlerror.h>
|
||||||
|
#include <libxml/SAX.h>
|
||||||
|
#include <libxml/SAX2.h>
|
||||||
|
#include <libxml/xmlmemory.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL xmlInitGlobals(void);
|
||||||
|
XMLPUBFUN void XMLCALL xmlCleanupGlobals(void);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlParserInputBufferCreateFilenameFunc:
|
||||||
|
* @URI: the URI to read from
|
||||||
|
* @enc: the requested source encoding
|
||||||
|
*
|
||||||
|
* Signature for the function doing the lookup for a suitable input method
|
||||||
|
* corresponding to an URI.
|
||||||
|
*
|
||||||
|
* Returns the new xmlParserInputBufferPtr in case of success or NULL if no
|
||||||
|
* method was found.
|
||||||
|
*/
|
||||||
|
typedef xmlParserInputBufferPtr (*xmlParserInputBufferCreateFilenameFunc) (const char *URI, xmlCharEncoding enc);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlOutputBufferCreateFilenameFunc:
|
||||||
|
* @URI: the URI to write to
|
||||||
|
* @enc: the requested target encoding
|
||||||
|
*
|
||||||
|
* Signature for the function doing the lookup for a suitable output method
|
||||||
|
* corresponding to an URI.
|
||||||
|
*
|
||||||
|
* Returns the new xmlOutputBufferPtr in case of success or NULL if no
|
||||||
|
* method was found.
|
||||||
|
*/
|
||||||
|
typedef xmlOutputBufferPtr (*xmlOutputBufferCreateFilenameFunc) (const char *URI, xmlCharEncodingHandlerPtr encoder, int compression);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlParserInputBufferCreateFilenameFunc
|
||||||
|
XMLCALL xmlParserInputBufferCreateFilenameDefault (xmlParserInputBufferCreateFilenameFunc func);
|
||||||
|
XMLPUBFUN xmlOutputBufferCreateFilenameFunc
|
||||||
|
XMLCALL xmlOutputBufferCreateFilenameDefault (xmlOutputBufferCreateFilenameFunc func);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Externally global symbols which need to be protected for backwards
|
||||||
|
* compatibility support.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#undef docbDefaultSAXHandler
|
||||||
|
#undef htmlDefaultSAXHandler
|
||||||
|
#undef oldXMLWDcompatibility
|
||||||
|
#undef xmlBufferAllocScheme
|
||||||
|
#undef xmlDefaultBufferSize
|
||||||
|
#undef xmlDefaultSAXHandler
|
||||||
|
#undef xmlDefaultSAXLocator
|
||||||
|
#undef xmlDoValidityCheckingDefaultValue
|
||||||
|
#undef xmlFree
|
||||||
|
#undef xmlGenericError
|
||||||
|
#undef xmlStructuredError
|
||||||
|
#undef xmlGenericErrorContext
|
||||||
|
#undef xmlStructuredErrorContext
|
||||||
|
#undef xmlGetWarningsDefaultValue
|
||||||
|
#undef xmlIndentTreeOutput
|
||||||
|
#undef xmlTreeIndentString
|
||||||
|
#undef xmlKeepBlanksDefaultValue
|
||||||
|
#undef xmlLineNumbersDefaultValue
|
||||||
|
#undef xmlLoadExtDtdDefaultValue
|
||||||
|
#undef xmlMalloc
|
||||||
|
#undef xmlMallocAtomic
|
||||||
|
#undef xmlMemStrdup
|
||||||
|
#undef xmlParserDebugEntities
|
||||||
|
#undef xmlParserVersion
|
||||||
|
#undef xmlPedanticParserDefaultValue
|
||||||
|
#undef xmlRealloc
|
||||||
|
#undef xmlSaveNoEmptyTags
|
||||||
|
#undef xmlSubstituteEntitiesDefaultValue
|
||||||
|
#undef xmlRegisterNodeDefaultValue
|
||||||
|
#undef xmlDeregisterNodeDefaultValue
|
||||||
|
#undef xmlLastError
|
||||||
|
#undef xmlParserInputBufferCreateFilenameValue
|
||||||
|
#undef xmlOutputBufferCreateFilenameValue
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlRegisterNodeFunc:
|
||||||
|
* @node: the current node
|
||||||
|
*
|
||||||
|
* Signature for the registration callback of a created node
|
||||||
|
*/
|
||||||
|
typedef void (*xmlRegisterNodeFunc) (xmlNodePtr node);
|
||||||
|
/**
|
||||||
|
* xmlDeregisterNodeFunc:
|
||||||
|
* @node: the current node
|
||||||
|
*
|
||||||
|
* Signature for the deregistration callback of a discarded node
|
||||||
|
*/
|
||||||
|
typedef void (*xmlDeregisterNodeFunc) (xmlNodePtr node);
|
||||||
|
|
||||||
|
typedef struct _xmlGlobalState xmlGlobalState;
|
||||||
|
typedef xmlGlobalState *xmlGlobalStatePtr;
|
||||||
|
struct _xmlGlobalState
|
||||||
|
{
|
||||||
|
const char *xmlParserVersion;
|
||||||
|
|
||||||
|
xmlSAXLocator xmlDefaultSAXLocator;
|
||||||
|
xmlSAXHandlerV1 xmlDefaultSAXHandler;
|
||||||
|
xmlSAXHandlerV1 docbDefaultSAXHandler;
|
||||||
|
xmlSAXHandlerV1 htmlDefaultSAXHandler;
|
||||||
|
|
||||||
|
xmlFreeFunc xmlFree;
|
||||||
|
xmlMallocFunc xmlMalloc;
|
||||||
|
xmlStrdupFunc xmlMemStrdup;
|
||||||
|
xmlReallocFunc xmlRealloc;
|
||||||
|
|
||||||
|
xmlGenericErrorFunc xmlGenericError;
|
||||||
|
xmlStructuredErrorFunc xmlStructuredError;
|
||||||
|
void *xmlGenericErrorContext;
|
||||||
|
|
||||||
|
int oldXMLWDcompatibility;
|
||||||
|
|
||||||
|
xmlBufferAllocationScheme xmlBufferAllocScheme;
|
||||||
|
int xmlDefaultBufferSize;
|
||||||
|
|
||||||
|
int xmlSubstituteEntitiesDefaultValue;
|
||||||
|
int xmlDoValidityCheckingDefaultValue;
|
||||||
|
int xmlGetWarningsDefaultValue;
|
||||||
|
int xmlKeepBlanksDefaultValue;
|
||||||
|
int xmlLineNumbersDefaultValue;
|
||||||
|
int xmlLoadExtDtdDefaultValue;
|
||||||
|
int xmlParserDebugEntities;
|
||||||
|
int xmlPedanticParserDefaultValue;
|
||||||
|
|
||||||
|
int xmlSaveNoEmptyTags;
|
||||||
|
int xmlIndentTreeOutput;
|
||||||
|
const char *xmlTreeIndentString;
|
||||||
|
|
||||||
|
xmlRegisterNodeFunc xmlRegisterNodeDefaultValue;
|
||||||
|
xmlDeregisterNodeFunc xmlDeregisterNodeDefaultValue;
|
||||||
|
|
||||||
|
xmlMallocFunc xmlMallocAtomic;
|
||||||
|
xmlError xmlLastError;
|
||||||
|
|
||||||
|
xmlParserInputBufferCreateFilenameFunc xmlParserInputBufferCreateFilenameValue;
|
||||||
|
xmlOutputBufferCreateFilenameFunc xmlOutputBufferCreateFilenameValue;
|
||||||
|
|
||||||
|
void *xmlStructuredErrorContext;
|
||||||
|
};
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#include <libxml/threads.h>
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL xmlInitializeGlobalState(xmlGlobalStatePtr gs);
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL xmlThrDefSetGenericErrorFunc(void *ctx, xmlGenericErrorFunc handler);
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL xmlThrDefSetStructuredErrorFunc(void *ctx, xmlStructuredErrorFunc handler);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlRegisterNodeFunc XMLCALL xmlRegisterNodeDefault(xmlRegisterNodeFunc func);
|
||||||
|
XMLPUBFUN xmlRegisterNodeFunc XMLCALL xmlThrDefRegisterNodeDefault(xmlRegisterNodeFunc func);
|
||||||
|
XMLPUBFUN xmlDeregisterNodeFunc XMLCALL xmlDeregisterNodeDefault(xmlDeregisterNodeFunc func);
|
||||||
|
XMLPUBFUN xmlDeregisterNodeFunc XMLCALL xmlThrDefDeregisterNodeDefault(xmlDeregisterNodeFunc func);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlOutputBufferCreateFilenameFunc XMLCALL
|
||||||
|
xmlThrDefOutputBufferCreateFilenameDefault(xmlOutputBufferCreateFilenameFunc func);
|
||||||
|
XMLPUBFUN xmlParserInputBufferCreateFilenameFunc XMLCALL
|
||||||
|
xmlThrDefParserInputBufferCreateFilenameDefault(xmlParserInputBufferCreateFilenameFunc func);
|
||||||
|
|
||||||
|
/** DOC_DISABLE */
|
||||||
|
/*
|
||||||
|
* In general the memory allocation entry points are not kept
|
||||||
|
* thread specific but this can be overridden by LIBXML_THREAD_ALLOC_ENABLED
|
||||||
|
* - xmlMalloc
|
||||||
|
* - xmlMallocAtomic
|
||||||
|
* - xmlRealloc
|
||||||
|
* - xmlMemStrdup
|
||||||
|
* - xmlFree
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifdef LIBXML_THREAD_ALLOC_ENABLED
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
XMLPUBFUN xmlMallocFunc * XMLCALL __xmlMalloc(void);
|
||||||
|
#define xmlMalloc \
|
||||||
|
(*(__xmlMalloc()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR xmlMallocFunc xmlMalloc;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
XMLPUBFUN xmlMallocFunc * XMLCALL __xmlMallocAtomic(void);
|
||||||
|
#define xmlMallocAtomic \
|
||||||
|
(*(__xmlMallocAtomic()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR xmlMallocFunc xmlMallocAtomic;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
XMLPUBFUN xmlReallocFunc * XMLCALL __xmlRealloc(void);
|
||||||
|
#define xmlRealloc \
|
||||||
|
(*(__xmlRealloc()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR xmlReallocFunc xmlRealloc;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
XMLPUBFUN xmlFreeFunc * XMLCALL __xmlFree(void);
|
||||||
|
#define xmlFree \
|
||||||
|
(*(__xmlFree()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR xmlFreeFunc xmlFree;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
XMLPUBFUN xmlStrdupFunc * XMLCALL __xmlMemStrdup(void);
|
||||||
|
#define xmlMemStrdup \
|
||||||
|
(*(__xmlMemStrdup()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR xmlStrdupFunc xmlMemStrdup;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#else /* !LIBXML_THREAD_ALLOC_ENABLED */
|
||||||
|
XMLPUBVAR xmlMallocFunc xmlMalloc;
|
||||||
|
XMLPUBVAR xmlMallocFunc xmlMallocAtomic;
|
||||||
|
XMLPUBVAR xmlReallocFunc xmlRealloc;
|
||||||
|
XMLPUBVAR xmlFreeFunc xmlFree;
|
||||||
|
XMLPUBVAR xmlStrdupFunc xmlMemStrdup;
|
||||||
|
#endif /* LIBXML_THREAD_ALLOC_ENABLED */
|
||||||
|
|
||||||
|
#ifdef LIBXML_DOCB_ENABLED
|
||||||
|
XMLPUBFUN xmlSAXHandlerV1 * XMLCALL __docbDefaultSAXHandler(void);
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
#define docbDefaultSAXHandler \
|
||||||
|
(*(__docbDefaultSAXHandler()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR xmlSAXHandlerV1 docbDefaultSAXHandler;
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef LIBXML_HTML_ENABLED
|
||||||
|
XMLPUBFUN xmlSAXHandlerV1 * XMLCALL __htmlDefaultSAXHandler(void);
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
#define htmlDefaultSAXHandler \
|
||||||
|
(*(__htmlDefaultSAXHandler()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR xmlSAXHandlerV1 htmlDefaultSAXHandler;
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
XMLPUBFUN xmlError * XMLCALL __xmlLastError(void);
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
#define xmlLastError \
|
||||||
|
(*(__xmlLastError()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR xmlError xmlLastError;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Everything starting from the line below is
|
||||||
|
* Automatically generated by build_glob.py.
|
||||||
|
* Do not modify the previous line.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
XMLPUBFUN int * XMLCALL __oldXMLWDcompatibility(void);
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
#define oldXMLWDcompatibility \
|
||||||
|
(*(__oldXMLWDcompatibility()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR int oldXMLWDcompatibility;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
XMLPUBFUN xmlBufferAllocationScheme * XMLCALL __xmlBufferAllocScheme(void);
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
#define xmlBufferAllocScheme \
|
||||||
|
(*(__xmlBufferAllocScheme()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR xmlBufferAllocationScheme xmlBufferAllocScheme;
|
||||||
|
#endif
|
||||||
|
XMLPUBFUN xmlBufferAllocationScheme XMLCALL xmlThrDefBufferAllocScheme(xmlBufferAllocationScheme v);
|
||||||
|
|
||||||
|
XMLPUBFUN int * XMLCALL __xmlDefaultBufferSize(void);
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
#define xmlDefaultBufferSize \
|
||||||
|
(*(__xmlDefaultBufferSize()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR int xmlDefaultBufferSize;
|
||||||
|
#endif
|
||||||
|
XMLPUBFUN int XMLCALL xmlThrDefDefaultBufferSize(int v);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlSAXHandlerV1 * XMLCALL __xmlDefaultSAXHandler(void);
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
#define xmlDefaultSAXHandler \
|
||||||
|
(*(__xmlDefaultSAXHandler()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR xmlSAXHandlerV1 xmlDefaultSAXHandler;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
XMLPUBFUN xmlSAXLocator * XMLCALL __xmlDefaultSAXLocator(void);
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
#define xmlDefaultSAXLocator \
|
||||||
|
(*(__xmlDefaultSAXLocator()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR xmlSAXLocator xmlDefaultSAXLocator;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
XMLPUBFUN int * XMLCALL __xmlDoValidityCheckingDefaultValue(void);
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
#define xmlDoValidityCheckingDefaultValue \
|
||||||
|
(*(__xmlDoValidityCheckingDefaultValue()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR int xmlDoValidityCheckingDefaultValue;
|
||||||
|
#endif
|
||||||
|
XMLPUBFUN int XMLCALL xmlThrDefDoValidityCheckingDefaultValue(int v);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlGenericErrorFunc * XMLCALL __xmlGenericError(void);
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
#define xmlGenericError \
|
||||||
|
(*(__xmlGenericError()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR xmlGenericErrorFunc xmlGenericError;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
XMLPUBFUN xmlStructuredErrorFunc * XMLCALL __xmlStructuredError(void);
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
#define xmlStructuredError \
|
||||||
|
(*(__xmlStructuredError()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR xmlStructuredErrorFunc xmlStructuredError;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
XMLPUBFUN void * * XMLCALL __xmlGenericErrorContext(void);
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
#define xmlGenericErrorContext \
|
||||||
|
(*(__xmlGenericErrorContext()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR void * xmlGenericErrorContext;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
XMLPUBFUN void * * XMLCALL __xmlStructuredErrorContext(void);
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
#define xmlStructuredErrorContext \
|
||||||
|
(*(__xmlStructuredErrorContext()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR void * xmlStructuredErrorContext;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
XMLPUBFUN int * XMLCALL __xmlGetWarningsDefaultValue(void);
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
#define xmlGetWarningsDefaultValue \
|
||||||
|
(*(__xmlGetWarningsDefaultValue()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR int xmlGetWarningsDefaultValue;
|
||||||
|
#endif
|
||||||
|
XMLPUBFUN int XMLCALL xmlThrDefGetWarningsDefaultValue(int v);
|
||||||
|
|
||||||
|
XMLPUBFUN int * XMLCALL __xmlIndentTreeOutput(void);
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
#define xmlIndentTreeOutput \
|
||||||
|
(*(__xmlIndentTreeOutput()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR int xmlIndentTreeOutput;
|
||||||
|
#endif
|
||||||
|
XMLPUBFUN int XMLCALL xmlThrDefIndentTreeOutput(int v);
|
||||||
|
|
||||||
|
XMLPUBFUN const char * * XMLCALL __xmlTreeIndentString(void);
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
#define xmlTreeIndentString \
|
||||||
|
(*(__xmlTreeIndentString()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR const char * xmlTreeIndentString;
|
||||||
|
#endif
|
||||||
|
XMLPUBFUN const char * XMLCALL xmlThrDefTreeIndentString(const char * v);
|
||||||
|
|
||||||
|
XMLPUBFUN int * XMLCALL __xmlKeepBlanksDefaultValue(void);
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
#define xmlKeepBlanksDefaultValue \
|
||||||
|
(*(__xmlKeepBlanksDefaultValue()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR int xmlKeepBlanksDefaultValue;
|
||||||
|
#endif
|
||||||
|
XMLPUBFUN int XMLCALL xmlThrDefKeepBlanksDefaultValue(int v);
|
||||||
|
|
||||||
|
XMLPUBFUN int * XMLCALL __xmlLineNumbersDefaultValue(void);
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
#define xmlLineNumbersDefaultValue \
|
||||||
|
(*(__xmlLineNumbersDefaultValue()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR int xmlLineNumbersDefaultValue;
|
||||||
|
#endif
|
||||||
|
XMLPUBFUN int XMLCALL xmlThrDefLineNumbersDefaultValue(int v);
|
||||||
|
|
||||||
|
XMLPUBFUN int * XMLCALL __xmlLoadExtDtdDefaultValue(void);
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
#define xmlLoadExtDtdDefaultValue \
|
||||||
|
(*(__xmlLoadExtDtdDefaultValue()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR int xmlLoadExtDtdDefaultValue;
|
||||||
|
#endif
|
||||||
|
XMLPUBFUN int XMLCALL xmlThrDefLoadExtDtdDefaultValue(int v);
|
||||||
|
|
||||||
|
XMLPUBFUN int * XMLCALL __xmlParserDebugEntities(void);
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
#define xmlParserDebugEntities \
|
||||||
|
(*(__xmlParserDebugEntities()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR int xmlParserDebugEntities;
|
||||||
|
#endif
|
||||||
|
XMLPUBFUN int XMLCALL xmlThrDefParserDebugEntities(int v);
|
||||||
|
|
||||||
|
XMLPUBFUN const char * * XMLCALL __xmlParserVersion(void);
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
#define xmlParserVersion \
|
||||||
|
(*(__xmlParserVersion()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR const char * xmlParserVersion;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
XMLPUBFUN int * XMLCALL __xmlPedanticParserDefaultValue(void);
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
#define xmlPedanticParserDefaultValue \
|
||||||
|
(*(__xmlPedanticParserDefaultValue()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR int xmlPedanticParserDefaultValue;
|
||||||
|
#endif
|
||||||
|
XMLPUBFUN int XMLCALL xmlThrDefPedanticParserDefaultValue(int v);
|
||||||
|
|
||||||
|
XMLPUBFUN int * XMLCALL __xmlSaveNoEmptyTags(void);
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
#define xmlSaveNoEmptyTags \
|
||||||
|
(*(__xmlSaveNoEmptyTags()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR int xmlSaveNoEmptyTags;
|
||||||
|
#endif
|
||||||
|
XMLPUBFUN int XMLCALL xmlThrDefSaveNoEmptyTags(int v);
|
||||||
|
|
||||||
|
XMLPUBFUN int * XMLCALL __xmlSubstituteEntitiesDefaultValue(void);
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
#define xmlSubstituteEntitiesDefaultValue \
|
||||||
|
(*(__xmlSubstituteEntitiesDefaultValue()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR int xmlSubstituteEntitiesDefaultValue;
|
||||||
|
#endif
|
||||||
|
XMLPUBFUN int XMLCALL xmlThrDefSubstituteEntitiesDefaultValue(int v);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlRegisterNodeFunc * XMLCALL __xmlRegisterNodeDefaultValue(void);
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
#define xmlRegisterNodeDefaultValue \
|
||||||
|
(*(__xmlRegisterNodeDefaultValue()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR xmlRegisterNodeFunc xmlRegisterNodeDefaultValue;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
XMLPUBFUN xmlDeregisterNodeFunc * XMLCALL __xmlDeregisterNodeDefaultValue(void);
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
#define xmlDeregisterNodeDefaultValue \
|
||||||
|
(*(__xmlDeregisterNodeDefaultValue()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR xmlDeregisterNodeFunc xmlDeregisterNodeDefaultValue;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
XMLPUBFUN xmlParserInputBufferCreateFilenameFunc * XMLCALL __xmlParserInputBufferCreateFilenameValue(void);
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
#define xmlParserInputBufferCreateFilenameValue \
|
||||||
|
(*(__xmlParserInputBufferCreateFilenameValue()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR xmlParserInputBufferCreateFilenameFunc xmlParserInputBufferCreateFilenameValue;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
XMLPUBFUN xmlOutputBufferCreateFilenameFunc * XMLCALL __xmlOutputBufferCreateFilenameValue(void);
|
||||||
|
#ifdef LIBXML_THREAD_ENABLED
|
||||||
|
#define xmlOutputBufferCreateFilenameValue \
|
||||||
|
(*(__xmlOutputBufferCreateFilenameValue()))
|
||||||
|
#else
|
||||||
|
XMLPUBVAR xmlOutputBufferCreateFilenameFunc xmlOutputBufferCreateFilenameValue;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* __XML_GLOBALS_H */
|
|
@ -0,0 +1,233 @@
|
||||||
|
/*
|
||||||
|
* Summary: Chained hash tables
|
||||||
|
* Description: This module implements the hash table support used in
|
||||||
|
* various places in the library.
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Bjorn Reese <bjorn.reese@systematic.dk>
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_HASH_H__
|
||||||
|
#define __XML_HASH_H__
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The hash table.
|
||||||
|
*/
|
||||||
|
typedef struct _xmlHashTable xmlHashTable;
|
||||||
|
typedef xmlHashTable *xmlHashTablePtr;
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
#include <libxml/parser.h>
|
||||||
|
#include <libxml/dict.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Recent version of gcc produce a warning when a function pointer is assigned
|
||||||
|
* to an object pointer, or vice versa. The following macro is a dirty hack
|
||||||
|
* to allow suppression of the warning. If your architecture has function
|
||||||
|
* pointers which are a different size than a void pointer, there may be some
|
||||||
|
* serious trouble within the library.
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* XML_CAST_FPTR:
|
||||||
|
* @fptr: pointer to a function
|
||||||
|
*
|
||||||
|
* Macro to do a casting from an object pointer to a
|
||||||
|
* function pointer without encountering a warning from
|
||||||
|
* gcc
|
||||||
|
*
|
||||||
|
* #define XML_CAST_FPTR(fptr) (*(void **)(&fptr))
|
||||||
|
* This macro violated ISO C aliasing rules (gcc4 on s390 broke)
|
||||||
|
* so it is disabled now
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define XML_CAST_FPTR(fptr) fptr
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* function types:
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* xmlHashDeallocator:
|
||||||
|
* @payload: the data in the hash
|
||||||
|
* @name: the name associated
|
||||||
|
*
|
||||||
|
* Callback to free data from a hash.
|
||||||
|
*/
|
||||||
|
typedef void (*xmlHashDeallocator)(void *payload, xmlChar *name);
|
||||||
|
/**
|
||||||
|
* xmlHashCopier:
|
||||||
|
* @payload: the data in the hash
|
||||||
|
* @name: the name associated
|
||||||
|
*
|
||||||
|
* Callback to copy data from a hash.
|
||||||
|
*
|
||||||
|
* Returns a copy of the data or NULL in case of error.
|
||||||
|
*/
|
||||||
|
typedef void *(*xmlHashCopier)(void *payload, xmlChar *name);
|
||||||
|
/**
|
||||||
|
* xmlHashScanner:
|
||||||
|
* @payload: the data in the hash
|
||||||
|
* @data: extra scannner data
|
||||||
|
* @name: the name associated
|
||||||
|
*
|
||||||
|
* Callback when scanning data in a hash with the simple scanner.
|
||||||
|
*/
|
||||||
|
typedef void (*xmlHashScanner)(void *payload, void *data, xmlChar *name);
|
||||||
|
/**
|
||||||
|
* xmlHashScannerFull:
|
||||||
|
* @payload: the data in the hash
|
||||||
|
* @data: extra scannner data
|
||||||
|
* @name: the name associated
|
||||||
|
* @name2: the second name associated
|
||||||
|
* @name3: the third name associated
|
||||||
|
*
|
||||||
|
* Callback when scanning data in a hash with the full scanner.
|
||||||
|
*/
|
||||||
|
typedef void (*xmlHashScannerFull)(void *payload, void *data,
|
||||||
|
const xmlChar *name, const xmlChar *name2,
|
||||||
|
const xmlChar *name3);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Constructor and destructor.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlHashTablePtr XMLCALL
|
||||||
|
xmlHashCreate (int size);
|
||||||
|
XMLPUBFUN xmlHashTablePtr XMLCALL
|
||||||
|
xmlHashCreateDict(int size,
|
||||||
|
xmlDictPtr dict);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlHashFree (xmlHashTablePtr table,
|
||||||
|
xmlHashDeallocator f);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Add a new entry to the hash table.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlHashAddEntry (xmlHashTablePtr table,
|
||||||
|
const xmlChar *name,
|
||||||
|
void *userdata);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlHashUpdateEntry(xmlHashTablePtr table,
|
||||||
|
const xmlChar *name,
|
||||||
|
void *userdata,
|
||||||
|
xmlHashDeallocator f);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlHashAddEntry2(xmlHashTablePtr table,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *name2,
|
||||||
|
void *userdata);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlHashUpdateEntry2(xmlHashTablePtr table,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *name2,
|
||||||
|
void *userdata,
|
||||||
|
xmlHashDeallocator f);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlHashAddEntry3(xmlHashTablePtr table,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *name2,
|
||||||
|
const xmlChar *name3,
|
||||||
|
void *userdata);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlHashUpdateEntry3(xmlHashTablePtr table,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *name2,
|
||||||
|
const xmlChar *name3,
|
||||||
|
void *userdata,
|
||||||
|
xmlHashDeallocator f);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Remove an entry from the hash table.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlHashRemoveEntry(xmlHashTablePtr table, const xmlChar *name,
|
||||||
|
xmlHashDeallocator f);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlHashRemoveEntry2(xmlHashTablePtr table, const xmlChar *name,
|
||||||
|
const xmlChar *name2, xmlHashDeallocator f);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlHashRemoveEntry3(xmlHashTablePtr table, const xmlChar *name,
|
||||||
|
const xmlChar *name2, const xmlChar *name3,
|
||||||
|
xmlHashDeallocator f);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Retrieve the userdata.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN void * XMLCALL
|
||||||
|
xmlHashLookup (xmlHashTablePtr table,
|
||||||
|
const xmlChar *name);
|
||||||
|
XMLPUBFUN void * XMLCALL
|
||||||
|
xmlHashLookup2 (xmlHashTablePtr table,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *name2);
|
||||||
|
XMLPUBFUN void * XMLCALL
|
||||||
|
xmlHashLookup3 (xmlHashTablePtr table,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *name2,
|
||||||
|
const xmlChar *name3);
|
||||||
|
XMLPUBFUN void * XMLCALL
|
||||||
|
xmlHashQLookup (xmlHashTablePtr table,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *prefix);
|
||||||
|
XMLPUBFUN void * XMLCALL
|
||||||
|
xmlHashQLookup2 (xmlHashTablePtr table,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *prefix,
|
||||||
|
const xmlChar *name2,
|
||||||
|
const xmlChar *prefix2);
|
||||||
|
XMLPUBFUN void * XMLCALL
|
||||||
|
xmlHashQLookup3 (xmlHashTablePtr table,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *prefix,
|
||||||
|
const xmlChar *name2,
|
||||||
|
const xmlChar *prefix2,
|
||||||
|
const xmlChar *name3,
|
||||||
|
const xmlChar *prefix3);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Helpers.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlHashTablePtr XMLCALL
|
||||||
|
xmlHashCopy (xmlHashTablePtr table,
|
||||||
|
xmlHashCopier f);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlHashSize (xmlHashTablePtr table);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlHashScan (xmlHashTablePtr table,
|
||||||
|
xmlHashScanner f,
|
||||||
|
void *data);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlHashScan3 (xmlHashTablePtr table,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *name2,
|
||||||
|
const xmlChar *name3,
|
||||||
|
xmlHashScanner f,
|
||||||
|
void *data);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlHashScanFull (xmlHashTablePtr table,
|
||||||
|
xmlHashScannerFull f,
|
||||||
|
void *data);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlHashScanFull3(xmlHashTablePtr table,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *name2,
|
||||||
|
const xmlChar *name3,
|
||||||
|
xmlHashScannerFull f,
|
||||||
|
void *data);
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif /* ! __XML_HASH_H__ */
|
|
@ -0,0 +1,137 @@
|
||||||
|
/*
|
||||||
|
* Summary: lists interfaces
|
||||||
|
* Description: this module implement the list support used in
|
||||||
|
* various place in the library.
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Gary Pennington <Gary.Pennington@uk.sun.com>
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_LINK_INCLUDE__
|
||||||
|
#define __XML_LINK_INCLUDE__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef struct _xmlLink xmlLink;
|
||||||
|
typedef xmlLink *xmlLinkPtr;
|
||||||
|
|
||||||
|
typedef struct _xmlList xmlList;
|
||||||
|
typedef xmlList *xmlListPtr;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlListDeallocator:
|
||||||
|
* @lk: the data to deallocate
|
||||||
|
*
|
||||||
|
* Callback function used to free data from a list.
|
||||||
|
*/
|
||||||
|
typedef void (*xmlListDeallocator) (xmlLinkPtr lk);
|
||||||
|
/**
|
||||||
|
* xmlListDataCompare:
|
||||||
|
* @data0: the first data
|
||||||
|
* @data1: the second data
|
||||||
|
*
|
||||||
|
* Callback function used to compare 2 data.
|
||||||
|
*
|
||||||
|
* Returns 0 is equality, -1 or 1 otherwise depending on the ordering.
|
||||||
|
*/
|
||||||
|
typedef int (*xmlListDataCompare) (const void *data0, const void *data1);
|
||||||
|
/**
|
||||||
|
* xmlListWalker:
|
||||||
|
* @data: the data found in the list
|
||||||
|
* @user: extra user provided data to the walker
|
||||||
|
*
|
||||||
|
* Callback function used when walking a list with xmlListWalk().
|
||||||
|
*
|
||||||
|
* Returns 0 to stop walking the list, 1 otherwise.
|
||||||
|
*/
|
||||||
|
typedef int (*xmlListWalker) (const void *data, const void *user);
|
||||||
|
|
||||||
|
/* Creation/Deletion */
|
||||||
|
XMLPUBFUN xmlListPtr XMLCALL
|
||||||
|
xmlListCreate (xmlListDeallocator deallocator,
|
||||||
|
xmlListDataCompare compare);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlListDelete (xmlListPtr l);
|
||||||
|
|
||||||
|
/* Basic Operators */
|
||||||
|
XMLPUBFUN void * XMLCALL
|
||||||
|
xmlListSearch (xmlListPtr l,
|
||||||
|
void *data);
|
||||||
|
XMLPUBFUN void * XMLCALL
|
||||||
|
xmlListReverseSearch (xmlListPtr l,
|
||||||
|
void *data);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlListInsert (xmlListPtr l,
|
||||||
|
void *data) ;
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlListAppend (xmlListPtr l,
|
||||||
|
void *data) ;
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlListRemoveFirst (xmlListPtr l,
|
||||||
|
void *data);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlListRemoveLast (xmlListPtr l,
|
||||||
|
void *data);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlListRemoveAll (xmlListPtr l,
|
||||||
|
void *data);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlListClear (xmlListPtr l);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlListEmpty (xmlListPtr l);
|
||||||
|
XMLPUBFUN xmlLinkPtr XMLCALL
|
||||||
|
xmlListFront (xmlListPtr l);
|
||||||
|
XMLPUBFUN xmlLinkPtr XMLCALL
|
||||||
|
xmlListEnd (xmlListPtr l);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlListSize (xmlListPtr l);
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlListPopFront (xmlListPtr l);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlListPopBack (xmlListPtr l);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlListPushFront (xmlListPtr l,
|
||||||
|
void *data);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlListPushBack (xmlListPtr l,
|
||||||
|
void *data);
|
||||||
|
|
||||||
|
/* Advanced Operators */
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlListReverse (xmlListPtr l);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlListSort (xmlListPtr l);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlListWalk (xmlListPtr l,
|
||||||
|
xmlListWalker walker,
|
||||||
|
const void *user);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlListReverseWalk (xmlListPtr l,
|
||||||
|
xmlListWalker walker,
|
||||||
|
const void *user);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlListMerge (xmlListPtr l1,
|
||||||
|
xmlListPtr l2);
|
||||||
|
XMLPUBFUN xmlListPtr XMLCALL
|
||||||
|
xmlListDup (const xmlListPtr old);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlListCopy (xmlListPtr cur,
|
||||||
|
const xmlListPtr old);
|
||||||
|
/* Link operators */
|
||||||
|
XMLPUBFUN void * XMLCALL
|
||||||
|
xmlLinkGetData (xmlLinkPtr lk);
|
||||||
|
|
||||||
|
/* xmlListUnique() */
|
||||||
|
/* xmlListSwap */
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* __XML_LINK_INCLUDE__ */
|
|
@ -0,0 +1,162 @@
|
||||||
|
/*
|
||||||
|
* Summary: minimal FTP implementation
|
||||||
|
* Description: minimal FTP implementation allowing to fetch resources
|
||||||
|
* like external subset.
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __NANO_FTP_H__
|
||||||
|
#define __NANO_FTP_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
|
||||||
|
#ifdef LIBXML_FTP_ENABLED
|
||||||
|
|
||||||
|
/* Needed for portability to Windows 64 bits */
|
||||||
|
#if defined(__MINGW32__) || defined(_WIN32_WCE)
|
||||||
|
#include <winsock2.h>
|
||||||
|
#else
|
||||||
|
/**
|
||||||
|
* SOCKET:
|
||||||
|
*
|
||||||
|
* macro used to provide portability of code to windows sockets
|
||||||
|
*/
|
||||||
|
#define SOCKET int
|
||||||
|
/**
|
||||||
|
* INVALID_SOCKET:
|
||||||
|
*
|
||||||
|
* macro used to provide portability of code to windows sockets
|
||||||
|
* the value to be used when the socket is not valid
|
||||||
|
*/
|
||||||
|
#define INVALID_SOCKET (-1)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ftpListCallback:
|
||||||
|
* @userData: user provided data for the callback
|
||||||
|
* @filename: the file name (including "->" when links are shown)
|
||||||
|
* @attrib: the attribute string
|
||||||
|
* @owner: the owner string
|
||||||
|
* @group: the group string
|
||||||
|
* @size: the file size
|
||||||
|
* @links: the link count
|
||||||
|
* @year: the year
|
||||||
|
* @month: the month
|
||||||
|
* @day: the day
|
||||||
|
* @hour: the hour
|
||||||
|
* @minute: the minute
|
||||||
|
*
|
||||||
|
* A callback for the xmlNanoFTPList command.
|
||||||
|
* Note that only one of year and day:minute are specified.
|
||||||
|
*/
|
||||||
|
typedef void (*ftpListCallback) (void *userData,
|
||||||
|
const char *filename, const char *attrib,
|
||||||
|
const char *owner, const char *group,
|
||||||
|
unsigned long size, int links, int year,
|
||||||
|
const char *month, int day, int hour,
|
||||||
|
int minute);
|
||||||
|
/**
|
||||||
|
* ftpDataCallback:
|
||||||
|
* @userData: the user provided context
|
||||||
|
* @data: the data received
|
||||||
|
* @len: its size in bytes
|
||||||
|
*
|
||||||
|
* A callback for the xmlNanoFTPGet command.
|
||||||
|
*/
|
||||||
|
typedef void (*ftpDataCallback) (void *userData,
|
||||||
|
const char *data,
|
||||||
|
int len);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Init
|
||||||
|
*/
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlNanoFTPInit (void);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlNanoFTPCleanup (void);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Creating/freeing contexts.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN void * XMLCALL
|
||||||
|
xmlNanoFTPNewCtxt (const char *URL);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlNanoFTPFreeCtxt (void * ctx);
|
||||||
|
XMLPUBFUN void * XMLCALL
|
||||||
|
xmlNanoFTPConnectTo (const char *server,
|
||||||
|
int port);
|
||||||
|
/*
|
||||||
|
* Opening/closing session connections.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN void * XMLCALL
|
||||||
|
xmlNanoFTPOpen (const char *URL);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlNanoFTPConnect (void *ctx);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlNanoFTPClose (void *ctx);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlNanoFTPQuit (void *ctx);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlNanoFTPScanProxy (const char *URL);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlNanoFTPProxy (const char *host,
|
||||||
|
int port,
|
||||||
|
const char *user,
|
||||||
|
const char *passwd,
|
||||||
|
int type);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlNanoFTPUpdateURL (void *ctx,
|
||||||
|
const char *URL);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Rather internal commands.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlNanoFTPGetResponse (void *ctx);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlNanoFTPCheckResponse (void *ctx);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* CD/DIR/GET handlers.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlNanoFTPCwd (void *ctx,
|
||||||
|
const char *directory);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlNanoFTPDele (void *ctx,
|
||||||
|
const char *file);
|
||||||
|
|
||||||
|
XMLPUBFUN SOCKET XMLCALL
|
||||||
|
xmlNanoFTPGetConnection (void *ctx);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlNanoFTPCloseConnection(void *ctx);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlNanoFTPList (void *ctx,
|
||||||
|
ftpListCallback callback,
|
||||||
|
void *userData,
|
||||||
|
const char *filename);
|
||||||
|
XMLPUBFUN SOCKET XMLCALL
|
||||||
|
xmlNanoFTPGetSocket (void *ctx,
|
||||||
|
const char *filename);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlNanoFTPGet (void *ctx,
|
||||||
|
ftpDataCallback callback,
|
||||||
|
void *userData,
|
||||||
|
const char *filename);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlNanoFTPRead (void *ctx,
|
||||||
|
void *dest,
|
||||||
|
int len);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif /* LIBXML_FTP_ENABLED */
|
||||||
|
#endif /* __NANO_FTP_H__ */
|
|
@ -0,0 +1,81 @@
|
||||||
|
/*
|
||||||
|
* Summary: minimal HTTP implementation
|
||||||
|
* Description: minimal HTTP implementation allowing to fetch resources
|
||||||
|
* like external subset.
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __NANO_HTTP_H__
|
||||||
|
#define __NANO_HTTP_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
|
||||||
|
#ifdef LIBXML_HTTP_ENABLED
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlNanoHTTPInit (void);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlNanoHTTPCleanup (void);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlNanoHTTPScanProxy (const char *URL);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlNanoHTTPFetch (const char *URL,
|
||||||
|
const char *filename,
|
||||||
|
char **contentType);
|
||||||
|
XMLPUBFUN void * XMLCALL
|
||||||
|
xmlNanoHTTPMethod (const char *URL,
|
||||||
|
const char *method,
|
||||||
|
const char *input,
|
||||||
|
char **contentType,
|
||||||
|
const char *headers,
|
||||||
|
int ilen);
|
||||||
|
XMLPUBFUN void * XMLCALL
|
||||||
|
xmlNanoHTTPMethodRedir (const char *URL,
|
||||||
|
const char *method,
|
||||||
|
const char *input,
|
||||||
|
char **contentType,
|
||||||
|
char **redir,
|
||||||
|
const char *headers,
|
||||||
|
int ilen);
|
||||||
|
XMLPUBFUN void * XMLCALL
|
||||||
|
xmlNanoHTTPOpen (const char *URL,
|
||||||
|
char **contentType);
|
||||||
|
XMLPUBFUN void * XMLCALL
|
||||||
|
xmlNanoHTTPOpenRedir (const char *URL,
|
||||||
|
char **contentType,
|
||||||
|
char **redir);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlNanoHTTPReturnCode (void *ctx);
|
||||||
|
XMLPUBFUN const char * XMLCALL
|
||||||
|
xmlNanoHTTPAuthHeader (void *ctx);
|
||||||
|
XMLPUBFUN const char * XMLCALL
|
||||||
|
xmlNanoHTTPRedir (void *ctx);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlNanoHTTPContentLength( void * ctx );
|
||||||
|
XMLPUBFUN const char * XMLCALL
|
||||||
|
xmlNanoHTTPEncoding (void *ctx);
|
||||||
|
XMLPUBFUN const char * XMLCALL
|
||||||
|
xmlNanoHTTPMimeType (void *ctx);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlNanoHTTPRead (void *ctx,
|
||||||
|
void *dest,
|
||||||
|
int len);
|
||||||
|
#ifdef LIBXML_OUTPUT_ENABLED
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlNanoHTTPSave (void *ctxt,
|
||||||
|
const char *filename);
|
||||||
|
#endif /* LIBXML_OUTPUT_ENABLED */
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlNanoHTTPClose (void *ctx);
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* LIBXML_HTTP_ENABLED */
|
||||||
|
#endif /* __NANO_HTTP_H__ */
|
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,611 @@
|
||||||
|
/*
|
||||||
|
* Summary: internals routines exported by the parser.
|
||||||
|
* Description: this module exports a number of internal parsing routines
|
||||||
|
* they are not really all intended for applications but
|
||||||
|
* can prove useful doing low level processing.
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_PARSER_INTERNALS_H__
|
||||||
|
#define __XML_PARSER_INTERNALS_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
#include <libxml/parser.h>
|
||||||
|
#include <libxml/HTMLparser.h>
|
||||||
|
#include <libxml/chvalid.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlParserMaxDepth:
|
||||||
|
*
|
||||||
|
* arbitrary depth limit for the XML documents that we allow to
|
||||||
|
* process. This is not a limitation of the parser but a safety
|
||||||
|
* boundary feature, use XML_PARSE_HUGE option to override it.
|
||||||
|
*/
|
||||||
|
XMLPUBVAR unsigned int xmlParserMaxDepth;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* XML_MAX_TEXT_LENGTH:
|
||||||
|
*
|
||||||
|
* Maximum size allowed for a single text node when building a tree.
|
||||||
|
* This is not a limitation of the parser but a safety boundary feature,
|
||||||
|
* use XML_PARSE_HUGE option to override it.
|
||||||
|
*/
|
||||||
|
#define XML_MAX_TEXT_LENGTH 10000000
|
||||||
|
|
||||||
|
/**
|
||||||
|
* XML_MAX_NAMELEN:
|
||||||
|
*
|
||||||
|
* Identifiers can be longer, but this will be more costly
|
||||||
|
* at runtime.
|
||||||
|
*/
|
||||||
|
#define XML_MAX_NAMELEN 100
|
||||||
|
|
||||||
|
/**
|
||||||
|
* INPUT_CHUNK:
|
||||||
|
*
|
||||||
|
* The parser tries to always have that amount of input ready.
|
||||||
|
* One of the point is providing context when reporting errors.
|
||||||
|
*/
|
||||||
|
#define INPUT_CHUNK 250
|
||||||
|
|
||||||
|
/************************************************************************
|
||||||
|
* *
|
||||||
|
* UNICODE version of the macros. *
|
||||||
|
* *
|
||||||
|
************************************************************************/
|
||||||
|
/**
|
||||||
|
* IS_BYTE_CHAR:
|
||||||
|
* @c: an byte value (int)
|
||||||
|
*
|
||||||
|
* Macro to check the following production in the XML spec:
|
||||||
|
*
|
||||||
|
* [2] Char ::= #x9 | #xA | #xD | [#x20...]
|
||||||
|
* any byte character in the accepted range
|
||||||
|
*/
|
||||||
|
#define IS_BYTE_CHAR(c) xmlIsChar_ch(c)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* IS_CHAR:
|
||||||
|
* @c: an UNICODE value (int)
|
||||||
|
*
|
||||||
|
* Macro to check the following production in the XML spec:
|
||||||
|
*
|
||||||
|
* [2] Char ::= #x9 | #xA | #xD | [#x20-#xD7FF] | [#xE000-#xFFFD]
|
||||||
|
* | [#x10000-#x10FFFF]
|
||||||
|
* any Unicode character, excluding the surrogate blocks, FFFE, and FFFF.
|
||||||
|
*/
|
||||||
|
#define IS_CHAR(c) xmlIsCharQ(c)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* IS_CHAR_CH:
|
||||||
|
* @c: an xmlChar (usually an unsigned char)
|
||||||
|
*
|
||||||
|
* Behaves like IS_CHAR on single-byte value
|
||||||
|
*/
|
||||||
|
#define IS_CHAR_CH(c) xmlIsChar_ch(c)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* IS_BLANK:
|
||||||
|
* @c: an UNICODE value (int)
|
||||||
|
*
|
||||||
|
* Macro to check the following production in the XML spec:
|
||||||
|
*
|
||||||
|
* [3] S ::= (#x20 | #x9 | #xD | #xA)+
|
||||||
|
*/
|
||||||
|
#define IS_BLANK(c) xmlIsBlankQ(c)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* IS_BLANK_CH:
|
||||||
|
* @c: an xmlChar value (normally unsigned char)
|
||||||
|
*
|
||||||
|
* Behaviour same as IS_BLANK
|
||||||
|
*/
|
||||||
|
#define IS_BLANK_CH(c) xmlIsBlank_ch(c)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* IS_BASECHAR:
|
||||||
|
* @c: an UNICODE value (int)
|
||||||
|
*
|
||||||
|
* Macro to check the following production in the XML spec:
|
||||||
|
*
|
||||||
|
* [85] BaseChar ::= ... long list see REC ...
|
||||||
|
*/
|
||||||
|
#define IS_BASECHAR(c) xmlIsBaseCharQ(c)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* IS_DIGIT:
|
||||||
|
* @c: an UNICODE value (int)
|
||||||
|
*
|
||||||
|
* Macro to check the following production in the XML spec:
|
||||||
|
*
|
||||||
|
* [88] Digit ::= ... long list see REC ...
|
||||||
|
*/
|
||||||
|
#define IS_DIGIT(c) xmlIsDigitQ(c)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* IS_DIGIT_CH:
|
||||||
|
* @c: an xmlChar value (usually an unsigned char)
|
||||||
|
*
|
||||||
|
* Behaves like IS_DIGIT but with a single byte argument
|
||||||
|
*/
|
||||||
|
#define IS_DIGIT_CH(c) xmlIsDigit_ch(c)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* IS_COMBINING:
|
||||||
|
* @c: an UNICODE value (int)
|
||||||
|
*
|
||||||
|
* Macro to check the following production in the XML spec:
|
||||||
|
*
|
||||||
|
* [87] CombiningChar ::= ... long list see REC ...
|
||||||
|
*/
|
||||||
|
#define IS_COMBINING(c) xmlIsCombiningQ(c)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* IS_COMBINING_CH:
|
||||||
|
* @c: an xmlChar (usually an unsigned char)
|
||||||
|
*
|
||||||
|
* Always false (all combining chars > 0xff)
|
||||||
|
*/
|
||||||
|
#define IS_COMBINING_CH(c) 0
|
||||||
|
|
||||||
|
/**
|
||||||
|
* IS_EXTENDER:
|
||||||
|
* @c: an UNICODE value (int)
|
||||||
|
*
|
||||||
|
* Macro to check the following production in the XML spec:
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* [89] Extender ::= #x00B7 | #x02D0 | #x02D1 | #x0387 | #x0640 |
|
||||||
|
* #x0E46 | #x0EC6 | #x3005 | [#x3031-#x3035] |
|
||||||
|
* [#x309D-#x309E] | [#x30FC-#x30FE]
|
||||||
|
*/
|
||||||
|
#define IS_EXTENDER(c) xmlIsExtenderQ(c)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* IS_EXTENDER_CH:
|
||||||
|
* @c: an xmlChar value (usually an unsigned char)
|
||||||
|
*
|
||||||
|
* Behaves like IS_EXTENDER but with a single-byte argument
|
||||||
|
*/
|
||||||
|
#define IS_EXTENDER_CH(c) xmlIsExtender_ch(c)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* IS_IDEOGRAPHIC:
|
||||||
|
* @c: an UNICODE value (int)
|
||||||
|
*
|
||||||
|
* Macro to check the following production in the XML spec:
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* [86] Ideographic ::= [#x4E00-#x9FA5] | #x3007 | [#x3021-#x3029]
|
||||||
|
*/
|
||||||
|
#define IS_IDEOGRAPHIC(c) xmlIsIdeographicQ(c)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* IS_LETTER:
|
||||||
|
* @c: an UNICODE value (int)
|
||||||
|
*
|
||||||
|
* Macro to check the following production in the XML spec:
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* [84] Letter ::= BaseChar | Ideographic
|
||||||
|
*/
|
||||||
|
#define IS_LETTER(c) (IS_BASECHAR(c) || IS_IDEOGRAPHIC(c))
|
||||||
|
|
||||||
|
/**
|
||||||
|
* IS_LETTER_CH:
|
||||||
|
* @c: an xmlChar value (normally unsigned char)
|
||||||
|
*
|
||||||
|
* Macro behaves like IS_LETTER, but only check base chars
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define IS_LETTER_CH(c) xmlIsBaseChar_ch(c)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* IS_ASCII_LETTER:
|
||||||
|
* @c: an xmlChar value
|
||||||
|
*
|
||||||
|
* Macro to check [a-zA-Z]
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define IS_ASCII_LETTER(c) (((0x41 <= (c)) && ((c) <= 0x5a)) || \
|
||||||
|
((0x61 <= (c)) && ((c) <= 0x7a)))
|
||||||
|
|
||||||
|
/**
|
||||||
|
* IS_ASCII_DIGIT:
|
||||||
|
* @c: an xmlChar value
|
||||||
|
*
|
||||||
|
* Macro to check [0-9]
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define IS_ASCII_DIGIT(c) ((0x30 <= (c)) && ((c) <= 0x39))
|
||||||
|
|
||||||
|
/**
|
||||||
|
* IS_PUBIDCHAR:
|
||||||
|
* @c: an UNICODE value (int)
|
||||||
|
*
|
||||||
|
* Macro to check the following production in the XML spec:
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* [13] PubidChar ::= #x20 | #xD | #xA | [a-zA-Z0-9] | [-'()+,./:=?;!*#@$_%]
|
||||||
|
*/
|
||||||
|
#define IS_PUBIDCHAR(c) xmlIsPubidCharQ(c)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* IS_PUBIDCHAR_CH:
|
||||||
|
* @c: an xmlChar value (normally unsigned char)
|
||||||
|
*
|
||||||
|
* Same as IS_PUBIDCHAR but for single-byte value
|
||||||
|
*/
|
||||||
|
#define IS_PUBIDCHAR_CH(c) xmlIsPubidChar_ch(c)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* SKIP_EOL:
|
||||||
|
* @p: and UTF8 string pointer
|
||||||
|
*
|
||||||
|
* Skips the end of line chars.
|
||||||
|
*/
|
||||||
|
#define SKIP_EOL(p) \
|
||||||
|
if (*(p) == 0x13) { p++ ; if (*(p) == 0x10) p++; } \
|
||||||
|
if (*(p) == 0x10) { p++ ; if (*(p) == 0x13) p++; }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* MOVETO_ENDTAG:
|
||||||
|
* @p: and UTF8 string pointer
|
||||||
|
*
|
||||||
|
* Skips to the next '>' char.
|
||||||
|
*/
|
||||||
|
#define MOVETO_ENDTAG(p) \
|
||||||
|
while ((*p) && (*(p) != '>')) (p)++
|
||||||
|
|
||||||
|
/**
|
||||||
|
* MOVETO_STARTTAG:
|
||||||
|
* @p: and UTF8 string pointer
|
||||||
|
*
|
||||||
|
* Skips to the next '<' char.
|
||||||
|
*/
|
||||||
|
#define MOVETO_STARTTAG(p) \
|
||||||
|
while ((*p) && (*(p) != '<')) (p)++
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Global variables used for predefined strings.
|
||||||
|
*/
|
||||||
|
XMLPUBVAR const xmlChar xmlStringText[];
|
||||||
|
XMLPUBVAR const xmlChar xmlStringTextNoenc[];
|
||||||
|
XMLPUBVAR const xmlChar xmlStringComment[];
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Function to finish the work of the macros where needed.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL xmlIsLetter (int c);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parser context.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlParserCtxtPtr XMLCALL
|
||||||
|
xmlCreateFileParserCtxt (const char *filename);
|
||||||
|
XMLPUBFUN xmlParserCtxtPtr XMLCALL
|
||||||
|
xmlCreateURLParserCtxt (const char *filename,
|
||||||
|
int options);
|
||||||
|
XMLPUBFUN xmlParserCtxtPtr XMLCALL
|
||||||
|
xmlCreateMemoryParserCtxt(const char *buffer,
|
||||||
|
int size);
|
||||||
|
XMLPUBFUN xmlParserCtxtPtr XMLCALL
|
||||||
|
xmlCreateEntityParserCtxt(const xmlChar *URL,
|
||||||
|
const xmlChar *ID,
|
||||||
|
const xmlChar *base);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSwitchEncoding (xmlParserCtxtPtr ctxt,
|
||||||
|
xmlCharEncoding enc);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSwitchToEncoding (xmlParserCtxtPtr ctxt,
|
||||||
|
xmlCharEncodingHandlerPtr handler);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSwitchInputEncoding (xmlParserCtxtPtr ctxt,
|
||||||
|
xmlParserInputPtr input,
|
||||||
|
xmlCharEncodingHandlerPtr handler);
|
||||||
|
|
||||||
|
#ifdef IN_LIBXML
|
||||||
|
/* internal error reporting */
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
__xmlErrEncoding (xmlParserCtxtPtr ctxt,
|
||||||
|
xmlParserErrors xmlerr,
|
||||||
|
const char *msg,
|
||||||
|
const xmlChar * str1,
|
||||||
|
const xmlChar * str2);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Input Streams.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlParserInputPtr XMLCALL
|
||||||
|
xmlNewStringInputStream (xmlParserCtxtPtr ctxt,
|
||||||
|
const xmlChar *buffer);
|
||||||
|
XMLPUBFUN xmlParserInputPtr XMLCALL
|
||||||
|
xmlNewEntityInputStream (xmlParserCtxtPtr ctxt,
|
||||||
|
xmlEntityPtr entity);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlPushInput (xmlParserCtxtPtr ctxt,
|
||||||
|
xmlParserInputPtr input);
|
||||||
|
XMLPUBFUN xmlChar XMLCALL
|
||||||
|
xmlPopInput (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlFreeInputStream (xmlParserInputPtr input);
|
||||||
|
XMLPUBFUN xmlParserInputPtr XMLCALL
|
||||||
|
xmlNewInputFromFile (xmlParserCtxtPtr ctxt,
|
||||||
|
const char *filename);
|
||||||
|
XMLPUBFUN xmlParserInputPtr XMLCALL
|
||||||
|
xmlNewInputStream (xmlParserCtxtPtr ctxt);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Namespaces.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlSplitQName (xmlParserCtxtPtr ctxt,
|
||||||
|
const xmlChar *name,
|
||||||
|
xmlChar **prefix);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Generic production rules.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlParseName (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlParseNmtoken (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlParseEntityValue (xmlParserCtxtPtr ctxt,
|
||||||
|
xmlChar **orig);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlParseAttValue (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlParseSystemLiteral (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlParsePubidLiteral (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlParseCharData (xmlParserCtxtPtr ctxt,
|
||||||
|
int cdata);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlParseExternalID (xmlParserCtxtPtr ctxt,
|
||||||
|
xmlChar **publicID,
|
||||||
|
int strict);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlParseComment (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlParsePITarget (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlParsePI (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlParseNotationDecl (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlParseEntityDecl (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlParseDefaultDecl (xmlParserCtxtPtr ctxt,
|
||||||
|
xmlChar **value);
|
||||||
|
XMLPUBFUN xmlEnumerationPtr XMLCALL
|
||||||
|
xmlParseNotationType (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN xmlEnumerationPtr XMLCALL
|
||||||
|
xmlParseEnumerationType (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlParseEnumeratedType (xmlParserCtxtPtr ctxt,
|
||||||
|
xmlEnumerationPtr *tree);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlParseAttributeType (xmlParserCtxtPtr ctxt,
|
||||||
|
xmlEnumerationPtr *tree);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlParseAttributeListDecl(xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN xmlElementContentPtr XMLCALL
|
||||||
|
xmlParseElementMixedContentDecl
|
||||||
|
(xmlParserCtxtPtr ctxt,
|
||||||
|
int inputchk);
|
||||||
|
XMLPUBFUN xmlElementContentPtr XMLCALL
|
||||||
|
xmlParseElementChildrenContentDecl
|
||||||
|
(xmlParserCtxtPtr ctxt,
|
||||||
|
int inputchk);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlParseElementContentDecl(xmlParserCtxtPtr ctxt,
|
||||||
|
const xmlChar *name,
|
||||||
|
xmlElementContentPtr *result);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlParseElementDecl (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlParseMarkupDecl (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlParseCharRef (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN xmlEntityPtr XMLCALL
|
||||||
|
xmlParseEntityRef (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlParseReference (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlParsePEReference (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlParseDocTypeDecl (xmlParserCtxtPtr ctxt);
|
||||||
|
#ifdef LIBXML_SAX1_ENABLED
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlParseAttribute (xmlParserCtxtPtr ctxt,
|
||||||
|
xmlChar **value);
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlParseStartTag (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlParseEndTag (xmlParserCtxtPtr ctxt);
|
||||||
|
#endif /* LIBXML_SAX1_ENABLED */
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlParseCDSect (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlParseContent (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlParseElement (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlParseVersionNum (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlParseVersionInfo (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlParseEncName (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlParseEncodingDecl (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlParseSDDecl (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlParseXMLDecl (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlParseTextDecl (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlParseMisc (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlParseExternalSubset (xmlParserCtxtPtr ctxt,
|
||||||
|
const xmlChar *ExternalID,
|
||||||
|
const xmlChar *SystemID);
|
||||||
|
/**
|
||||||
|
* XML_SUBSTITUTE_NONE:
|
||||||
|
*
|
||||||
|
* If no entities need to be substituted.
|
||||||
|
*/
|
||||||
|
#define XML_SUBSTITUTE_NONE 0
|
||||||
|
/**
|
||||||
|
* XML_SUBSTITUTE_REF:
|
||||||
|
*
|
||||||
|
* Whether general entities need to be substituted.
|
||||||
|
*/
|
||||||
|
#define XML_SUBSTITUTE_REF 1
|
||||||
|
/**
|
||||||
|
* XML_SUBSTITUTE_PEREF:
|
||||||
|
*
|
||||||
|
* Whether parameter entities need to be substituted.
|
||||||
|
*/
|
||||||
|
#define XML_SUBSTITUTE_PEREF 2
|
||||||
|
/**
|
||||||
|
* XML_SUBSTITUTE_BOTH:
|
||||||
|
*
|
||||||
|
* Both general and parameter entities need to be substituted.
|
||||||
|
*/
|
||||||
|
#define XML_SUBSTITUTE_BOTH 3
|
||||||
|
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlStringDecodeEntities (xmlParserCtxtPtr ctxt,
|
||||||
|
const xmlChar *str,
|
||||||
|
int what,
|
||||||
|
xmlChar end,
|
||||||
|
xmlChar end2,
|
||||||
|
xmlChar end3);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlStringLenDecodeEntities (xmlParserCtxtPtr ctxt,
|
||||||
|
const xmlChar *str,
|
||||||
|
int len,
|
||||||
|
int what,
|
||||||
|
xmlChar end,
|
||||||
|
xmlChar end2,
|
||||||
|
xmlChar end3);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Generated by MACROS on top of parser.c c.f. PUSH_AND_POP.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL nodePush (xmlParserCtxtPtr ctxt,
|
||||||
|
xmlNodePtr value);
|
||||||
|
XMLPUBFUN xmlNodePtr XMLCALL nodePop (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN int XMLCALL inputPush (xmlParserCtxtPtr ctxt,
|
||||||
|
xmlParserInputPtr value);
|
||||||
|
XMLPUBFUN xmlParserInputPtr XMLCALL inputPop (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL namePop (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN int XMLCALL namePush (xmlParserCtxtPtr ctxt,
|
||||||
|
const xmlChar *value);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* other commodities shared between parser.c and parserInternals.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL xmlSkipBlankChars (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN int XMLCALL xmlStringCurrentChar (xmlParserCtxtPtr ctxt,
|
||||||
|
const xmlChar *cur,
|
||||||
|
int *len);
|
||||||
|
XMLPUBFUN void XMLCALL xmlParserHandlePEReference(xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN int XMLCALL xmlCheckLanguageID (const xmlChar *lang);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Really core function shared with HTML parser.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL xmlCurrentChar (xmlParserCtxtPtr ctxt,
|
||||||
|
int *len);
|
||||||
|
XMLPUBFUN int XMLCALL xmlCopyCharMultiByte (xmlChar *out,
|
||||||
|
int val);
|
||||||
|
XMLPUBFUN int XMLCALL xmlCopyChar (int len,
|
||||||
|
xmlChar *out,
|
||||||
|
int val);
|
||||||
|
XMLPUBFUN void XMLCALL xmlNextChar (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL xmlParserInputShrink (xmlParserInputPtr in);
|
||||||
|
|
||||||
|
#ifdef LIBXML_HTML_ENABLED
|
||||||
|
/*
|
||||||
|
* Actually comes from the HTML parser but launched from the init stuff.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN void XMLCALL htmlInitAutoClose (void);
|
||||||
|
XMLPUBFUN htmlParserCtxtPtr XMLCALL htmlCreateFileParserCtxt(const char *filename,
|
||||||
|
const char *encoding);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Specific function to keep track of entities references
|
||||||
|
* and used by the XSLT debugger.
|
||||||
|
*/
|
||||||
|
#ifdef LIBXML_LEGACY_ENABLED
|
||||||
|
/**
|
||||||
|
* xmlEntityReferenceFunc:
|
||||||
|
* @ent: the entity
|
||||||
|
* @firstNode: the fist node in the chunk
|
||||||
|
* @lastNode: the last nod in the chunk
|
||||||
|
*
|
||||||
|
* Callback function used when one needs to be able to track back the
|
||||||
|
* provenance of a chunk of nodes inherited from an entity replacement.
|
||||||
|
*/
|
||||||
|
typedef void (*xmlEntityReferenceFunc) (xmlEntityPtr ent,
|
||||||
|
xmlNodePtr firstNode,
|
||||||
|
xmlNodePtr lastNode);
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL xmlSetEntityReferenceFunc (xmlEntityReferenceFunc func);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlParseQuotedString (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlParseNamespace (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlNamespaceParseNSDef (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlScanName (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlNamespaceParseNCName (xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL xmlParserHandleReference(xmlParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlNamespaceParseQName (xmlParserCtxtPtr ctxt,
|
||||||
|
xmlChar **prefix);
|
||||||
|
/**
|
||||||
|
* Entities
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlDecodeEntities (xmlParserCtxtPtr ctxt,
|
||||||
|
int len,
|
||||||
|
int what,
|
||||||
|
xmlChar end,
|
||||||
|
xmlChar end2,
|
||||||
|
xmlChar end3);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlHandleEntity (xmlParserCtxtPtr ctxt,
|
||||||
|
xmlEntityPtr entity);
|
||||||
|
|
||||||
|
#endif /* LIBXML_LEGACY_ENABLED */
|
||||||
|
|
||||||
|
#ifdef IN_LIBXML
|
||||||
|
/*
|
||||||
|
* internal only
|
||||||
|
*/
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlErrMemory (xmlParserCtxtPtr ctxt,
|
||||||
|
const char *extra);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif /* __XML_PARSER_INTERNALS_H__ */
|
|
@ -0,0 +1,100 @@
|
||||||
|
/*
|
||||||
|
* Summary: pattern expression handling
|
||||||
|
* Description: allows to compile and test pattern expressions for nodes
|
||||||
|
* either in a tree or based on a parser state.
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_PATTERN_H__
|
||||||
|
#define __XML_PATTERN_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
#include <libxml/tree.h>
|
||||||
|
#include <libxml/dict.h>
|
||||||
|
|
||||||
|
#ifdef LIBXML_PATTERN_ENABLED
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlPattern:
|
||||||
|
*
|
||||||
|
* A compiled (XPath based) pattern to select nodes
|
||||||
|
*/
|
||||||
|
typedef struct _xmlPattern xmlPattern;
|
||||||
|
typedef xmlPattern *xmlPatternPtr;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlPatternFlags:
|
||||||
|
*
|
||||||
|
* This is the set of options affecting the behaviour of pattern
|
||||||
|
* matching with this module
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
XML_PATTERN_DEFAULT = 0, /* simple pattern match */
|
||||||
|
XML_PATTERN_XPATH = 1<<0, /* standard XPath pattern */
|
||||||
|
XML_PATTERN_XSSEL = 1<<1, /* XPath subset for schema selector */
|
||||||
|
XML_PATTERN_XSFIELD = 1<<2 /* XPath subset for schema field */
|
||||||
|
} xmlPatternFlags;
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlFreePattern (xmlPatternPtr comp);
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlFreePatternList (xmlPatternPtr comp);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlPatternPtr XMLCALL
|
||||||
|
xmlPatterncompile (const xmlChar *pattern,
|
||||||
|
xmlDict *dict,
|
||||||
|
int flags,
|
||||||
|
const xmlChar **namespaces);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlPatternMatch (xmlPatternPtr comp,
|
||||||
|
xmlNodePtr node);
|
||||||
|
|
||||||
|
/* streaming interfaces */
|
||||||
|
typedef struct _xmlStreamCtxt xmlStreamCtxt;
|
||||||
|
typedef xmlStreamCtxt *xmlStreamCtxtPtr;
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlPatternStreamable (xmlPatternPtr comp);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlPatternMaxDepth (xmlPatternPtr comp);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlPatternMinDepth (xmlPatternPtr comp);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlPatternFromRoot (xmlPatternPtr comp);
|
||||||
|
XMLPUBFUN xmlStreamCtxtPtr XMLCALL
|
||||||
|
xmlPatternGetStreamCtxt (xmlPatternPtr comp);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlFreeStreamCtxt (xmlStreamCtxtPtr stream);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlStreamPushNode (xmlStreamCtxtPtr stream,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *ns,
|
||||||
|
int nodeType);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlStreamPush (xmlStreamCtxtPtr stream,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *ns);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlStreamPushAttr (xmlStreamCtxtPtr stream,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *ns);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlStreamPop (xmlStreamCtxtPtr stream);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlStreamWantsAnyNode (xmlStreamCtxtPtr stream);
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* LIBXML_PATTERN_ENABLED */
|
||||||
|
|
||||||
|
#endif /* __XML_PATTERN_H__ */
|
|
@ -0,0 +1,213 @@
|
||||||
|
/*
|
||||||
|
* Summary: implementation of the Relax-NG validation
|
||||||
|
* Description: implementation of the Relax-NG validation
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_RELAX_NG__
|
||||||
|
#define __XML_RELAX_NG__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
#include <libxml/hash.h>
|
||||||
|
#include <libxml/xmlstring.h>
|
||||||
|
|
||||||
|
#ifdef LIBXML_SCHEMAS_ENABLED
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef struct _xmlRelaxNG xmlRelaxNG;
|
||||||
|
typedef xmlRelaxNG *xmlRelaxNGPtr;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlRelaxNGValidityErrorFunc:
|
||||||
|
* @ctx: the validation context
|
||||||
|
* @msg: the message
|
||||||
|
* @...: extra arguments
|
||||||
|
*
|
||||||
|
* Signature of an error callback from a Relax-NG validation
|
||||||
|
*/
|
||||||
|
typedef void (XMLCDECL *xmlRelaxNGValidityErrorFunc) (void *ctx, const char *msg, ...) LIBXML_ATTR_FORMAT(2,3);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlRelaxNGValidityWarningFunc:
|
||||||
|
* @ctx: the validation context
|
||||||
|
* @msg: the message
|
||||||
|
* @...: extra arguments
|
||||||
|
*
|
||||||
|
* Signature of a warning callback from a Relax-NG validation
|
||||||
|
*/
|
||||||
|
typedef void (XMLCDECL *xmlRelaxNGValidityWarningFunc) (void *ctx, const char *msg, ...) LIBXML_ATTR_FORMAT(2,3);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A schemas validation context
|
||||||
|
*/
|
||||||
|
typedef struct _xmlRelaxNGParserCtxt xmlRelaxNGParserCtxt;
|
||||||
|
typedef xmlRelaxNGParserCtxt *xmlRelaxNGParserCtxtPtr;
|
||||||
|
|
||||||
|
typedef struct _xmlRelaxNGValidCtxt xmlRelaxNGValidCtxt;
|
||||||
|
typedef xmlRelaxNGValidCtxt *xmlRelaxNGValidCtxtPtr;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* xmlRelaxNGValidErr:
|
||||||
|
*
|
||||||
|
* List of possible Relax NG validation errors
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
XML_RELAXNG_OK = 0,
|
||||||
|
XML_RELAXNG_ERR_MEMORY,
|
||||||
|
XML_RELAXNG_ERR_TYPE,
|
||||||
|
XML_RELAXNG_ERR_TYPEVAL,
|
||||||
|
XML_RELAXNG_ERR_DUPID,
|
||||||
|
XML_RELAXNG_ERR_TYPECMP,
|
||||||
|
XML_RELAXNG_ERR_NOSTATE,
|
||||||
|
XML_RELAXNG_ERR_NODEFINE,
|
||||||
|
XML_RELAXNG_ERR_LISTEXTRA,
|
||||||
|
XML_RELAXNG_ERR_LISTEMPTY,
|
||||||
|
XML_RELAXNG_ERR_INTERNODATA,
|
||||||
|
XML_RELAXNG_ERR_INTERSEQ,
|
||||||
|
XML_RELAXNG_ERR_INTEREXTRA,
|
||||||
|
XML_RELAXNG_ERR_ELEMNAME,
|
||||||
|
XML_RELAXNG_ERR_ATTRNAME,
|
||||||
|
XML_RELAXNG_ERR_ELEMNONS,
|
||||||
|
XML_RELAXNG_ERR_ATTRNONS,
|
||||||
|
XML_RELAXNG_ERR_ELEMWRONGNS,
|
||||||
|
XML_RELAXNG_ERR_ATTRWRONGNS,
|
||||||
|
XML_RELAXNG_ERR_ELEMEXTRANS,
|
||||||
|
XML_RELAXNG_ERR_ATTREXTRANS,
|
||||||
|
XML_RELAXNG_ERR_ELEMNOTEMPTY,
|
||||||
|
XML_RELAXNG_ERR_NOELEM,
|
||||||
|
XML_RELAXNG_ERR_NOTELEM,
|
||||||
|
XML_RELAXNG_ERR_ATTRVALID,
|
||||||
|
XML_RELAXNG_ERR_CONTENTVALID,
|
||||||
|
XML_RELAXNG_ERR_EXTRACONTENT,
|
||||||
|
XML_RELAXNG_ERR_INVALIDATTR,
|
||||||
|
XML_RELAXNG_ERR_DATAELEM,
|
||||||
|
XML_RELAXNG_ERR_VALELEM,
|
||||||
|
XML_RELAXNG_ERR_LISTELEM,
|
||||||
|
XML_RELAXNG_ERR_DATATYPE,
|
||||||
|
XML_RELAXNG_ERR_VALUE,
|
||||||
|
XML_RELAXNG_ERR_LIST,
|
||||||
|
XML_RELAXNG_ERR_NOGRAMMAR,
|
||||||
|
XML_RELAXNG_ERR_EXTRADATA,
|
||||||
|
XML_RELAXNG_ERR_LACKDATA,
|
||||||
|
XML_RELAXNG_ERR_INTERNAL,
|
||||||
|
XML_RELAXNG_ERR_ELEMWRONG,
|
||||||
|
XML_RELAXNG_ERR_TEXTWRONG
|
||||||
|
} xmlRelaxNGValidErr;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* xmlRelaxNGParserFlags:
|
||||||
|
*
|
||||||
|
* List of possible Relax NG Parser flags
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
XML_RELAXNGP_NONE = 0,
|
||||||
|
XML_RELAXNGP_FREE_DOC = 1,
|
||||||
|
XML_RELAXNGP_CRNG = 2
|
||||||
|
} xmlRelaxNGParserFlag;
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlRelaxNGInitTypes (void);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlRelaxNGCleanupTypes (void);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Interfaces for parsing.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlRelaxNGParserCtxtPtr XMLCALL
|
||||||
|
xmlRelaxNGNewParserCtxt (const char *URL);
|
||||||
|
XMLPUBFUN xmlRelaxNGParserCtxtPtr XMLCALL
|
||||||
|
xmlRelaxNGNewMemParserCtxt (const char *buffer,
|
||||||
|
int size);
|
||||||
|
XMLPUBFUN xmlRelaxNGParserCtxtPtr XMLCALL
|
||||||
|
xmlRelaxNGNewDocParserCtxt (xmlDocPtr doc);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlRelaxParserSetFlag (xmlRelaxNGParserCtxtPtr ctxt,
|
||||||
|
int flag);
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlRelaxNGFreeParserCtxt (xmlRelaxNGParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlRelaxNGSetParserErrors(xmlRelaxNGParserCtxtPtr ctxt,
|
||||||
|
xmlRelaxNGValidityErrorFunc err,
|
||||||
|
xmlRelaxNGValidityWarningFunc warn,
|
||||||
|
void *ctx);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlRelaxNGGetParserErrors(xmlRelaxNGParserCtxtPtr ctxt,
|
||||||
|
xmlRelaxNGValidityErrorFunc *err,
|
||||||
|
xmlRelaxNGValidityWarningFunc *warn,
|
||||||
|
void **ctx);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlRelaxNGSetParserStructuredErrors(
|
||||||
|
xmlRelaxNGParserCtxtPtr ctxt,
|
||||||
|
xmlStructuredErrorFunc serror,
|
||||||
|
void *ctx);
|
||||||
|
XMLPUBFUN xmlRelaxNGPtr XMLCALL
|
||||||
|
xmlRelaxNGParse (xmlRelaxNGParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlRelaxNGFree (xmlRelaxNGPtr schema);
|
||||||
|
#ifdef LIBXML_OUTPUT_ENABLED
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlRelaxNGDump (FILE *output,
|
||||||
|
xmlRelaxNGPtr schema);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlRelaxNGDumpTree (FILE * output,
|
||||||
|
xmlRelaxNGPtr schema);
|
||||||
|
#endif /* LIBXML_OUTPUT_ENABLED */
|
||||||
|
/*
|
||||||
|
* Interfaces for validating
|
||||||
|
*/
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlRelaxNGSetValidErrors(xmlRelaxNGValidCtxtPtr ctxt,
|
||||||
|
xmlRelaxNGValidityErrorFunc err,
|
||||||
|
xmlRelaxNGValidityWarningFunc warn,
|
||||||
|
void *ctx);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlRelaxNGGetValidErrors(xmlRelaxNGValidCtxtPtr ctxt,
|
||||||
|
xmlRelaxNGValidityErrorFunc *err,
|
||||||
|
xmlRelaxNGValidityWarningFunc *warn,
|
||||||
|
void **ctx);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlRelaxNGSetValidStructuredErrors(xmlRelaxNGValidCtxtPtr ctxt,
|
||||||
|
xmlStructuredErrorFunc serror, void *ctx);
|
||||||
|
XMLPUBFUN xmlRelaxNGValidCtxtPtr XMLCALL
|
||||||
|
xmlRelaxNGNewValidCtxt (xmlRelaxNGPtr schema);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlRelaxNGFreeValidCtxt (xmlRelaxNGValidCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlRelaxNGValidateDoc (xmlRelaxNGValidCtxtPtr ctxt,
|
||||||
|
xmlDocPtr doc);
|
||||||
|
/*
|
||||||
|
* Interfaces for progressive validation when possible
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlRelaxNGValidatePushElement (xmlRelaxNGValidCtxtPtr ctxt,
|
||||||
|
xmlDocPtr doc,
|
||||||
|
xmlNodePtr elem);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlRelaxNGValidatePushCData (xmlRelaxNGValidCtxtPtr ctxt,
|
||||||
|
const xmlChar *data,
|
||||||
|
int len);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlRelaxNGValidatePopElement (xmlRelaxNGValidCtxtPtr ctxt,
|
||||||
|
xmlDocPtr doc,
|
||||||
|
xmlNodePtr elem);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlRelaxNGValidateFullElement (xmlRelaxNGValidCtxtPtr ctxt,
|
||||||
|
xmlDocPtr doc,
|
||||||
|
xmlNodePtr elem);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* LIBXML_SCHEMAS_ENABLED */
|
||||||
|
|
||||||
|
#endif /* __XML_RELAX_NG__ */
|
|
@ -0,0 +1,958 @@
|
||||||
|
/*
|
||||||
|
* Summary: internal interfaces for XML Schemas
|
||||||
|
* Description: internal interfaces for the XML Schemas handling
|
||||||
|
* and schema validity checking
|
||||||
|
* The Schemas development is a Work In Progress.
|
||||||
|
* Some of those interfaces are not garanteed to be API or ABI stable !
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef __XML_SCHEMA_INTERNALS_H__
|
||||||
|
#define __XML_SCHEMA_INTERNALS_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
|
||||||
|
#ifdef LIBXML_SCHEMAS_ENABLED
|
||||||
|
|
||||||
|
#include <libxml/xmlregexp.h>
|
||||||
|
#include <libxml/hash.h>
|
||||||
|
#include <libxml/dict.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
XML_SCHEMAS_UNKNOWN = 0,
|
||||||
|
XML_SCHEMAS_STRING,
|
||||||
|
XML_SCHEMAS_NORMSTRING,
|
||||||
|
XML_SCHEMAS_DECIMAL,
|
||||||
|
XML_SCHEMAS_TIME,
|
||||||
|
XML_SCHEMAS_GDAY,
|
||||||
|
XML_SCHEMAS_GMONTH,
|
||||||
|
XML_SCHEMAS_GMONTHDAY,
|
||||||
|
XML_SCHEMAS_GYEAR,
|
||||||
|
XML_SCHEMAS_GYEARMONTH,
|
||||||
|
XML_SCHEMAS_DATE,
|
||||||
|
XML_SCHEMAS_DATETIME,
|
||||||
|
XML_SCHEMAS_DURATION,
|
||||||
|
XML_SCHEMAS_FLOAT,
|
||||||
|
XML_SCHEMAS_DOUBLE,
|
||||||
|
XML_SCHEMAS_BOOLEAN,
|
||||||
|
XML_SCHEMAS_TOKEN,
|
||||||
|
XML_SCHEMAS_LANGUAGE,
|
||||||
|
XML_SCHEMAS_NMTOKEN,
|
||||||
|
XML_SCHEMAS_NMTOKENS,
|
||||||
|
XML_SCHEMAS_NAME,
|
||||||
|
XML_SCHEMAS_QNAME,
|
||||||
|
XML_SCHEMAS_NCNAME,
|
||||||
|
XML_SCHEMAS_ID,
|
||||||
|
XML_SCHEMAS_IDREF,
|
||||||
|
XML_SCHEMAS_IDREFS,
|
||||||
|
XML_SCHEMAS_ENTITY,
|
||||||
|
XML_SCHEMAS_ENTITIES,
|
||||||
|
XML_SCHEMAS_NOTATION,
|
||||||
|
XML_SCHEMAS_ANYURI,
|
||||||
|
XML_SCHEMAS_INTEGER,
|
||||||
|
XML_SCHEMAS_NPINTEGER,
|
||||||
|
XML_SCHEMAS_NINTEGER,
|
||||||
|
XML_SCHEMAS_NNINTEGER,
|
||||||
|
XML_SCHEMAS_PINTEGER,
|
||||||
|
XML_SCHEMAS_INT,
|
||||||
|
XML_SCHEMAS_UINT,
|
||||||
|
XML_SCHEMAS_LONG,
|
||||||
|
XML_SCHEMAS_ULONG,
|
||||||
|
XML_SCHEMAS_SHORT,
|
||||||
|
XML_SCHEMAS_USHORT,
|
||||||
|
XML_SCHEMAS_BYTE,
|
||||||
|
XML_SCHEMAS_UBYTE,
|
||||||
|
XML_SCHEMAS_HEXBINARY,
|
||||||
|
XML_SCHEMAS_BASE64BINARY,
|
||||||
|
XML_SCHEMAS_ANYTYPE,
|
||||||
|
XML_SCHEMAS_ANYSIMPLETYPE
|
||||||
|
} xmlSchemaValType;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* XML Schemas defines multiple type of types.
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
XML_SCHEMA_TYPE_BASIC = 1, /* A built-in datatype */
|
||||||
|
XML_SCHEMA_TYPE_ANY,
|
||||||
|
XML_SCHEMA_TYPE_FACET,
|
||||||
|
XML_SCHEMA_TYPE_SIMPLE,
|
||||||
|
XML_SCHEMA_TYPE_COMPLEX,
|
||||||
|
XML_SCHEMA_TYPE_SEQUENCE = 6,
|
||||||
|
XML_SCHEMA_TYPE_CHOICE,
|
||||||
|
XML_SCHEMA_TYPE_ALL,
|
||||||
|
XML_SCHEMA_TYPE_SIMPLE_CONTENT,
|
||||||
|
XML_SCHEMA_TYPE_COMPLEX_CONTENT,
|
||||||
|
XML_SCHEMA_TYPE_UR,
|
||||||
|
XML_SCHEMA_TYPE_RESTRICTION,
|
||||||
|
XML_SCHEMA_TYPE_EXTENSION,
|
||||||
|
XML_SCHEMA_TYPE_ELEMENT,
|
||||||
|
XML_SCHEMA_TYPE_ATTRIBUTE,
|
||||||
|
XML_SCHEMA_TYPE_ATTRIBUTEGROUP,
|
||||||
|
XML_SCHEMA_TYPE_GROUP,
|
||||||
|
XML_SCHEMA_TYPE_NOTATION,
|
||||||
|
XML_SCHEMA_TYPE_LIST,
|
||||||
|
XML_SCHEMA_TYPE_UNION,
|
||||||
|
XML_SCHEMA_TYPE_ANY_ATTRIBUTE,
|
||||||
|
XML_SCHEMA_TYPE_IDC_UNIQUE,
|
||||||
|
XML_SCHEMA_TYPE_IDC_KEY,
|
||||||
|
XML_SCHEMA_TYPE_IDC_KEYREF,
|
||||||
|
XML_SCHEMA_TYPE_PARTICLE = 25,
|
||||||
|
XML_SCHEMA_TYPE_ATTRIBUTE_USE,
|
||||||
|
XML_SCHEMA_FACET_MININCLUSIVE = 1000,
|
||||||
|
XML_SCHEMA_FACET_MINEXCLUSIVE,
|
||||||
|
XML_SCHEMA_FACET_MAXINCLUSIVE,
|
||||||
|
XML_SCHEMA_FACET_MAXEXCLUSIVE,
|
||||||
|
XML_SCHEMA_FACET_TOTALDIGITS,
|
||||||
|
XML_SCHEMA_FACET_FRACTIONDIGITS,
|
||||||
|
XML_SCHEMA_FACET_PATTERN,
|
||||||
|
XML_SCHEMA_FACET_ENUMERATION,
|
||||||
|
XML_SCHEMA_FACET_WHITESPACE,
|
||||||
|
XML_SCHEMA_FACET_LENGTH,
|
||||||
|
XML_SCHEMA_FACET_MAXLENGTH,
|
||||||
|
XML_SCHEMA_FACET_MINLENGTH,
|
||||||
|
XML_SCHEMA_EXTRA_QNAMEREF = 2000,
|
||||||
|
XML_SCHEMA_EXTRA_ATTR_USE_PROHIB
|
||||||
|
} xmlSchemaTypeType;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
XML_SCHEMA_CONTENT_UNKNOWN = 0,
|
||||||
|
XML_SCHEMA_CONTENT_EMPTY = 1,
|
||||||
|
XML_SCHEMA_CONTENT_ELEMENTS,
|
||||||
|
XML_SCHEMA_CONTENT_MIXED,
|
||||||
|
XML_SCHEMA_CONTENT_SIMPLE,
|
||||||
|
XML_SCHEMA_CONTENT_MIXED_OR_ELEMENTS, /* Obsolete */
|
||||||
|
XML_SCHEMA_CONTENT_BASIC,
|
||||||
|
XML_SCHEMA_CONTENT_ANY
|
||||||
|
} xmlSchemaContentType;
|
||||||
|
|
||||||
|
typedef struct _xmlSchemaVal xmlSchemaVal;
|
||||||
|
typedef xmlSchemaVal *xmlSchemaValPtr;
|
||||||
|
|
||||||
|
typedef struct _xmlSchemaType xmlSchemaType;
|
||||||
|
typedef xmlSchemaType *xmlSchemaTypePtr;
|
||||||
|
|
||||||
|
typedef struct _xmlSchemaFacet xmlSchemaFacet;
|
||||||
|
typedef xmlSchemaFacet *xmlSchemaFacetPtr;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Annotation
|
||||||
|
*/
|
||||||
|
typedef struct _xmlSchemaAnnot xmlSchemaAnnot;
|
||||||
|
typedef xmlSchemaAnnot *xmlSchemaAnnotPtr;
|
||||||
|
struct _xmlSchemaAnnot {
|
||||||
|
struct _xmlSchemaAnnot *next;
|
||||||
|
xmlNodePtr content; /* the annotation */
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ANYATTR_SKIP:
|
||||||
|
*
|
||||||
|
* Skip unknown attribute from validation
|
||||||
|
* Obsolete, not used anymore.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ANYATTR_SKIP 1
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ANYATTR_LAX:
|
||||||
|
*
|
||||||
|
* Ignore validation non definition on attributes
|
||||||
|
* Obsolete, not used anymore.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ANYATTR_LAX 2
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ANYATTR_STRICT:
|
||||||
|
*
|
||||||
|
* Apply strict validation rules on attributes
|
||||||
|
* Obsolete, not used anymore.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ANYATTR_STRICT 3
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ANY_SKIP:
|
||||||
|
*
|
||||||
|
* Skip unknown attribute from validation
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ANY_SKIP 1
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ANY_LAX:
|
||||||
|
*
|
||||||
|
* Used by wildcards.
|
||||||
|
* Validate if type found, don't worry if not found
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ANY_LAX 2
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ANY_STRICT:
|
||||||
|
*
|
||||||
|
* Used by wildcards.
|
||||||
|
* Apply strict validation rules
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ANY_STRICT 3
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ATTR_USE_PROHIBITED:
|
||||||
|
*
|
||||||
|
* Used by wildcards.
|
||||||
|
* The attribute is prohibited.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ATTR_USE_PROHIBITED 0
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ATTR_USE_REQUIRED:
|
||||||
|
*
|
||||||
|
* The attribute is required.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ATTR_USE_REQUIRED 1
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ATTR_USE_OPTIONAL:
|
||||||
|
*
|
||||||
|
* The attribute is optional.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ATTR_USE_OPTIONAL 2
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ATTR_GLOBAL:
|
||||||
|
*
|
||||||
|
* allow elements in no namespace
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ATTR_GLOBAL 1 << 0
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ATTR_NSDEFAULT:
|
||||||
|
*
|
||||||
|
* allow elements in no namespace
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ATTR_NSDEFAULT 1 << 7
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ATTR_INTERNAL_RESOLVED:
|
||||||
|
*
|
||||||
|
* this is set when the "type" and "ref" references
|
||||||
|
* have been resolved.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ATTR_INTERNAL_RESOLVED 1 << 8
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ATTR_FIXED:
|
||||||
|
*
|
||||||
|
* the attribute has a fixed value
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ATTR_FIXED 1 << 9
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlSchemaAttribute:
|
||||||
|
* An attribute definition.
|
||||||
|
*/
|
||||||
|
|
||||||
|
typedef struct _xmlSchemaAttribute xmlSchemaAttribute;
|
||||||
|
typedef xmlSchemaAttribute *xmlSchemaAttributePtr;
|
||||||
|
struct _xmlSchemaAttribute {
|
||||||
|
xmlSchemaTypeType type;
|
||||||
|
struct _xmlSchemaAttribute *next; /* the next attribute (not used?) */
|
||||||
|
const xmlChar *name; /* the name of the declaration */
|
||||||
|
const xmlChar *id; /* Deprecated; not used */
|
||||||
|
const xmlChar *ref; /* Deprecated; not used */
|
||||||
|
const xmlChar *refNs; /* Deprecated; not used */
|
||||||
|
const xmlChar *typeName; /* the local name of the type definition */
|
||||||
|
const xmlChar *typeNs; /* the ns URI of the type definition */
|
||||||
|
xmlSchemaAnnotPtr annot;
|
||||||
|
|
||||||
|
xmlSchemaTypePtr base; /* Deprecated; not used */
|
||||||
|
int occurs; /* Deprecated; not used */
|
||||||
|
const xmlChar *defValue; /* The initial value of the value constraint */
|
||||||
|
xmlSchemaTypePtr subtypes; /* the type definition */
|
||||||
|
xmlNodePtr node;
|
||||||
|
const xmlChar *targetNamespace;
|
||||||
|
int flags;
|
||||||
|
const xmlChar *refPrefix; /* Deprecated; not used */
|
||||||
|
xmlSchemaValPtr defVal; /* The compiled value constraint */
|
||||||
|
xmlSchemaAttributePtr refDecl; /* Deprecated; not used */
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlSchemaAttributeLink:
|
||||||
|
* Used to build a list of attribute uses on complexType definitions.
|
||||||
|
* WARNING: Deprecated; not used.
|
||||||
|
*/
|
||||||
|
typedef struct _xmlSchemaAttributeLink xmlSchemaAttributeLink;
|
||||||
|
typedef xmlSchemaAttributeLink *xmlSchemaAttributeLinkPtr;
|
||||||
|
struct _xmlSchemaAttributeLink {
|
||||||
|
struct _xmlSchemaAttributeLink *next;/* the next attribute link ... */
|
||||||
|
struct _xmlSchemaAttribute *attr;/* the linked attribute */
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_WILDCARD_COMPLETE:
|
||||||
|
*
|
||||||
|
* If the wildcard is complete.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_WILDCARD_COMPLETE 1 << 0
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlSchemaCharValueLink:
|
||||||
|
* Used to build a list of namespaces on wildcards.
|
||||||
|
*/
|
||||||
|
typedef struct _xmlSchemaWildcardNs xmlSchemaWildcardNs;
|
||||||
|
typedef xmlSchemaWildcardNs *xmlSchemaWildcardNsPtr;
|
||||||
|
struct _xmlSchemaWildcardNs {
|
||||||
|
struct _xmlSchemaWildcardNs *next;/* the next constraint link ... */
|
||||||
|
const xmlChar *value;/* the value */
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlSchemaWildcard.
|
||||||
|
* A wildcard.
|
||||||
|
*/
|
||||||
|
typedef struct _xmlSchemaWildcard xmlSchemaWildcard;
|
||||||
|
typedef xmlSchemaWildcard *xmlSchemaWildcardPtr;
|
||||||
|
struct _xmlSchemaWildcard {
|
||||||
|
xmlSchemaTypeType type; /* The kind of type */
|
||||||
|
const xmlChar *id; /* Deprecated; not used */
|
||||||
|
xmlSchemaAnnotPtr annot;
|
||||||
|
xmlNodePtr node;
|
||||||
|
int minOccurs; /* Deprecated; not used */
|
||||||
|
int maxOccurs; /* Deprecated; not used */
|
||||||
|
int processContents;
|
||||||
|
int any; /* Indicates if the ns constraint is of ##any */
|
||||||
|
xmlSchemaWildcardNsPtr nsSet; /* The list of allowed namespaces */
|
||||||
|
xmlSchemaWildcardNsPtr negNsSet; /* The negated namespace */
|
||||||
|
int flags;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ATTRGROUP_WILDCARD_BUILDED:
|
||||||
|
*
|
||||||
|
* The attribute wildcard has been already builded.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ATTRGROUP_WILDCARD_BUILDED 1 << 0
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ATTRGROUP_GLOBAL:
|
||||||
|
*
|
||||||
|
* The attribute wildcard has been already builded.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ATTRGROUP_GLOBAL 1 << 1
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ATTRGROUP_MARKED:
|
||||||
|
*
|
||||||
|
* Marks the attr group as marked; used for circular checks.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ATTRGROUP_MARKED 1 << 2
|
||||||
|
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ATTRGROUP_REDEFINED:
|
||||||
|
*
|
||||||
|
* The attr group was redefined.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ATTRGROUP_REDEFINED 1 << 3
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ATTRGROUP_HAS_REFS:
|
||||||
|
*
|
||||||
|
* Whether this attr. group contains attr. group references.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ATTRGROUP_HAS_REFS 1 << 4
|
||||||
|
|
||||||
|
/**
|
||||||
|
* An attribute group definition.
|
||||||
|
*
|
||||||
|
* xmlSchemaAttribute and xmlSchemaAttributeGroup start of structures
|
||||||
|
* must be kept similar
|
||||||
|
*/
|
||||||
|
typedef struct _xmlSchemaAttributeGroup xmlSchemaAttributeGroup;
|
||||||
|
typedef xmlSchemaAttributeGroup *xmlSchemaAttributeGroupPtr;
|
||||||
|
struct _xmlSchemaAttributeGroup {
|
||||||
|
xmlSchemaTypeType type; /* The kind of type */
|
||||||
|
struct _xmlSchemaAttribute *next;/* the next attribute if in a group ... */
|
||||||
|
const xmlChar *name;
|
||||||
|
const xmlChar *id;
|
||||||
|
const xmlChar *ref; /* Deprecated; not used */
|
||||||
|
const xmlChar *refNs; /* Deprecated; not used */
|
||||||
|
xmlSchemaAnnotPtr annot;
|
||||||
|
|
||||||
|
xmlSchemaAttributePtr attributes; /* Deprecated; not used */
|
||||||
|
xmlNodePtr node;
|
||||||
|
int flags;
|
||||||
|
xmlSchemaWildcardPtr attributeWildcard;
|
||||||
|
const xmlChar *refPrefix; /* Deprecated; not used */
|
||||||
|
xmlSchemaAttributeGroupPtr refItem; /* Deprecated; not used */
|
||||||
|
const xmlChar *targetNamespace;
|
||||||
|
void *attrUses;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlSchemaTypeLink:
|
||||||
|
* Used to build a list of types (e.g. member types of
|
||||||
|
* simpleType with variety "union").
|
||||||
|
*/
|
||||||
|
typedef struct _xmlSchemaTypeLink xmlSchemaTypeLink;
|
||||||
|
typedef xmlSchemaTypeLink *xmlSchemaTypeLinkPtr;
|
||||||
|
struct _xmlSchemaTypeLink {
|
||||||
|
struct _xmlSchemaTypeLink *next;/* the next type link ... */
|
||||||
|
xmlSchemaTypePtr type;/* the linked type */
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlSchemaFacetLink:
|
||||||
|
* Used to build a list of facets.
|
||||||
|
*/
|
||||||
|
typedef struct _xmlSchemaFacetLink xmlSchemaFacetLink;
|
||||||
|
typedef xmlSchemaFacetLink *xmlSchemaFacetLinkPtr;
|
||||||
|
struct _xmlSchemaFacetLink {
|
||||||
|
struct _xmlSchemaFacetLink *next;/* the next facet link ... */
|
||||||
|
xmlSchemaFacetPtr facet;/* the linked facet */
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_MIXED:
|
||||||
|
*
|
||||||
|
* the element content type is mixed
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_MIXED 1 << 0
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_DERIVATION_METHOD_EXTENSION:
|
||||||
|
*
|
||||||
|
* the simple or complex type has a derivation method of "extension".
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_DERIVATION_METHOD_EXTENSION 1 << 1
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_DERIVATION_METHOD_RESTRICTION:
|
||||||
|
*
|
||||||
|
* the simple or complex type has a derivation method of "restriction".
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_DERIVATION_METHOD_RESTRICTION 1 << 2
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_GLOBAL:
|
||||||
|
*
|
||||||
|
* the type is global
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_GLOBAL 1 << 3
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_OWNED_ATTR_WILDCARD:
|
||||||
|
*
|
||||||
|
* the complexType owns an attribute wildcard, i.e.
|
||||||
|
* it can be freed by the complexType
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_OWNED_ATTR_WILDCARD 1 << 4 /* Obsolete. */
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_VARIETY_ABSENT:
|
||||||
|
*
|
||||||
|
* the simpleType has a variety of "absent".
|
||||||
|
* TODO: Actually not necessary :-/, since if
|
||||||
|
* none of the variety flags occur then it's
|
||||||
|
* automatically absent.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_VARIETY_ABSENT 1 << 5
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_VARIETY_LIST:
|
||||||
|
*
|
||||||
|
* the simpleType has a variety of "list".
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_VARIETY_LIST 1 << 6
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_VARIETY_UNION:
|
||||||
|
*
|
||||||
|
* the simpleType has a variety of "union".
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_VARIETY_UNION 1 << 7
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_VARIETY_ATOMIC:
|
||||||
|
*
|
||||||
|
* the simpleType has a variety of "union".
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_VARIETY_ATOMIC 1 << 8
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_FINAL_EXTENSION:
|
||||||
|
*
|
||||||
|
* the complexType has a final of "extension".
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_FINAL_EXTENSION 1 << 9
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_FINAL_RESTRICTION:
|
||||||
|
*
|
||||||
|
* the simpleType/complexType has a final of "restriction".
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_FINAL_RESTRICTION 1 << 10
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_FINAL_LIST:
|
||||||
|
*
|
||||||
|
* the simpleType has a final of "list".
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_FINAL_LIST 1 << 11
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_FINAL_UNION:
|
||||||
|
*
|
||||||
|
* the simpleType has a final of "union".
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_FINAL_UNION 1 << 12
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_FINAL_DEFAULT:
|
||||||
|
*
|
||||||
|
* the simpleType has a final of "default".
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_FINAL_DEFAULT 1 << 13
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_BUILTIN_PRIMITIVE:
|
||||||
|
*
|
||||||
|
* Marks the item as a builtin primitive.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_BUILTIN_PRIMITIVE 1 << 14
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_MARKED:
|
||||||
|
*
|
||||||
|
* Marks the item as marked; used for circular checks.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_MARKED 1 << 16
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_BLOCK_DEFAULT:
|
||||||
|
*
|
||||||
|
* the complexType did not specify 'block' so use the default of the
|
||||||
|
* <schema> item.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_BLOCK_DEFAULT 1 << 17
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_BLOCK_EXTENSION:
|
||||||
|
*
|
||||||
|
* the complexType has a 'block' of "extension".
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_BLOCK_EXTENSION 1 << 18
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_BLOCK_RESTRICTION:
|
||||||
|
*
|
||||||
|
* the complexType has a 'block' of "restriction".
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_BLOCK_RESTRICTION 1 << 19
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_ABSTRACT:
|
||||||
|
*
|
||||||
|
* the simple/complexType is abstract.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_ABSTRACT 1 << 20
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_FACETSNEEDVALUE:
|
||||||
|
*
|
||||||
|
* indicates if the facets need a computed value
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_FACETSNEEDVALUE 1 << 21
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_INTERNAL_RESOLVED:
|
||||||
|
*
|
||||||
|
* indicates that the type was typefixed
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_INTERNAL_RESOLVED 1 << 22
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_INTERNAL_INVALID:
|
||||||
|
*
|
||||||
|
* indicates that the type is invalid
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_INTERNAL_INVALID 1 << 23
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_WHITESPACE_PRESERVE:
|
||||||
|
*
|
||||||
|
* a whitespace-facet value of "preserve"
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_WHITESPACE_PRESERVE 1 << 24
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_WHITESPACE_REPLACE:
|
||||||
|
*
|
||||||
|
* a whitespace-facet value of "replace"
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_WHITESPACE_REPLACE 1 << 25
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_WHITESPACE_COLLAPSE:
|
||||||
|
*
|
||||||
|
* a whitespace-facet value of "collapse"
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_WHITESPACE_COLLAPSE 1 << 26
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_HAS_FACETS:
|
||||||
|
*
|
||||||
|
* has facets
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_HAS_FACETS 1 << 27
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_NORMVALUENEEDED:
|
||||||
|
*
|
||||||
|
* indicates if the facets (pattern) need a normalized value
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_NORMVALUENEEDED 1 << 28
|
||||||
|
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_FIXUP_1:
|
||||||
|
*
|
||||||
|
* First stage of fixup was done.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_FIXUP_1 1 << 29
|
||||||
|
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_REDEFINED:
|
||||||
|
*
|
||||||
|
* The type was redefined.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_TYPE_REDEFINED 1 << 30
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_TYPE_REDEFINING:
|
||||||
|
*
|
||||||
|
* The type redefines an other type.
|
||||||
|
*/
|
||||||
|
/* #define XML_SCHEMAS_TYPE_REDEFINING 1 << 31 */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* _xmlSchemaType:
|
||||||
|
*
|
||||||
|
* Schemas type definition.
|
||||||
|
*/
|
||||||
|
struct _xmlSchemaType {
|
||||||
|
xmlSchemaTypeType type; /* The kind of type */
|
||||||
|
struct _xmlSchemaType *next; /* the next type if in a sequence ... */
|
||||||
|
const xmlChar *name;
|
||||||
|
const xmlChar *id ; /* Deprecated; not used */
|
||||||
|
const xmlChar *ref; /* Deprecated; not used */
|
||||||
|
const xmlChar *refNs; /* Deprecated; not used */
|
||||||
|
xmlSchemaAnnotPtr annot;
|
||||||
|
xmlSchemaTypePtr subtypes;
|
||||||
|
xmlSchemaAttributePtr attributes; /* Deprecated; not used */
|
||||||
|
xmlNodePtr node;
|
||||||
|
int minOccurs; /* Deprecated; not used */
|
||||||
|
int maxOccurs; /* Deprecated; not used */
|
||||||
|
|
||||||
|
int flags;
|
||||||
|
xmlSchemaContentType contentType;
|
||||||
|
const xmlChar *base; /* Base type's local name */
|
||||||
|
const xmlChar *baseNs; /* Base type's target namespace */
|
||||||
|
xmlSchemaTypePtr baseType; /* The base type component */
|
||||||
|
xmlSchemaFacetPtr facets; /* Local facets */
|
||||||
|
struct _xmlSchemaType *redef; /* Deprecated; not used */
|
||||||
|
int recurse; /* Obsolete */
|
||||||
|
xmlSchemaAttributeLinkPtr *attributeUses; /* Deprecated; not used */
|
||||||
|
xmlSchemaWildcardPtr attributeWildcard;
|
||||||
|
int builtInType; /* Type of built-in types. */
|
||||||
|
xmlSchemaTypeLinkPtr memberTypes; /* member-types if a union type. */
|
||||||
|
xmlSchemaFacetLinkPtr facetSet; /* All facets (incl. inherited) */
|
||||||
|
const xmlChar *refPrefix; /* Deprecated; not used */
|
||||||
|
xmlSchemaTypePtr contentTypeDef; /* Used for the simple content of complex types.
|
||||||
|
Could we use @subtypes for this? */
|
||||||
|
xmlRegexpPtr contModel; /* Holds the automaton of the content model */
|
||||||
|
const xmlChar *targetNamespace;
|
||||||
|
void *attrUses;
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* xmlSchemaElement:
|
||||||
|
* An element definition.
|
||||||
|
*
|
||||||
|
* xmlSchemaType, xmlSchemaFacet and xmlSchemaElement start of
|
||||||
|
* structures must be kept similar
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ELEM_NILLABLE:
|
||||||
|
*
|
||||||
|
* the element is nillable
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ELEM_NILLABLE 1 << 0
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ELEM_GLOBAL:
|
||||||
|
*
|
||||||
|
* the element is global
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ELEM_GLOBAL 1 << 1
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ELEM_DEFAULT:
|
||||||
|
*
|
||||||
|
* the element has a default value
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ELEM_DEFAULT 1 << 2
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ELEM_FIXED:
|
||||||
|
*
|
||||||
|
* the element has a fixed value
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ELEM_FIXED 1 << 3
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ELEM_ABSTRACT:
|
||||||
|
*
|
||||||
|
* the element is abstract
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ELEM_ABSTRACT 1 << 4
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ELEM_TOPLEVEL:
|
||||||
|
*
|
||||||
|
* the element is top level
|
||||||
|
* obsolete: use XML_SCHEMAS_ELEM_GLOBAL instead
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ELEM_TOPLEVEL 1 << 5
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ELEM_REF:
|
||||||
|
*
|
||||||
|
* the element is a reference to a type
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ELEM_REF 1 << 6
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ELEM_NSDEFAULT:
|
||||||
|
*
|
||||||
|
* allow elements in no namespace
|
||||||
|
* Obsolete, not used anymore.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ELEM_NSDEFAULT 1 << 7
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ELEM_INTERNAL_RESOLVED:
|
||||||
|
*
|
||||||
|
* this is set when "type", "ref", "substitutionGroup"
|
||||||
|
* references have been resolved.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ELEM_INTERNAL_RESOLVED 1 << 8
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ELEM_CIRCULAR:
|
||||||
|
*
|
||||||
|
* a helper flag for the search of circular references.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ELEM_CIRCULAR 1 << 9
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ELEM_BLOCK_ABSENT:
|
||||||
|
*
|
||||||
|
* the "block" attribute is absent
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ELEM_BLOCK_ABSENT 1 << 10
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ELEM_BLOCK_EXTENSION:
|
||||||
|
*
|
||||||
|
* disallowed substitutions are absent
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ELEM_BLOCK_EXTENSION 1 << 11
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ELEM_BLOCK_RESTRICTION:
|
||||||
|
*
|
||||||
|
* disallowed substitutions: "restriction"
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ELEM_BLOCK_RESTRICTION 1 << 12
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ELEM_BLOCK_SUBSTITUTION:
|
||||||
|
*
|
||||||
|
* disallowed substitutions: "substituion"
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ELEM_BLOCK_SUBSTITUTION 1 << 13
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ELEM_FINAL_ABSENT:
|
||||||
|
*
|
||||||
|
* substitution group exclusions are absent
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ELEM_FINAL_ABSENT 1 << 14
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ELEM_FINAL_EXTENSION:
|
||||||
|
*
|
||||||
|
* substitution group exclusions: "extension"
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ELEM_FINAL_EXTENSION 1 << 15
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ELEM_FINAL_RESTRICTION:
|
||||||
|
*
|
||||||
|
* substitution group exclusions: "restriction"
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ELEM_FINAL_RESTRICTION 1 << 16
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ELEM_SUBST_GROUP_HEAD:
|
||||||
|
*
|
||||||
|
* the declaration is a substitution group head
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ELEM_SUBST_GROUP_HEAD 1 << 17
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_ELEM_INTERNAL_CHECKED:
|
||||||
|
*
|
||||||
|
* this is set when the elem decl has been checked against
|
||||||
|
* all constraints
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_ELEM_INTERNAL_CHECKED 1 << 18
|
||||||
|
|
||||||
|
typedef struct _xmlSchemaElement xmlSchemaElement;
|
||||||
|
typedef xmlSchemaElement *xmlSchemaElementPtr;
|
||||||
|
struct _xmlSchemaElement {
|
||||||
|
xmlSchemaTypeType type; /* The kind of type */
|
||||||
|
struct _xmlSchemaType *next; /* Not used? */
|
||||||
|
const xmlChar *name;
|
||||||
|
const xmlChar *id; /* Deprecated; not used */
|
||||||
|
const xmlChar *ref; /* Deprecated; not used */
|
||||||
|
const xmlChar *refNs; /* Deprecated; not used */
|
||||||
|
xmlSchemaAnnotPtr annot;
|
||||||
|
xmlSchemaTypePtr subtypes; /* the type definition */
|
||||||
|
xmlSchemaAttributePtr attributes;
|
||||||
|
xmlNodePtr node;
|
||||||
|
int minOccurs; /* Deprecated; not used */
|
||||||
|
int maxOccurs; /* Deprecated; not used */
|
||||||
|
|
||||||
|
int flags;
|
||||||
|
const xmlChar *targetNamespace;
|
||||||
|
const xmlChar *namedType;
|
||||||
|
const xmlChar *namedTypeNs;
|
||||||
|
const xmlChar *substGroup;
|
||||||
|
const xmlChar *substGroupNs;
|
||||||
|
const xmlChar *scope;
|
||||||
|
const xmlChar *value; /* The original value of the value constraint. */
|
||||||
|
struct _xmlSchemaElement *refDecl; /* This will now be used for the
|
||||||
|
substitution group affiliation */
|
||||||
|
xmlRegexpPtr contModel; /* Obsolete for WXS, maybe used for RelaxNG */
|
||||||
|
xmlSchemaContentType contentType;
|
||||||
|
const xmlChar *refPrefix; /* Deprecated; not used */
|
||||||
|
xmlSchemaValPtr defVal; /* The compiled value contraint. */
|
||||||
|
void *idcs; /* The identity-constraint defs */
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* XML_SCHEMAS_FACET_UNKNOWN:
|
||||||
|
*
|
||||||
|
* unknown facet handling
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_FACET_UNKNOWN 0
|
||||||
|
/*
|
||||||
|
* XML_SCHEMAS_FACET_PRESERVE:
|
||||||
|
*
|
||||||
|
* preserve the type of the facet
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_FACET_PRESERVE 1
|
||||||
|
/*
|
||||||
|
* XML_SCHEMAS_FACET_REPLACE:
|
||||||
|
*
|
||||||
|
* replace the type of the facet
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_FACET_REPLACE 2
|
||||||
|
/*
|
||||||
|
* XML_SCHEMAS_FACET_COLLAPSE:
|
||||||
|
*
|
||||||
|
* collapse the types of the facet
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_FACET_COLLAPSE 3
|
||||||
|
/**
|
||||||
|
* A facet definition.
|
||||||
|
*/
|
||||||
|
struct _xmlSchemaFacet {
|
||||||
|
xmlSchemaTypeType type; /* The kind of type */
|
||||||
|
struct _xmlSchemaFacet *next;/* the next type if in a sequence ... */
|
||||||
|
const xmlChar *value; /* The original value */
|
||||||
|
const xmlChar *id; /* Obsolete */
|
||||||
|
xmlSchemaAnnotPtr annot;
|
||||||
|
xmlNodePtr node;
|
||||||
|
int fixed; /* XML_SCHEMAS_FACET_PRESERVE, etc. */
|
||||||
|
int whitespace;
|
||||||
|
xmlSchemaValPtr val; /* The compiled value */
|
||||||
|
xmlRegexpPtr regexp; /* The regex for patterns */
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A notation definition.
|
||||||
|
*/
|
||||||
|
typedef struct _xmlSchemaNotation xmlSchemaNotation;
|
||||||
|
typedef xmlSchemaNotation *xmlSchemaNotationPtr;
|
||||||
|
struct _xmlSchemaNotation {
|
||||||
|
xmlSchemaTypeType type; /* The kind of type */
|
||||||
|
const xmlChar *name;
|
||||||
|
xmlSchemaAnnotPtr annot;
|
||||||
|
const xmlChar *identifier;
|
||||||
|
const xmlChar *targetNamespace;
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* TODO: Actually all those flags used for the schema should sit
|
||||||
|
* on the schema parser context, since they are used only
|
||||||
|
* during parsing an XML schema document, and not available
|
||||||
|
* on the component level as per spec.
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_QUALIF_ELEM:
|
||||||
|
*
|
||||||
|
* Reflects elementFormDefault == qualified in
|
||||||
|
* an XML schema document.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_QUALIF_ELEM 1 << 0
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_QUALIF_ATTR:
|
||||||
|
*
|
||||||
|
* Reflects attributeFormDefault == qualified in
|
||||||
|
* an XML schema document.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_QUALIF_ATTR 1 << 1
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_FINAL_DEFAULT_EXTENSION:
|
||||||
|
*
|
||||||
|
* the schema has "extension" in the set of finalDefault.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_FINAL_DEFAULT_EXTENSION 1 << 2
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_FINAL_DEFAULT_RESTRICTION:
|
||||||
|
*
|
||||||
|
* the schema has "restriction" in the set of finalDefault.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_FINAL_DEFAULT_RESTRICTION 1 << 3
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_FINAL_DEFAULT_LIST:
|
||||||
|
*
|
||||||
|
* the cshema has "list" in the set of finalDefault.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_FINAL_DEFAULT_LIST 1 << 4
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_FINAL_DEFAULT_UNION:
|
||||||
|
*
|
||||||
|
* the schema has "union" in the set of finalDefault.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_FINAL_DEFAULT_UNION 1 << 5
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_BLOCK_DEFAULT_EXTENSION:
|
||||||
|
*
|
||||||
|
* the schema has "extension" in the set of blockDefault.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_BLOCK_DEFAULT_EXTENSION 1 << 6
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_BLOCK_DEFAULT_RESTRICTION:
|
||||||
|
*
|
||||||
|
* the schema has "restriction" in the set of blockDefault.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_BLOCK_DEFAULT_RESTRICTION 1 << 7
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_BLOCK_DEFAULT_SUBSTITUTION:
|
||||||
|
*
|
||||||
|
* the schema has "substitution" in the set of blockDefault.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_BLOCK_DEFAULT_SUBSTITUTION 1 << 8
|
||||||
|
/**
|
||||||
|
* XML_SCHEMAS_INCLUDING_CONVERT_NS:
|
||||||
|
*
|
||||||
|
* the schema is currently including an other schema with
|
||||||
|
* no target namespace.
|
||||||
|
*/
|
||||||
|
#define XML_SCHEMAS_INCLUDING_CONVERT_NS 1 << 9
|
||||||
|
/**
|
||||||
|
* _xmlSchema:
|
||||||
|
*
|
||||||
|
* A Schemas definition
|
||||||
|
*/
|
||||||
|
struct _xmlSchema {
|
||||||
|
const xmlChar *name; /* schema name */
|
||||||
|
const xmlChar *targetNamespace; /* the target namespace */
|
||||||
|
const xmlChar *version;
|
||||||
|
const xmlChar *id; /* Obsolete */
|
||||||
|
xmlDocPtr doc;
|
||||||
|
xmlSchemaAnnotPtr annot;
|
||||||
|
int flags;
|
||||||
|
|
||||||
|
xmlHashTablePtr typeDecl;
|
||||||
|
xmlHashTablePtr attrDecl;
|
||||||
|
xmlHashTablePtr attrgrpDecl;
|
||||||
|
xmlHashTablePtr elemDecl;
|
||||||
|
xmlHashTablePtr notaDecl;
|
||||||
|
|
||||||
|
xmlHashTablePtr schemasImports;
|
||||||
|
|
||||||
|
void *_private; /* unused by the library for users or bindings */
|
||||||
|
xmlHashTablePtr groupDecl;
|
||||||
|
xmlDictPtr dict;
|
||||||
|
void *includes; /* the includes, this is opaque for now */
|
||||||
|
int preserve; /* whether to free the document */
|
||||||
|
int counter; /* used to give ononymous components unique names */
|
||||||
|
xmlHashTablePtr idcDef; /* All identity-constraint defs. */
|
||||||
|
void *volatiles; /* Obsolete */
|
||||||
|
};
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL xmlSchemaFreeType (xmlSchemaTypePtr type);
|
||||||
|
XMLPUBFUN void XMLCALL xmlSchemaFreeWildcard(xmlSchemaWildcardPtr wildcard);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* LIBXML_SCHEMAS_ENABLED */
|
||||||
|
#endif /* __XML_SCHEMA_INTERNALS_H__ */
|
|
@ -0,0 +1,142 @@
|
||||||
|
/*
|
||||||
|
* Summary: XML Schemastron implementation
|
||||||
|
* Description: interface to the XML Schematron validity checking.
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef __XML_SCHEMATRON_H__
|
||||||
|
#define __XML_SCHEMATRON_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
|
||||||
|
#ifdef LIBXML_SCHEMATRON_ENABLED
|
||||||
|
|
||||||
|
#include <libxml/tree.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
XML_SCHEMATRON_OUT_QUIET = 1 << 0, /* quiet no report */
|
||||||
|
XML_SCHEMATRON_OUT_TEXT = 1 << 1, /* build a textual report */
|
||||||
|
XML_SCHEMATRON_OUT_XML = 1 << 2, /* output SVRL */
|
||||||
|
XML_SCHEMATRON_OUT_ERROR = 1 << 3, /* output via xmlStructuredErrorFunc */
|
||||||
|
XML_SCHEMATRON_OUT_FILE = 1 << 8, /* output to a file descriptor */
|
||||||
|
XML_SCHEMATRON_OUT_BUFFER = 1 << 9, /* output to a buffer */
|
||||||
|
XML_SCHEMATRON_OUT_IO = 1 << 10 /* output to I/O mechanism */
|
||||||
|
} xmlSchematronValidOptions;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The schemas related types are kept internal
|
||||||
|
*/
|
||||||
|
typedef struct _xmlSchematron xmlSchematron;
|
||||||
|
typedef xmlSchematron *xmlSchematronPtr;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlSchematronValidityErrorFunc:
|
||||||
|
* @ctx: the validation context
|
||||||
|
* @msg: the message
|
||||||
|
* @...: extra arguments
|
||||||
|
*
|
||||||
|
* Signature of an error callback from a Schematron validation
|
||||||
|
*/
|
||||||
|
typedef void (*xmlSchematronValidityErrorFunc) (void *ctx, const char *msg, ...);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlSchematronValidityWarningFunc:
|
||||||
|
* @ctx: the validation context
|
||||||
|
* @msg: the message
|
||||||
|
* @...: extra arguments
|
||||||
|
*
|
||||||
|
* Signature of a warning callback from a Schematron validation
|
||||||
|
*/
|
||||||
|
typedef void (*xmlSchematronValidityWarningFunc) (void *ctx, const char *msg, ...);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A schemas validation context
|
||||||
|
*/
|
||||||
|
typedef struct _xmlSchematronParserCtxt xmlSchematronParserCtxt;
|
||||||
|
typedef xmlSchematronParserCtxt *xmlSchematronParserCtxtPtr;
|
||||||
|
|
||||||
|
typedef struct _xmlSchematronValidCtxt xmlSchematronValidCtxt;
|
||||||
|
typedef xmlSchematronValidCtxt *xmlSchematronValidCtxtPtr;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Interfaces for parsing.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlSchematronParserCtxtPtr XMLCALL
|
||||||
|
xmlSchematronNewParserCtxt (const char *URL);
|
||||||
|
XMLPUBFUN xmlSchematronParserCtxtPtr XMLCALL
|
||||||
|
xmlSchematronNewMemParserCtxt(const char *buffer,
|
||||||
|
int size);
|
||||||
|
XMLPUBFUN xmlSchematronParserCtxtPtr XMLCALL
|
||||||
|
xmlSchematronNewDocParserCtxt(xmlDocPtr doc);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSchematronFreeParserCtxt (xmlSchematronParserCtxtPtr ctxt);
|
||||||
|
/*****
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSchematronSetParserErrors(xmlSchematronParserCtxtPtr ctxt,
|
||||||
|
xmlSchematronValidityErrorFunc err,
|
||||||
|
xmlSchematronValidityWarningFunc warn,
|
||||||
|
void *ctx);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchematronGetParserErrors(xmlSchematronParserCtxtPtr ctxt,
|
||||||
|
xmlSchematronValidityErrorFunc * err,
|
||||||
|
xmlSchematronValidityWarningFunc * warn,
|
||||||
|
void **ctx);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchematronIsValid (xmlSchematronValidCtxtPtr ctxt);
|
||||||
|
*****/
|
||||||
|
XMLPUBFUN xmlSchematronPtr XMLCALL
|
||||||
|
xmlSchematronParse (xmlSchematronParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSchematronFree (xmlSchematronPtr schema);
|
||||||
|
/*
|
||||||
|
* Interfaces for validating
|
||||||
|
*/
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSchematronSetValidStructuredErrors(
|
||||||
|
xmlSchematronValidCtxtPtr ctxt,
|
||||||
|
xmlStructuredErrorFunc serror,
|
||||||
|
void *ctx);
|
||||||
|
/******
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSchematronSetValidErrors (xmlSchematronValidCtxtPtr ctxt,
|
||||||
|
xmlSchematronValidityErrorFunc err,
|
||||||
|
xmlSchematronValidityWarningFunc warn,
|
||||||
|
void *ctx);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchematronGetValidErrors (xmlSchematronValidCtxtPtr ctxt,
|
||||||
|
xmlSchematronValidityErrorFunc *err,
|
||||||
|
xmlSchematronValidityWarningFunc *warn,
|
||||||
|
void **ctx);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchematronSetValidOptions(xmlSchematronValidCtxtPtr ctxt,
|
||||||
|
int options);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchematronValidCtxtGetOptions(xmlSchematronValidCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchematronValidateOneElement (xmlSchematronValidCtxtPtr ctxt,
|
||||||
|
xmlNodePtr elem);
|
||||||
|
*******/
|
||||||
|
|
||||||
|
XMLPUBFUN xmlSchematronValidCtxtPtr XMLCALL
|
||||||
|
xmlSchematronNewValidCtxt (xmlSchematronPtr schema,
|
||||||
|
int options);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSchematronFreeValidCtxt (xmlSchematronValidCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchematronValidateDoc (xmlSchematronValidCtxtPtr ctxt,
|
||||||
|
xmlDocPtr instance);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* LIBXML_SCHEMATRON_ENABLED */
|
||||||
|
#endif /* __XML_SCHEMATRON_H__ */
|
|
@ -0,0 +1,84 @@
|
||||||
|
/**
|
||||||
|
* Summary: interfaces for thread handling
|
||||||
|
* Description: set of generic threading related routines
|
||||||
|
* should work with pthreads, Windows native or TLS threads
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_THREADS_H__
|
||||||
|
#define __XML_THREADS_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* xmlMutex are a simple mutual exception locks.
|
||||||
|
*/
|
||||||
|
typedef struct _xmlMutex xmlMutex;
|
||||||
|
typedef xmlMutex *xmlMutexPtr;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* xmlRMutex are reentrant mutual exception locks.
|
||||||
|
*/
|
||||||
|
typedef struct _xmlRMutex xmlRMutex;
|
||||||
|
typedef xmlRMutex *xmlRMutexPtr;
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#include <libxml/globals.h>
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
XMLPUBFUN xmlMutexPtr XMLCALL
|
||||||
|
xmlNewMutex (void);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlMutexLock (xmlMutexPtr tok);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlMutexUnlock (xmlMutexPtr tok);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlFreeMutex (xmlMutexPtr tok);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlRMutexPtr XMLCALL
|
||||||
|
xmlNewRMutex (void);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlRMutexLock (xmlRMutexPtr tok);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlRMutexUnlock (xmlRMutexPtr tok);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlFreeRMutex (xmlRMutexPtr tok);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Library wide APIs.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlInitThreads (void);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlLockLibrary (void);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlUnlockLibrary(void);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlGetThreadId (void);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlIsMainThread (void);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlCleanupThreads(void);
|
||||||
|
XMLPUBFUN xmlGlobalStatePtr XMLCALL
|
||||||
|
xmlGetGlobalState(void);
|
||||||
|
|
||||||
|
#if defined(HAVE_WIN32_THREADS) && !defined(HAVE_COMPILER_TLS) && defined(LIBXML_STATIC_FOR_DLL)
|
||||||
|
int XMLCALL xmlDllMain(void *hinstDLL, unsigned long fdwReason, void *lpvReserved);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#endif /* __XML_THREADS_H__ */
|
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,94 @@
|
||||||
|
/**
|
||||||
|
* Summary: library of generic URI related routines
|
||||||
|
* Description: library of generic URI related routines
|
||||||
|
* Implements RFC 2396
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_URI_H__
|
||||||
|
#define __XML_URI_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
#include <libxml/tree.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlURI:
|
||||||
|
*
|
||||||
|
* A parsed URI reference. This is a struct containing the various fields
|
||||||
|
* as described in RFC 2396 but separated for further processing.
|
||||||
|
*
|
||||||
|
* Note: query is a deprecated field which is incorrectly unescaped.
|
||||||
|
* query_raw takes precedence over query if the former is set.
|
||||||
|
* See: http://mail.gnome.org/archives/xml/2007-April/thread.html#00127
|
||||||
|
*/
|
||||||
|
typedef struct _xmlURI xmlURI;
|
||||||
|
typedef xmlURI *xmlURIPtr;
|
||||||
|
struct _xmlURI {
|
||||||
|
char *scheme; /* the URI scheme */
|
||||||
|
char *opaque; /* opaque part */
|
||||||
|
char *authority; /* the authority part */
|
||||||
|
char *server; /* the server part */
|
||||||
|
char *user; /* the user part */
|
||||||
|
int port; /* the port number */
|
||||||
|
char *path; /* the path string */
|
||||||
|
char *query; /* the query string (deprecated - use with caution) */
|
||||||
|
char *fragment; /* the fragment identifier */
|
||||||
|
int cleanup; /* parsing potentially unclean URI */
|
||||||
|
char *query_raw; /* the query string (as it appears in the URI) */
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This function is in tree.h:
|
||||||
|
* xmlChar * xmlNodeGetBase (xmlDocPtr doc,
|
||||||
|
* xmlNodePtr cur);
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlURIPtr XMLCALL
|
||||||
|
xmlCreateURI (void);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlBuildURI (const xmlChar *URI,
|
||||||
|
const xmlChar *base);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlBuildRelativeURI (const xmlChar *URI,
|
||||||
|
const xmlChar *base);
|
||||||
|
XMLPUBFUN xmlURIPtr XMLCALL
|
||||||
|
xmlParseURI (const char *str);
|
||||||
|
XMLPUBFUN xmlURIPtr XMLCALL
|
||||||
|
xmlParseURIRaw (const char *str,
|
||||||
|
int raw);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlParseURIReference (xmlURIPtr uri,
|
||||||
|
const char *str);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlSaveUri (xmlURIPtr uri);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlPrintURI (FILE *stream,
|
||||||
|
xmlURIPtr uri);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlURIEscapeStr (const xmlChar *str,
|
||||||
|
const xmlChar *list);
|
||||||
|
XMLPUBFUN char * XMLCALL
|
||||||
|
xmlURIUnescapeString (const char *str,
|
||||||
|
int len,
|
||||||
|
char *target);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlNormalizeURIPath (char *path);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlURIEscape (const xmlChar *str);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlFreeURI (xmlURIPtr uri);
|
||||||
|
XMLPUBFUN xmlChar* XMLCALL
|
||||||
|
xmlCanonicPath (const xmlChar *path);
|
||||||
|
XMLPUBFUN xmlChar* XMLCALL
|
||||||
|
xmlPathToURI (const xmlChar *path);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif /* __XML_URI_H__ */
|
|
@ -0,0 +1,458 @@
|
||||||
|
/*
|
||||||
|
* Summary: The DTD validation
|
||||||
|
* Description: API for the DTD handling and the validity checking
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef __XML_VALID_H__
|
||||||
|
#define __XML_VALID_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
#include <libxml/xmlerror.h>
|
||||||
|
#include <libxml/tree.h>
|
||||||
|
#include <libxml/list.h>
|
||||||
|
#include <libxml/xmlautomata.h>
|
||||||
|
#include <libxml/xmlregexp.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Validation state added for non-determinist content model.
|
||||||
|
*/
|
||||||
|
typedef struct _xmlValidState xmlValidState;
|
||||||
|
typedef xmlValidState *xmlValidStatePtr;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlValidityErrorFunc:
|
||||||
|
* @ctx: usually an xmlValidCtxtPtr to a validity error context,
|
||||||
|
* but comes from ctxt->userData (which normally contains such
|
||||||
|
* a pointer); ctxt->userData can be changed by the user.
|
||||||
|
* @msg: the string to format *printf like vararg
|
||||||
|
* @...: remaining arguments to the format
|
||||||
|
*
|
||||||
|
* Callback called when a validity error is found. This is a message
|
||||||
|
* oriented function similar to an *printf function.
|
||||||
|
*/
|
||||||
|
typedef void (XMLCDECL *xmlValidityErrorFunc) (void *ctx,
|
||||||
|
const char *msg,
|
||||||
|
...) LIBXML_ATTR_FORMAT(2,3);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlValidityWarningFunc:
|
||||||
|
* @ctx: usually an xmlValidCtxtPtr to a validity error context,
|
||||||
|
* but comes from ctxt->userData (which normally contains such
|
||||||
|
* a pointer); ctxt->userData can be changed by the user.
|
||||||
|
* @msg: the string to format *printf like vararg
|
||||||
|
* @...: remaining arguments to the format
|
||||||
|
*
|
||||||
|
* Callback called when a validity warning is found. This is a message
|
||||||
|
* oriented function similar to an *printf function.
|
||||||
|
*/
|
||||||
|
typedef void (XMLCDECL *xmlValidityWarningFunc) (void *ctx,
|
||||||
|
const char *msg,
|
||||||
|
...) LIBXML_ATTR_FORMAT(2,3);
|
||||||
|
|
||||||
|
#ifdef IN_LIBXML
|
||||||
|
/**
|
||||||
|
* XML_CTXT_FINISH_DTD_0:
|
||||||
|
*
|
||||||
|
* Special value for finishDtd field when embedded in an xmlParserCtxt
|
||||||
|
*/
|
||||||
|
#define XML_CTXT_FINISH_DTD_0 0xabcd1234
|
||||||
|
/**
|
||||||
|
* XML_CTXT_FINISH_DTD_1:
|
||||||
|
*
|
||||||
|
* Special value for finishDtd field when embedded in an xmlParserCtxt
|
||||||
|
*/
|
||||||
|
#define XML_CTXT_FINISH_DTD_1 0xabcd1235
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* xmlValidCtxt:
|
||||||
|
* An xmlValidCtxt is used for error reporting when validating.
|
||||||
|
*/
|
||||||
|
typedef struct _xmlValidCtxt xmlValidCtxt;
|
||||||
|
typedef xmlValidCtxt *xmlValidCtxtPtr;
|
||||||
|
struct _xmlValidCtxt {
|
||||||
|
void *userData; /* user specific data block */
|
||||||
|
xmlValidityErrorFunc error; /* the callback in case of errors */
|
||||||
|
xmlValidityWarningFunc warning; /* the callback in case of warning */
|
||||||
|
|
||||||
|
/* Node analysis stack used when validating within entities */
|
||||||
|
xmlNodePtr node; /* Current parsed Node */
|
||||||
|
int nodeNr; /* Depth of the parsing stack */
|
||||||
|
int nodeMax; /* Max depth of the parsing stack */
|
||||||
|
xmlNodePtr *nodeTab; /* array of nodes */
|
||||||
|
|
||||||
|
unsigned int finishDtd; /* finished validating the Dtd ? */
|
||||||
|
xmlDocPtr doc; /* the document */
|
||||||
|
int valid; /* temporary validity check result */
|
||||||
|
|
||||||
|
/* state state used for non-determinist content validation */
|
||||||
|
xmlValidState *vstate; /* current state */
|
||||||
|
int vstateNr; /* Depth of the validation stack */
|
||||||
|
int vstateMax; /* Max depth of the validation stack */
|
||||||
|
xmlValidState *vstateTab; /* array of validation states */
|
||||||
|
|
||||||
|
#ifdef LIBXML_REGEXP_ENABLED
|
||||||
|
xmlAutomataPtr am; /* the automata */
|
||||||
|
xmlAutomataStatePtr state; /* used to build the automata */
|
||||||
|
#else
|
||||||
|
void *am;
|
||||||
|
void *state;
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* ALL notation declarations are stored in a table.
|
||||||
|
* There is one table per DTD.
|
||||||
|
*/
|
||||||
|
|
||||||
|
typedef struct _xmlHashTable xmlNotationTable;
|
||||||
|
typedef xmlNotationTable *xmlNotationTablePtr;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* ALL element declarations are stored in a table.
|
||||||
|
* There is one table per DTD.
|
||||||
|
*/
|
||||||
|
|
||||||
|
typedef struct _xmlHashTable xmlElementTable;
|
||||||
|
typedef xmlElementTable *xmlElementTablePtr;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* ALL attribute declarations are stored in a table.
|
||||||
|
* There is one table per DTD.
|
||||||
|
*/
|
||||||
|
|
||||||
|
typedef struct _xmlHashTable xmlAttributeTable;
|
||||||
|
typedef xmlAttributeTable *xmlAttributeTablePtr;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* ALL IDs attributes are stored in a table.
|
||||||
|
* There is one table per document.
|
||||||
|
*/
|
||||||
|
|
||||||
|
typedef struct _xmlHashTable xmlIDTable;
|
||||||
|
typedef xmlIDTable *xmlIDTablePtr;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* ALL Refs attributes are stored in a table.
|
||||||
|
* There is one table per document.
|
||||||
|
*/
|
||||||
|
|
||||||
|
typedef struct _xmlHashTable xmlRefTable;
|
||||||
|
typedef xmlRefTable *xmlRefTablePtr;
|
||||||
|
|
||||||
|
/* Notation */
|
||||||
|
XMLPUBFUN xmlNotationPtr XMLCALL
|
||||||
|
xmlAddNotationDecl (xmlValidCtxtPtr ctxt,
|
||||||
|
xmlDtdPtr dtd,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *PublicID,
|
||||||
|
const xmlChar *SystemID);
|
||||||
|
#ifdef LIBXML_TREE_ENABLED
|
||||||
|
XMLPUBFUN xmlNotationTablePtr XMLCALL
|
||||||
|
xmlCopyNotationTable (xmlNotationTablePtr table);
|
||||||
|
#endif /* LIBXML_TREE_ENABLED */
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlFreeNotationTable (xmlNotationTablePtr table);
|
||||||
|
#ifdef LIBXML_OUTPUT_ENABLED
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlDumpNotationDecl (xmlBufferPtr buf,
|
||||||
|
xmlNotationPtr nota);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlDumpNotationTable (xmlBufferPtr buf,
|
||||||
|
xmlNotationTablePtr table);
|
||||||
|
#endif /* LIBXML_OUTPUT_ENABLED */
|
||||||
|
|
||||||
|
/* Element Content */
|
||||||
|
/* the non Doc version are being deprecated */
|
||||||
|
XMLPUBFUN xmlElementContentPtr XMLCALL
|
||||||
|
xmlNewElementContent (const xmlChar *name,
|
||||||
|
xmlElementContentType type);
|
||||||
|
XMLPUBFUN xmlElementContentPtr XMLCALL
|
||||||
|
xmlCopyElementContent (xmlElementContentPtr content);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlFreeElementContent (xmlElementContentPtr cur);
|
||||||
|
/* the new versions with doc argument */
|
||||||
|
XMLPUBFUN xmlElementContentPtr XMLCALL
|
||||||
|
xmlNewDocElementContent (xmlDocPtr doc,
|
||||||
|
const xmlChar *name,
|
||||||
|
xmlElementContentType type);
|
||||||
|
XMLPUBFUN xmlElementContentPtr XMLCALL
|
||||||
|
xmlCopyDocElementContent(xmlDocPtr doc,
|
||||||
|
xmlElementContentPtr content);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlFreeDocElementContent(xmlDocPtr doc,
|
||||||
|
xmlElementContentPtr cur);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSnprintfElementContent(char *buf,
|
||||||
|
int size,
|
||||||
|
xmlElementContentPtr content,
|
||||||
|
int englob);
|
||||||
|
#ifdef LIBXML_OUTPUT_ENABLED
|
||||||
|
/* DEPRECATED */
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSprintfElementContent(char *buf,
|
||||||
|
xmlElementContentPtr content,
|
||||||
|
int englob);
|
||||||
|
#endif /* LIBXML_OUTPUT_ENABLED */
|
||||||
|
/* DEPRECATED */
|
||||||
|
|
||||||
|
/* Element */
|
||||||
|
XMLPUBFUN xmlElementPtr XMLCALL
|
||||||
|
xmlAddElementDecl (xmlValidCtxtPtr ctxt,
|
||||||
|
xmlDtdPtr dtd,
|
||||||
|
const xmlChar *name,
|
||||||
|
xmlElementTypeVal type,
|
||||||
|
xmlElementContentPtr content);
|
||||||
|
#ifdef LIBXML_TREE_ENABLED
|
||||||
|
XMLPUBFUN xmlElementTablePtr XMLCALL
|
||||||
|
xmlCopyElementTable (xmlElementTablePtr table);
|
||||||
|
#endif /* LIBXML_TREE_ENABLED */
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlFreeElementTable (xmlElementTablePtr table);
|
||||||
|
#ifdef LIBXML_OUTPUT_ENABLED
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlDumpElementTable (xmlBufferPtr buf,
|
||||||
|
xmlElementTablePtr table);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlDumpElementDecl (xmlBufferPtr buf,
|
||||||
|
xmlElementPtr elem);
|
||||||
|
#endif /* LIBXML_OUTPUT_ENABLED */
|
||||||
|
|
||||||
|
/* Enumeration */
|
||||||
|
XMLPUBFUN xmlEnumerationPtr XMLCALL
|
||||||
|
xmlCreateEnumeration (const xmlChar *name);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlFreeEnumeration (xmlEnumerationPtr cur);
|
||||||
|
#ifdef LIBXML_TREE_ENABLED
|
||||||
|
XMLPUBFUN xmlEnumerationPtr XMLCALL
|
||||||
|
xmlCopyEnumeration (xmlEnumerationPtr cur);
|
||||||
|
#endif /* LIBXML_TREE_ENABLED */
|
||||||
|
|
||||||
|
/* Attribute */
|
||||||
|
XMLPUBFUN xmlAttributePtr XMLCALL
|
||||||
|
xmlAddAttributeDecl (xmlValidCtxtPtr ctxt,
|
||||||
|
xmlDtdPtr dtd,
|
||||||
|
const xmlChar *elem,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *ns,
|
||||||
|
xmlAttributeType type,
|
||||||
|
xmlAttributeDefault def,
|
||||||
|
const xmlChar *defaultValue,
|
||||||
|
xmlEnumerationPtr tree);
|
||||||
|
#ifdef LIBXML_TREE_ENABLED
|
||||||
|
XMLPUBFUN xmlAttributeTablePtr XMLCALL
|
||||||
|
xmlCopyAttributeTable (xmlAttributeTablePtr table);
|
||||||
|
#endif /* LIBXML_TREE_ENABLED */
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlFreeAttributeTable (xmlAttributeTablePtr table);
|
||||||
|
#ifdef LIBXML_OUTPUT_ENABLED
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlDumpAttributeTable (xmlBufferPtr buf,
|
||||||
|
xmlAttributeTablePtr table);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlDumpAttributeDecl (xmlBufferPtr buf,
|
||||||
|
xmlAttributePtr attr);
|
||||||
|
#endif /* LIBXML_OUTPUT_ENABLED */
|
||||||
|
|
||||||
|
/* IDs */
|
||||||
|
XMLPUBFUN xmlIDPtr XMLCALL
|
||||||
|
xmlAddID (xmlValidCtxtPtr ctxt,
|
||||||
|
xmlDocPtr doc,
|
||||||
|
const xmlChar *value,
|
||||||
|
xmlAttrPtr attr);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlFreeIDTable (xmlIDTablePtr table);
|
||||||
|
XMLPUBFUN xmlAttrPtr XMLCALL
|
||||||
|
xmlGetID (xmlDocPtr doc,
|
||||||
|
const xmlChar *ID);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlIsID (xmlDocPtr doc,
|
||||||
|
xmlNodePtr elem,
|
||||||
|
xmlAttrPtr attr);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlRemoveID (xmlDocPtr doc,
|
||||||
|
xmlAttrPtr attr);
|
||||||
|
|
||||||
|
/* IDREFs */
|
||||||
|
XMLPUBFUN xmlRefPtr XMLCALL
|
||||||
|
xmlAddRef (xmlValidCtxtPtr ctxt,
|
||||||
|
xmlDocPtr doc,
|
||||||
|
const xmlChar *value,
|
||||||
|
xmlAttrPtr attr);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlFreeRefTable (xmlRefTablePtr table);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlIsRef (xmlDocPtr doc,
|
||||||
|
xmlNodePtr elem,
|
||||||
|
xmlAttrPtr attr);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlRemoveRef (xmlDocPtr doc,
|
||||||
|
xmlAttrPtr attr);
|
||||||
|
XMLPUBFUN xmlListPtr XMLCALL
|
||||||
|
xmlGetRefs (xmlDocPtr doc,
|
||||||
|
const xmlChar *ID);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The public function calls related to validity checking.
|
||||||
|
*/
|
||||||
|
#ifdef LIBXML_VALID_ENABLED
|
||||||
|
/* Allocate/Release Validation Contexts */
|
||||||
|
XMLPUBFUN xmlValidCtxtPtr XMLCALL
|
||||||
|
xmlNewValidCtxt(void);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlFreeValidCtxt(xmlValidCtxtPtr);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlValidateRoot (xmlValidCtxtPtr ctxt,
|
||||||
|
xmlDocPtr doc);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlValidateElementDecl (xmlValidCtxtPtr ctxt,
|
||||||
|
xmlDocPtr doc,
|
||||||
|
xmlElementPtr elem);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlValidNormalizeAttributeValue(xmlDocPtr doc,
|
||||||
|
xmlNodePtr elem,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *value);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlValidCtxtNormalizeAttributeValue(xmlValidCtxtPtr ctxt,
|
||||||
|
xmlDocPtr doc,
|
||||||
|
xmlNodePtr elem,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *value);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlValidateAttributeDecl(xmlValidCtxtPtr ctxt,
|
||||||
|
xmlDocPtr doc,
|
||||||
|
xmlAttributePtr attr);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlValidateAttributeValue(xmlAttributeType type,
|
||||||
|
const xmlChar *value);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlValidateNotationDecl (xmlValidCtxtPtr ctxt,
|
||||||
|
xmlDocPtr doc,
|
||||||
|
xmlNotationPtr nota);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlValidateDtd (xmlValidCtxtPtr ctxt,
|
||||||
|
xmlDocPtr doc,
|
||||||
|
xmlDtdPtr dtd);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlValidateDtdFinal (xmlValidCtxtPtr ctxt,
|
||||||
|
xmlDocPtr doc);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlValidateDocument (xmlValidCtxtPtr ctxt,
|
||||||
|
xmlDocPtr doc);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlValidateElement (xmlValidCtxtPtr ctxt,
|
||||||
|
xmlDocPtr doc,
|
||||||
|
xmlNodePtr elem);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlValidateOneElement (xmlValidCtxtPtr ctxt,
|
||||||
|
xmlDocPtr doc,
|
||||||
|
xmlNodePtr elem);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlValidateOneAttribute (xmlValidCtxtPtr ctxt,
|
||||||
|
xmlDocPtr doc,
|
||||||
|
xmlNodePtr elem,
|
||||||
|
xmlAttrPtr attr,
|
||||||
|
const xmlChar *value);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlValidateOneNamespace (xmlValidCtxtPtr ctxt,
|
||||||
|
xmlDocPtr doc,
|
||||||
|
xmlNodePtr elem,
|
||||||
|
const xmlChar *prefix,
|
||||||
|
xmlNsPtr ns,
|
||||||
|
const xmlChar *value);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlValidateDocumentFinal(xmlValidCtxtPtr ctxt,
|
||||||
|
xmlDocPtr doc);
|
||||||
|
#endif /* LIBXML_VALID_ENABLED */
|
||||||
|
|
||||||
|
#if defined(LIBXML_VALID_ENABLED) || defined(LIBXML_SCHEMAS_ENABLED)
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlValidateNotationUse (xmlValidCtxtPtr ctxt,
|
||||||
|
xmlDocPtr doc,
|
||||||
|
const xmlChar *notationName);
|
||||||
|
#endif /* LIBXML_VALID_ENABLED or LIBXML_SCHEMAS_ENABLED */
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlIsMixedElement (xmlDocPtr doc,
|
||||||
|
const xmlChar *name);
|
||||||
|
XMLPUBFUN xmlAttributePtr XMLCALL
|
||||||
|
xmlGetDtdAttrDesc (xmlDtdPtr dtd,
|
||||||
|
const xmlChar *elem,
|
||||||
|
const xmlChar *name);
|
||||||
|
XMLPUBFUN xmlAttributePtr XMLCALL
|
||||||
|
xmlGetDtdQAttrDesc (xmlDtdPtr dtd,
|
||||||
|
const xmlChar *elem,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *prefix);
|
||||||
|
XMLPUBFUN xmlNotationPtr XMLCALL
|
||||||
|
xmlGetDtdNotationDesc (xmlDtdPtr dtd,
|
||||||
|
const xmlChar *name);
|
||||||
|
XMLPUBFUN xmlElementPtr XMLCALL
|
||||||
|
xmlGetDtdQElementDesc (xmlDtdPtr dtd,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *prefix);
|
||||||
|
XMLPUBFUN xmlElementPtr XMLCALL
|
||||||
|
xmlGetDtdElementDesc (xmlDtdPtr dtd,
|
||||||
|
const xmlChar *name);
|
||||||
|
|
||||||
|
#ifdef LIBXML_VALID_ENABLED
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlValidGetPotentialChildren(xmlElementContent *ctree,
|
||||||
|
const xmlChar **names,
|
||||||
|
int *len,
|
||||||
|
int max);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlValidGetValidElements(xmlNode *prev,
|
||||||
|
xmlNode *next,
|
||||||
|
const xmlChar **names,
|
||||||
|
int max);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlValidateNameValue (const xmlChar *value);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlValidateNamesValue (const xmlChar *value);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlValidateNmtokenValue (const xmlChar *value);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlValidateNmtokensValue(const xmlChar *value);
|
||||||
|
|
||||||
|
#ifdef LIBXML_REGEXP_ENABLED
|
||||||
|
/*
|
||||||
|
* Validation based on the regexp support
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlValidBuildContentModel(xmlValidCtxtPtr ctxt,
|
||||||
|
xmlElementPtr elem);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlValidatePushElement (xmlValidCtxtPtr ctxt,
|
||||||
|
xmlDocPtr doc,
|
||||||
|
xmlNodePtr elem,
|
||||||
|
const xmlChar *qname);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlValidatePushCData (xmlValidCtxtPtr ctxt,
|
||||||
|
const xmlChar *data,
|
||||||
|
int len);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlValidatePopElement (xmlValidCtxtPtr ctxt,
|
||||||
|
xmlDocPtr doc,
|
||||||
|
xmlNodePtr elem,
|
||||||
|
const xmlChar *qname);
|
||||||
|
#endif /* LIBXML_REGEXP_ENABLED */
|
||||||
|
#endif /* LIBXML_VALID_ENABLED */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif /* __XML_VALID_H__ */
|
|
@ -0,0 +1,129 @@
|
||||||
|
/*
|
||||||
|
* Summary: implementation of XInclude
|
||||||
|
* Description: API to handle XInclude processing,
|
||||||
|
* implements the
|
||||||
|
* World Wide Web Consortium Last Call Working Draft 10 November 2003
|
||||||
|
* http://www.w3.org/TR/2003/WD-xinclude-20031110
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_XINCLUDE_H__
|
||||||
|
#define __XML_XINCLUDE_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
#include <libxml/tree.h>
|
||||||
|
|
||||||
|
#ifdef LIBXML_XINCLUDE_ENABLED
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* XINCLUDE_NS:
|
||||||
|
*
|
||||||
|
* Macro defining the Xinclude namespace: http://www.w3.org/2003/XInclude
|
||||||
|
*/
|
||||||
|
#define XINCLUDE_NS (const xmlChar *) "http://www.w3.org/2003/XInclude"
|
||||||
|
/**
|
||||||
|
* XINCLUDE_OLD_NS:
|
||||||
|
*
|
||||||
|
* Macro defining the draft Xinclude namespace: http://www.w3.org/2001/XInclude
|
||||||
|
*/
|
||||||
|
#define XINCLUDE_OLD_NS (const xmlChar *) "http://www.w3.org/2001/XInclude"
|
||||||
|
/**
|
||||||
|
* XINCLUDE_NODE:
|
||||||
|
*
|
||||||
|
* Macro defining "include"
|
||||||
|
*/
|
||||||
|
#define XINCLUDE_NODE (const xmlChar *) "include"
|
||||||
|
/**
|
||||||
|
* XINCLUDE_FALLBACK:
|
||||||
|
*
|
||||||
|
* Macro defining "fallback"
|
||||||
|
*/
|
||||||
|
#define XINCLUDE_FALLBACK (const xmlChar *) "fallback"
|
||||||
|
/**
|
||||||
|
* XINCLUDE_HREF:
|
||||||
|
*
|
||||||
|
* Macro defining "href"
|
||||||
|
*/
|
||||||
|
#define XINCLUDE_HREF (const xmlChar *) "href"
|
||||||
|
/**
|
||||||
|
* XINCLUDE_PARSE:
|
||||||
|
*
|
||||||
|
* Macro defining "parse"
|
||||||
|
*/
|
||||||
|
#define XINCLUDE_PARSE (const xmlChar *) "parse"
|
||||||
|
/**
|
||||||
|
* XINCLUDE_PARSE_XML:
|
||||||
|
*
|
||||||
|
* Macro defining "xml"
|
||||||
|
*/
|
||||||
|
#define XINCLUDE_PARSE_XML (const xmlChar *) "xml"
|
||||||
|
/**
|
||||||
|
* XINCLUDE_PARSE_TEXT:
|
||||||
|
*
|
||||||
|
* Macro defining "text"
|
||||||
|
*/
|
||||||
|
#define XINCLUDE_PARSE_TEXT (const xmlChar *) "text"
|
||||||
|
/**
|
||||||
|
* XINCLUDE_PARSE_ENCODING:
|
||||||
|
*
|
||||||
|
* Macro defining "encoding"
|
||||||
|
*/
|
||||||
|
#define XINCLUDE_PARSE_ENCODING (const xmlChar *) "encoding"
|
||||||
|
/**
|
||||||
|
* XINCLUDE_PARSE_XPOINTER:
|
||||||
|
*
|
||||||
|
* Macro defining "xpointer"
|
||||||
|
*/
|
||||||
|
#define XINCLUDE_PARSE_XPOINTER (const xmlChar *) "xpointer"
|
||||||
|
|
||||||
|
typedef struct _xmlXIncludeCtxt xmlXIncludeCtxt;
|
||||||
|
typedef xmlXIncludeCtxt *xmlXIncludeCtxtPtr;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* standalone processing
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlXIncludeProcess (xmlDocPtr doc);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlXIncludeProcessFlags (xmlDocPtr doc,
|
||||||
|
int flags);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlXIncludeProcessFlagsData(xmlDocPtr doc,
|
||||||
|
int flags,
|
||||||
|
void *data);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlXIncludeProcessTreeFlagsData(xmlNodePtr tree,
|
||||||
|
int flags,
|
||||||
|
void *data);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlXIncludeProcessTree (xmlNodePtr tree);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlXIncludeProcessTreeFlags(xmlNodePtr tree,
|
||||||
|
int flags);
|
||||||
|
/*
|
||||||
|
* contextual processing
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlXIncludeCtxtPtr XMLCALL
|
||||||
|
xmlXIncludeNewContext (xmlDocPtr doc);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlXIncludeSetFlags (xmlXIncludeCtxtPtr ctxt,
|
||||||
|
int flags);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXIncludeFreeContext (xmlXIncludeCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlXIncludeProcessNode (xmlXIncludeCtxtPtr ctxt,
|
||||||
|
xmlNodePtr tree);
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* LIBXML_XINCLUDE_ENABLED */
|
||||||
|
|
||||||
|
#endif /* __XML_XINCLUDE_H__ */
|
|
@ -0,0 +1,189 @@
|
||||||
|
/*
|
||||||
|
* Summary: unfinished XLink detection module
|
||||||
|
* Description: unfinished XLink detection module
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_XLINK_H__
|
||||||
|
#define __XML_XLINK_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
#include <libxml/tree.h>
|
||||||
|
|
||||||
|
#ifdef LIBXML_XPTR_ENABLED
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Various defines for the various Link properties.
|
||||||
|
*
|
||||||
|
* NOTE: the link detection layer will try to resolve QName expansion
|
||||||
|
* of namespaces. If "foo" is the prefix for "http://foo.com/"
|
||||||
|
* then the link detection layer will expand role="foo:myrole"
|
||||||
|
* to "http://foo.com/:myrole".
|
||||||
|
* NOTE: the link detection layer will expand URI-Refences found on
|
||||||
|
* href attributes by using the base mechanism if found.
|
||||||
|
*/
|
||||||
|
typedef xmlChar *xlinkHRef;
|
||||||
|
typedef xmlChar *xlinkRole;
|
||||||
|
typedef xmlChar *xlinkTitle;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
XLINK_TYPE_NONE = 0,
|
||||||
|
XLINK_TYPE_SIMPLE,
|
||||||
|
XLINK_TYPE_EXTENDED,
|
||||||
|
XLINK_TYPE_EXTENDED_SET
|
||||||
|
} xlinkType;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
XLINK_SHOW_NONE = 0,
|
||||||
|
XLINK_SHOW_NEW,
|
||||||
|
XLINK_SHOW_EMBED,
|
||||||
|
XLINK_SHOW_REPLACE
|
||||||
|
} xlinkShow;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
XLINK_ACTUATE_NONE = 0,
|
||||||
|
XLINK_ACTUATE_AUTO,
|
||||||
|
XLINK_ACTUATE_ONREQUEST
|
||||||
|
} xlinkActuate;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xlinkNodeDetectFunc:
|
||||||
|
* @ctx: user data pointer
|
||||||
|
* @node: the node to check
|
||||||
|
*
|
||||||
|
* This is the prototype for the link detection routine.
|
||||||
|
* It calls the default link detection callbacks upon link detection.
|
||||||
|
*/
|
||||||
|
typedef void (*xlinkNodeDetectFunc) (void *ctx, xmlNodePtr node);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The link detection module interact with the upper layers using
|
||||||
|
* a set of callback registered at parsing time.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xlinkSimpleLinkFunk:
|
||||||
|
* @ctx: user data pointer
|
||||||
|
* @node: the node carrying the link
|
||||||
|
* @href: the target of the link
|
||||||
|
* @role: the role string
|
||||||
|
* @title: the link title
|
||||||
|
*
|
||||||
|
* This is the prototype for a simple link detection callback.
|
||||||
|
*/
|
||||||
|
typedef void
|
||||||
|
(*xlinkSimpleLinkFunk) (void *ctx,
|
||||||
|
xmlNodePtr node,
|
||||||
|
const xlinkHRef href,
|
||||||
|
const xlinkRole role,
|
||||||
|
const xlinkTitle title);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xlinkExtendedLinkFunk:
|
||||||
|
* @ctx: user data pointer
|
||||||
|
* @node: the node carrying the link
|
||||||
|
* @nbLocators: the number of locators detected on the link
|
||||||
|
* @hrefs: pointer to the array of locator hrefs
|
||||||
|
* @roles: pointer to the array of locator roles
|
||||||
|
* @nbArcs: the number of arcs detected on the link
|
||||||
|
* @from: pointer to the array of source roles found on the arcs
|
||||||
|
* @to: pointer to the array of target roles found on the arcs
|
||||||
|
* @show: array of values for the show attributes found on the arcs
|
||||||
|
* @actuate: array of values for the actuate attributes found on the arcs
|
||||||
|
* @nbTitles: the number of titles detected on the link
|
||||||
|
* @title: array of titles detected on the link
|
||||||
|
* @langs: array of xml:lang values for the titles
|
||||||
|
*
|
||||||
|
* This is the prototype for a extended link detection callback.
|
||||||
|
*/
|
||||||
|
typedef void
|
||||||
|
(*xlinkExtendedLinkFunk)(void *ctx,
|
||||||
|
xmlNodePtr node,
|
||||||
|
int nbLocators,
|
||||||
|
const xlinkHRef *hrefs,
|
||||||
|
const xlinkRole *roles,
|
||||||
|
int nbArcs,
|
||||||
|
const xlinkRole *from,
|
||||||
|
const xlinkRole *to,
|
||||||
|
xlinkShow *show,
|
||||||
|
xlinkActuate *actuate,
|
||||||
|
int nbTitles,
|
||||||
|
const xlinkTitle *titles,
|
||||||
|
const xmlChar **langs);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xlinkExtendedLinkSetFunk:
|
||||||
|
* @ctx: user data pointer
|
||||||
|
* @node: the node carrying the link
|
||||||
|
* @nbLocators: the number of locators detected on the link
|
||||||
|
* @hrefs: pointer to the array of locator hrefs
|
||||||
|
* @roles: pointer to the array of locator roles
|
||||||
|
* @nbTitles: the number of titles detected on the link
|
||||||
|
* @title: array of titles detected on the link
|
||||||
|
* @langs: array of xml:lang values for the titles
|
||||||
|
*
|
||||||
|
* This is the prototype for a extended link set detection callback.
|
||||||
|
*/
|
||||||
|
typedef void
|
||||||
|
(*xlinkExtendedLinkSetFunk) (void *ctx,
|
||||||
|
xmlNodePtr node,
|
||||||
|
int nbLocators,
|
||||||
|
const xlinkHRef *hrefs,
|
||||||
|
const xlinkRole *roles,
|
||||||
|
int nbTitles,
|
||||||
|
const xlinkTitle *titles,
|
||||||
|
const xmlChar **langs);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This is the structure containing a set of Links detection callbacks.
|
||||||
|
*
|
||||||
|
* There is no default xlink callbacks, if one want to get link
|
||||||
|
* recognition activated, those call backs must be provided before parsing.
|
||||||
|
*/
|
||||||
|
typedef struct _xlinkHandler xlinkHandler;
|
||||||
|
typedef xlinkHandler *xlinkHandlerPtr;
|
||||||
|
struct _xlinkHandler {
|
||||||
|
xlinkSimpleLinkFunk simple;
|
||||||
|
xlinkExtendedLinkFunk extended;
|
||||||
|
xlinkExtendedLinkSetFunk set;
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The default detection routine, can be overridden, they call the default
|
||||||
|
* detection callbacks.
|
||||||
|
*/
|
||||||
|
|
||||||
|
XMLPUBFUN xlinkNodeDetectFunc XMLCALL
|
||||||
|
xlinkGetDefaultDetect (void);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xlinkSetDefaultDetect (xlinkNodeDetectFunc func);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Routines to set/get the default handlers.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xlinkHandlerPtr XMLCALL
|
||||||
|
xlinkGetDefaultHandler (void);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xlinkSetDefaultHandler (xlinkHandlerPtr handler);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Link detection module itself.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xlinkType XMLCALL
|
||||||
|
xlinkIsLink (xmlDocPtr doc,
|
||||||
|
xmlNodePtr node);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* LIBXML_XPTR_ENABLED */
|
||||||
|
|
||||||
|
#endif /* __XML_XLINK_H__ */
|
|
@ -0,0 +1,360 @@
|
||||||
|
/*
|
||||||
|
* Summary: interface for the I/O interfaces used by the parser
|
||||||
|
* Description: interface for the I/O interfaces used by the parser
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_IO_H__
|
||||||
|
#define __XML_IO_H__
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Those are the functions and datatypes for the parser input
|
||||||
|
* I/O structures.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlInputMatchCallback:
|
||||||
|
* @filename: the filename or URI
|
||||||
|
*
|
||||||
|
* Callback used in the I/O Input API to detect if the current handler
|
||||||
|
* can provide input fonctionnalities for this resource.
|
||||||
|
*
|
||||||
|
* Returns 1 if yes and 0 if another Input module should be used
|
||||||
|
*/
|
||||||
|
typedef int (XMLCALL *xmlInputMatchCallback) (char const *filename);
|
||||||
|
/**
|
||||||
|
* xmlInputOpenCallback:
|
||||||
|
* @filename: the filename or URI
|
||||||
|
*
|
||||||
|
* Callback used in the I/O Input API to open the resource
|
||||||
|
*
|
||||||
|
* Returns an Input context or NULL in case or error
|
||||||
|
*/
|
||||||
|
typedef void * (XMLCALL *xmlInputOpenCallback) (char const *filename);
|
||||||
|
/**
|
||||||
|
* xmlInputReadCallback:
|
||||||
|
* @context: an Input context
|
||||||
|
* @buffer: the buffer to store data read
|
||||||
|
* @len: the length of the buffer in bytes
|
||||||
|
*
|
||||||
|
* Callback used in the I/O Input API to read the resource
|
||||||
|
*
|
||||||
|
* Returns the number of bytes read or -1 in case of error
|
||||||
|
*/
|
||||||
|
typedef int (XMLCALL *xmlInputReadCallback) (void * context, char * buffer, int len);
|
||||||
|
/**
|
||||||
|
* xmlInputCloseCallback:
|
||||||
|
* @context: an Input context
|
||||||
|
*
|
||||||
|
* Callback used in the I/O Input API to close the resource
|
||||||
|
*
|
||||||
|
* Returns 0 or -1 in case of error
|
||||||
|
*/
|
||||||
|
typedef int (XMLCALL *xmlInputCloseCallback) (void * context);
|
||||||
|
|
||||||
|
#ifdef LIBXML_OUTPUT_ENABLED
|
||||||
|
/*
|
||||||
|
* Those are the functions and datatypes for the library output
|
||||||
|
* I/O structures.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlOutputMatchCallback:
|
||||||
|
* @filename: the filename or URI
|
||||||
|
*
|
||||||
|
* Callback used in the I/O Output API to detect if the current handler
|
||||||
|
* can provide output fonctionnalities for this resource.
|
||||||
|
*
|
||||||
|
* Returns 1 if yes and 0 if another Output module should be used
|
||||||
|
*/
|
||||||
|
typedef int (XMLCALL *xmlOutputMatchCallback) (char const *filename);
|
||||||
|
/**
|
||||||
|
* xmlOutputOpenCallback:
|
||||||
|
* @filename: the filename or URI
|
||||||
|
*
|
||||||
|
* Callback used in the I/O Output API to open the resource
|
||||||
|
*
|
||||||
|
* Returns an Output context or NULL in case or error
|
||||||
|
*/
|
||||||
|
typedef void * (XMLCALL *xmlOutputOpenCallback) (char const *filename);
|
||||||
|
/**
|
||||||
|
* xmlOutputWriteCallback:
|
||||||
|
* @context: an Output context
|
||||||
|
* @buffer: the buffer of data to write
|
||||||
|
* @len: the length of the buffer in bytes
|
||||||
|
*
|
||||||
|
* Callback used in the I/O Output API to write to the resource
|
||||||
|
*
|
||||||
|
* Returns the number of bytes written or -1 in case of error
|
||||||
|
*/
|
||||||
|
typedef int (XMLCALL *xmlOutputWriteCallback) (void * context, const char * buffer,
|
||||||
|
int len);
|
||||||
|
/**
|
||||||
|
* xmlOutputCloseCallback:
|
||||||
|
* @context: an Output context
|
||||||
|
*
|
||||||
|
* Callback used in the I/O Output API to close the resource
|
||||||
|
*
|
||||||
|
* Returns 0 or -1 in case of error
|
||||||
|
*/
|
||||||
|
typedef int (XMLCALL *xmlOutputCloseCallback) (void * context);
|
||||||
|
#endif /* LIBXML_OUTPUT_ENABLED */
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <libxml/globals.h>
|
||||||
|
#include <libxml/tree.h>
|
||||||
|
#include <libxml/parser.h>
|
||||||
|
#include <libxml/encoding.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
struct _xmlParserInputBuffer {
|
||||||
|
void* context;
|
||||||
|
xmlInputReadCallback readcallback;
|
||||||
|
xmlInputCloseCallback closecallback;
|
||||||
|
|
||||||
|
xmlCharEncodingHandlerPtr encoder; /* I18N conversions to UTF-8 */
|
||||||
|
|
||||||
|
xmlBufferPtr buffer; /* Local buffer encoded in UTF-8 */
|
||||||
|
xmlBufferPtr raw; /* if encoder != NULL buffer for raw input */
|
||||||
|
int compressed; /* -1=unknown, 0=not compressed, 1=compressed */
|
||||||
|
int error;
|
||||||
|
unsigned long rawconsumed;/* amount consumed from raw */
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef LIBXML_OUTPUT_ENABLED
|
||||||
|
struct _xmlOutputBuffer {
|
||||||
|
void* context;
|
||||||
|
xmlOutputWriteCallback writecallback;
|
||||||
|
xmlOutputCloseCallback closecallback;
|
||||||
|
|
||||||
|
xmlCharEncodingHandlerPtr encoder; /* I18N conversions to UTF-8 */
|
||||||
|
|
||||||
|
xmlBufferPtr buffer; /* Local buffer encoded in UTF-8 or ISOLatin */
|
||||||
|
xmlBufferPtr conv; /* if encoder != NULL buffer for output */
|
||||||
|
int written; /* total number of byte written */
|
||||||
|
int error;
|
||||||
|
};
|
||||||
|
#endif /* LIBXML_OUTPUT_ENABLED */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Interfaces for input
|
||||||
|
*/
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlCleanupInputCallbacks (void);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlPopInputCallbacks (void);
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlRegisterDefaultInputCallbacks (void);
|
||||||
|
XMLPUBFUN xmlParserInputBufferPtr XMLCALL
|
||||||
|
xmlAllocParserInputBuffer (xmlCharEncoding enc);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlParserInputBufferPtr XMLCALL
|
||||||
|
xmlParserInputBufferCreateFilename (const char *URI,
|
||||||
|
xmlCharEncoding enc);
|
||||||
|
XMLPUBFUN xmlParserInputBufferPtr XMLCALL
|
||||||
|
xmlParserInputBufferCreateFile (FILE *file,
|
||||||
|
xmlCharEncoding enc);
|
||||||
|
XMLPUBFUN xmlParserInputBufferPtr XMLCALL
|
||||||
|
xmlParserInputBufferCreateFd (int fd,
|
||||||
|
xmlCharEncoding enc);
|
||||||
|
XMLPUBFUN xmlParserInputBufferPtr XMLCALL
|
||||||
|
xmlParserInputBufferCreateMem (const char *mem, int size,
|
||||||
|
xmlCharEncoding enc);
|
||||||
|
XMLPUBFUN xmlParserInputBufferPtr XMLCALL
|
||||||
|
xmlParserInputBufferCreateStatic (const char *mem, int size,
|
||||||
|
xmlCharEncoding enc);
|
||||||
|
XMLPUBFUN xmlParserInputBufferPtr XMLCALL
|
||||||
|
xmlParserInputBufferCreateIO (xmlInputReadCallback ioread,
|
||||||
|
xmlInputCloseCallback ioclose,
|
||||||
|
void *ioctx,
|
||||||
|
xmlCharEncoding enc);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlParserInputBufferRead (xmlParserInputBufferPtr in,
|
||||||
|
int len);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlParserInputBufferGrow (xmlParserInputBufferPtr in,
|
||||||
|
int len);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlParserInputBufferPush (xmlParserInputBufferPtr in,
|
||||||
|
int len,
|
||||||
|
const char *buf);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlFreeParserInputBuffer (xmlParserInputBufferPtr in);
|
||||||
|
XMLPUBFUN char * XMLCALL
|
||||||
|
xmlParserGetDirectory (const char *filename);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlRegisterInputCallbacks (xmlInputMatchCallback matchFunc,
|
||||||
|
xmlInputOpenCallback openFunc,
|
||||||
|
xmlInputReadCallback readFunc,
|
||||||
|
xmlInputCloseCallback closeFunc);
|
||||||
|
|
||||||
|
xmlParserInputBufferPtr
|
||||||
|
__xmlParserInputBufferCreateFilename(const char *URI,
|
||||||
|
xmlCharEncoding enc);
|
||||||
|
|
||||||
|
#ifdef LIBXML_OUTPUT_ENABLED
|
||||||
|
/*
|
||||||
|
* Interfaces for output
|
||||||
|
*/
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlCleanupOutputCallbacks (void);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlRegisterDefaultOutputCallbacks(void);
|
||||||
|
XMLPUBFUN xmlOutputBufferPtr XMLCALL
|
||||||
|
xmlAllocOutputBuffer (xmlCharEncodingHandlerPtr encoder);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlOutputBufferPtr XMLCALL
|
||||||
|
xmlOutputBufferCreateFilename (const char *URI,
|
||||||
|
xmlCharEncodingHandlerPtr encoder,
|
||||||
|
int compression);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlOutputBufferPtr XMLCALL
|
||||||
|
xmlOutputBufferCreateFile (FILE *file,
|
||||||
|
xmlCharEncodingHandlerPtr encoder);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlOutputBufferPtr XMLCALL
|
||||||
|
xmlOutputBufferCreateBuffer (xmlBufferPtr buffer,
|
||||||
|
xmlCharEncodingHandlerPtr encoder);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlOutputBufferPtr XMLCALL
|
||||||
|
xmlOutputBufferCreateFd (int fd,
|
||||||
|
xmlCharEncodingHandlerPtr encoder);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlOutputBufferPtr XMLCALL
|
||||||
|
xmlOutputBufferCreateIO (xmlOutputWriteCallback iowrite,
|
||||||
|
xmlOutputCloseCallback ioclose,
|
||||||
|
void *ioctx,
|
||||||
|
xmlCharEncodingHandlerPtr encoder);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlOutputBufferWrite (xmlOutputBufferPtr out,
|
||||||
|
int len,
|
||||||
|
const char *buf);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlOutputBufferWriteString (xmlOutputBufferPtr out,
|
||||||
|
const char *str);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlOutputBufferWriteEscape (xmlOutputBufferPtr out,
|
||||||
|
const xmlChar *str,
|
||||||
|
xmlCharEncodingOutputFunc escaping);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlOutputBufferFlush (xmlOutputBufferPtr out);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlOutputBufferClose (xmlOutputBufferPtr out);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlRegisterOutputCallbacks (xmlOutputMatchCallback matchFunc,
|
||||||
|
xmlOutputOpenCallback openFunc,
|
||||||
|
xmlOutputWriteCallback writeFunc,
|
||||||
|
xmlOutputCloseCallback closeFunc);
|
||||||
|
|
||||||
|
xmlOutputBufferPtr
|
||||||
|
__xmlOutputBufferCreateFilename(const char *URI,
|
||||||
|
xmlCharEncodingHandlerPtr encoder,
|
||||||
|
int compression);
|
||||||
|
|
||||||
|
#ifdef LIBXML_HTTP_ENABLED
|
||||||
|
/* This function only exists if HTTP support built into the library */
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlRegisterHTTPPostCallbacks (void );
|
||||||
|
#endif /* LIBXML_HTTP_ENABLED */
|
||||||
|
|
||||||
|
#endif /* LIBXML_OUTPUT_ENABLED */
|
||||||
|
|
||||||
|
XMLPUBFUN xmlParserInputPtr XMLCALL
|
||||||
|
xmlCheckHTTPInput (xmlParserCtxtPtr ctxt,
|
||||||
|
xmlParserInputPtr ret);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* A predefined entity loader disabling network accesses
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlParserInputPtr XMLCALL
|
||||||
|
xmlNoNetExternalEntityLoader (const char *URL,
|
||||||
|
const char *ID,
|
||||||
|
xmlParserCtxtPtr ctxt);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* xmlNormalizeWindowsPath is obsolete, don't use it.
|
||||||
|
* Check xmlCanonicPath in uri.h for a better alternative.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlNormalizeWindowsPath (const xmlChar *path);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlCheckFilename (const char *path);
|
||||||
|
/**
|
||||||
|
* Default 'file://' protocol callbacks
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlFileMatch (const char *filename);
|
||||||
|
XMLPUBFUN void * XMLCALL
|
||||||
|
xmlFileOpen (const char *filename);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlFileRead (void * context,
|
||||||
|
char * buffer,
|
||||||
|
int len);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlFileClose (void * context);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Default 'http://' protocol callbacks
|
||||||
|
*/
|
||||||
|
#ifdef LIBXML_HTTP_ENABLED
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlIOHTTPMatch (const char *filename);
|
||||||
|
XMLPUBFUN void * XMLCALL
|
||||||
|
xmlIOHTTPOpen (const char *filename);
|
||||||
|
#ifdef LIBXML_OUTPUT_ENABLED
|
||||||
|
XMLPUBFUN void * XMLCALL
|
||||||
|
xmlIOHTTPOpenW (const char * post_uri,
|
||||||
|
int compression );
|
||||||
|
#endif /* LIBXML_OUTPUT_ENABLED */
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlIOHTTPRead (void * context,
|
||||||
|
char * buffer,
|
||||||
|
int len);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlIOHTTPClose (void * context);
|
||||||
|
#endif /* LIBXML_HTTP_ENABLED */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Default 'ftp://' protocol callbacks
|
||||||
|
*/
|
||||||
|
#ifdef LIBXML_FTP_ENABLED
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlIOFTPMatch (const char *filename);
|
||||||
|
XMLPUBFUN void * XMLCALL
|
||||||
|
xmlIOFTPOpen (const char *filename);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlIOFTPRead (void * context,
|
||||||
|
char * buffer,
|
||||||
|
int len);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlIOFTPClose (void * context);
|
||||||
|
#endif /* LIBXML_FTP_ENABLED */
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* __XML_IO_H__ */
|
|
@ -0,0 +1,146 @@
|
||||||
|
/*
|
||||||
|
* Summary: API to build regexp automata
|
||||||
|
* Description: the API to build regexp automata
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_AUTOMATA_H__
|
||||||
|
#define __XML_AUTOMATA_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
#include <libxml/tree.h>
|
||||||
|
|
||||||
|
#ifdef LIBXML_REGEXP_ENABLED
|
||||||
|
#ifdef LIBXML_AUTOMATA_ENABLED
|
||||||
|
#include <libxml/xmlregexp.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlAutomataPtr:
|
||||||
|
*
|
||||||
|
* A libxml automata description, It can be compiled into a regexp
|
||||||
|
*/
|
||||||
|
typedef struct _xmlAutomata xmlAutomata;
|
||||||
|
typedef xmlAutomata *xmlAutomataPtr;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlAutomataStatePtr:
|
||||||
|
*
|
||||||
|
* A state int the automata description,
|
||||||
|
*/
|
||||||
|
typedef struct _xmlAutomataState xmlAutomataState;
|
||||||
|
typedef xmlAutomataState *xmlAutomataStatePtr;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Building API
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlAutomataPtr XMLCALL
|
||||||
|
xmlNewAutomata (void);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlFreeAutomata (xmlAutomataPtr am);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlAutomataStatePtr XMLCALL
|
||||||
|
xmlAutomataGetInitState (xmlAutomataPtr am);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlAutomataSetFinalState (xmlAutomataPtr am,
|
||||||
|
xmlAutomataStatePtr state);
|
||||||
|
XMLPUBFUN xmlAutomataStatePtr XMLCALL
|
||||||
|
xmlAutomataNewState (xmlAutomataPtr am);
|
||||||
|
XMLPUBFUN xmlAutomataStatePtr XMLCALL
|
||||||
|
xmlAutomataNewTransition (xmlAutomataPtr am,
|
||||||
|
xmlAutomataStatePtr from,
|
||||||
|
xmlAutomataStatePtr to,
|
||||||
|
const xmlChar *token,
|
||||||
|
void *data);
|
||||||
|
XMLPUBFUN xmlAutomataStatePtr XMLCALL
|
||||||
|
xmlAutomataNewTransition2 (xmlAutomataPtr am,
|
||||||
|
xmlAutomataStatePtr from,
|
||||||
|
xmlAutomataStatePtr to,
|
||||||
|
const xmlChar *token,
|
||||||
|
const xmlChar *token2,
|
||||||
|
void *data);
|
||||||
|
XMLPUBFUN xmlAutomataStatePtr XMLCALL
|
||||||
|
xmlAutomataNewNegTrans (xmlAutomataPtr am,
|
||||||
|
xmlAutomataStatePtr from,
|
||||||
|
xmlAutomataStatePtr to,
|
||||||
|
const xmlChar *token,
|
||||||
|
const xmlChar *token2,
|
||||||
|
void *data);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlAutomataStatePtr XMLCALL
|
||||||
|
xmlAutomataNewCountTrans (xmlAutomataPtr am,
|
||||||
|
xmlAutomataStatePtr from,
|
||||||
|
xmlAutomataStatePtr to,
|
||||||
|
const xmlChar *token,
|
||||||
|
int min,
|
||||||
|
int max,
|
||||||
|
void *data);
|
||||||
|
XMLPUBFUN xmlAutomataStatePtr XMLCALL
|
||||||
|
xmlAutomataNewCountTrans2 (xmlAutomataPtr am,
|
||||||
|
xmlAutomataStatePtr from,
|
||||||
|
xmlAutomataStatePtr to,
|
||||||
|
const xmlChar *token,
|
||||||
|
const xmlChar *token2,
|
||||||
|
int min,
|
||||||
|
int max,
|
||||||
|
void *data);
|
||||||
|
XMLPUBFUN xmlAutomataStatePtr XMLCALL
|
||||||
|
xmlAutomataNewOnceTrans (xmlAutomataPtr am,
|
||||||
|
xmlAutomataStatePtr from,
|
||||||
|
xmlAutomataStatePtr to,
|
||||||
|
const xmlChar *token,
|
||||||
|
int min,
|
||||||
|
int max,
|
||||||
|
void *data);
|
||||||
|
XMLPUBFUN xmlAutomataStatePtr XMLCALL
|
||||||
|
xmlAutomataNewOnceTrans2 (xmlAutomataPtr am,
|
||||||
|
xmlAutomataStatePtr from,
|
||||||
|
xmlAutomataStatePtr to,
|
||||||
|
const xmlChar *token,
|
||||||
|
const xmlChar *token2,
|
||||||
|
int min,
|
||||||
|
int max,
|
||||||
|
void *data);
|
||||||
|
XMLPUBFUN xmlAutomataStatePtr XMLCALL
|
||||||
|
xmlAutomataNewAllTrans (xmlAutomataPtr am,
|
||||||
|
xmlAutomataStatePtr from,
|
||||||
|
xmlAutomataStatePtr to,
|
||||||
|
int lax);
|
||||||
|
XMLPUBFUN xmlAutomataStatePtr XMLCALL
|
||||||
|
xmlAutomataNewEpsilon (xmlAutomataPtr am,
|
||||||
|
xmlAutomataStatePtr from,
|
||||||
|
xmlAutomataStatePtr to);
|
||||||
|
XMLPUBFUN xmlAutomataStatePtr XMLCALL
|
||||||
|
xmlAutomataNewCountedTrans (xmlAutomataPtr am,
|
||||||
|
xmlAutomataStatePtr from,
|
||||||
|
xmlAutomataStatePtr to,
|
||||||
|
int counter);
|
||||||
|
XMLPUBFUN xmlAutomataStatePtr XMLCALL
|
||||||
|
xmlAutomataNewCounterTrans (xmlAutomataPtr am,
|
||||||
|
xmlAutomataStatePtr from,
|
||||||
|
xmlAutomataStatePtr to,
|
||||||
|
int counter);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlAutomataNewCounter (xmlAutomataPtr am,
|
||||||
|
int min,
|
||||||
|
int max);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlRegexpPtr XMLCALL
|
||||||
|
xmlAutomataCompile (xmlAutomataPtr am);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlAutomataIsDeterminist (xmlAutomataPtr am);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* LIBXML_AUTOMATA_ENABLED */
|
||||||
|
#endif /* LIBXML_REGEXP_ENABLED */
|
||||||
|
|
||||||
|
#endif /* __XML_AUTOMATA_H__ */
|
|
@ -0,0 +1,944 @@
|
||||||
|
/*
|
||||||
|
* Summary: error handling
|
||||||
|
* Description: the API used to report errors
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <libxml/parser.h>
|
||||||
|
|
||||||
|
#ifndef __XML_ERROR_H__
|
||||||
|
#define __XML_ERROR_H__
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlErrorLevel:
|
||||||
|
*
|
||||||
|
* Indicates the level of an error
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
XML_ERR_NONE = 0,
|
||||||
|
XML_ERR_WARNING = 1, /* A simple warning */
|
||||||
|
XML_ERR_ERROR = 2, /* A recoverable error */
|
||||||
|
XML_ERR_FATAL = 3 /* A fatal error */
|
||||||
|
} xmlErrorLevel;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlErrorDomain:
|
||||||
|
*
|
||||||
|
* Indicates where an error may have come from
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
XML_FROM_NONE = 0,
|
||||||
|
XML_FROM_PARSER, /* The XML parser */
|
||||||
|
XML_FROM_TREE, /* The tree module */
|
||||||
|
XML_FROM_NAMESPACE, /* The XML Namespace module */
|
||||||
|
XML_FROM_DTD, /* The XML DTD validation with parser context*/
|
||||||
|
XML_FROM_HTML, /* The HTML parser */
|
||||||
|
XML_FROM_MEMORY, /* The memory allocator */
|
||||||
|
XML_FROM_OUTPUT, /* The serialization code */
|
||||||
|
XML_FROM_IO, /* The Input/Output stack */
|
||||||
|
XML_FROM_FTP, /* The FTP module */
|
||||||
|
XML_FROM_HTTP, /* The HTTP module */
|
||||||
|
XML_FROM_XINCLUDE, /* The XInclude processing */
|
||||||
|
XML_FROM_XPATH, /* The XPath module */
|
||||||
|
XML_FROM_XPOINTER, /* The XPointer module */
|
||||||
|
XML_FROM_REGEXP, /* The regular expressions module */
|
||||||
|
XML_FROM_DATATYPE, /* The W3C XML Schemas Datatype module */
|
||||||
|
XML_FROM_SCHEMASP, /* The W3C XML Schemas parser module */
|
||||||
|
XML_FROM_SCHEMASV, /* The W3C XML Schemas validation module */
|
||||||
|
XML_FROM_RELAXNGP, /* The Relax-NG parser module */
|
||||||
|
XML_FROM_RELAXNGV, /* The Relax-NG validator module */
|
||||||
|
XML_FROM_CATALOG, /* The Catalog module */
|
||||||
|
XML_FROM_C14N, /* The Canonicalization module */
|
||||||
|
XML_FROM_XSLT, /* The XSLT engine from libxslt */
|
||||||
|
XML_FROM_VALID, /* The XML DTD validation with valid context */
|
||||||
|
XML_FROM_CHECK, /* The error checking module */
|
||||||
|
XML_FROM_WRITER, /* The xmlwriter module */
|
||||||
|
XML_FROM_MODULE, /* The dynamically loaded module module*/
|
||||||
|
XML_FROM_I18N, /* The module handling character conversion */
|
||||||
|
XML_FROM_SCHEMATRONV /* The Schematron validator module */
|
||||||
|
} xmlErrorDomain;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlError:
|
||||||
|
*
|
||||||
|
* An XML Error instance.
|
||||||
|
*/
|
||||||
|
|
||||||
|
typedef struct _xmlError xmlError;
|
||||||
|
typedef xmlError *xmlErrorPtr;
|
||||||
|
struct _xmlError {
|
||||||
|
int domain; /* What part of the library raised this error */
|
||||||
|
int code; /* The error code, e.g. an xmlParserError */
|
||||||
|
char *message;/* human-readable informative error message */
|
||||||
|
xmlErrorLevel level;/* how consequent is the error */
|
||||||
|
char *file; /* the filename */
|
||||||
|
int line; /* the line number if available */
|
||||||
|
char *str1; /* extra string information */
|
||||||
|
char *str2; /* extra string information */
|
||||||
|
char *str3; /* extra string information */
|
||||||
|
int int1; /* extra number information */
|
||||||
|
int int2; /* column number of the error or 0 if N/A (todo: rename this field when we would break ABI) */
|
||||||
|
void *ctxt; /* the parser context if available */
|
||||||
|
void *node; /* the node in the tree */
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlParserError:
|
||||||
|
*
|
||||||
|
* This is an error that the XML (or HTML) parser can generate
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
XML_ERR_OK = 0,
|
||||||
|
XML_ERR_INTERNAL_ERROR, /* 1 */
|
||||||
|
XML_ERR_NO_MEMORY, /* 2 */
|
||||||
|
XML_ERR_DOCUMENT_START, /* 3 */
|
||||||
|
XML_ERR_DOCUMENT_EMPTY, /* 4 */
|
||||||
|
XML_ERR_DOCUMENT_END, /* 5 */
|
||||||
|
XML_ERR_INVALID_HEX_CHARREF, /* 6 */
|
||||||
|
XML_ERR_INVALID_DEC_CHARREF, /* 7 */
|
||||||
|
XML_ERR_INVALID_CHARREF, /* 8 */
|
||||||
|
XML_ERR_INVALID_CHAR, /* 9 */
|
||||||
|
XML_ERR_CHARREF_AT_EOF, /* 10 */
|
||||||
|
XML_ERR_CHARREF_IN_PROLOG, /* 11 */
|
||||||
|
XML_ERR_CHARREF_IN_EPILOG, /* 12 */
|
||||||
|
XML_ERR_CHARREF_IN_DTD, /* 13 */
|
||||||
|
XML_ERR_ENTITYREF_AT_EOF, /* 14 */
|
||||||
|
XML_ERR_ENTITYREF_IN_PROLOG, /* 15 */
|
||||||
|
XML_ERR_ENTITYREF_IN_EPILOG, /* 16 */
|
||||||
|
XML_ERR_ENTITYREF_IN_DTD, /* 17 */
|
||||||
|
XML_ERR_PEREF_AT_EOF, /* 18 */
|
||||||
|
XML_ERR_PEREF_IN_PROLOG, /* 19 */
|
||||||
|
XML_ERR_PEREF_IN_EPILOG, /* 20 */
|
||||||
|
XML_ERR_PEREF_IN_INT_SUBSET, /* 21 */
|
||||||
|
XML_ERR_ENTITYREF_NO_NAME, /* 22 */
|
||||||
|
XML_ERR_ENTITYREF_SEMICOL_MISSING, /* 23 */
|
||||||
|
XML_ERR_PEREF_NO_NAME, /* 24 */
|
||||||
|
XML_ERR_PEREF_SEMICOL_MISSING, /* 25 */
|
||||||
|
XML_ERR_UNDECLARED_ENTITY, /* 26 */
|
||||||
|
XML_WAR_UNDECLARED_ENTITY, /* 27 */
|
||||||
|
XML_ERR_UNPARSED_ENTITY, /* 28 */
|
||||||
|
XML_ERR_ENTITY_IS_EXTERNAL, /* 29 */
|
||||||
|
XML_ERR_ENTITY_IS_PARAMETER, /* 30 */
|
||||||
|
XML_ERR_UNKNOWN_ENCODING, /* 31 */
|
||||||
|
XML_ERR_UNSUPPORTED_ENCODING, /* 32 */
|
||||||
|
XML_ERR_STRING_NOT_STARTED, /* 33 */
|
||||||
|
XML_ERR_STRING_NOT_CLOSED, /* 34 */
|
||||||
|
XML_ERR_NS_DECL_ERROR, /* 35 */
|
||||||
|
XML_ERR_ENTITY_NOT_STARTED, /* 36 */
|
||||||
|
XML_ERR_ENTITY_NOT_FINISHED, /* 37 */
|
||||||
|
XML_ERR_LT_IN_ATTRIBUTE, /* 38 */
|
||||||
|
XML_ERR_ATTRIBUTE_NOT_STARTED, /* 39 */
|
||||||
|
XML_ERR_ATTRIBUTE_NOT_FINISHED, /* 40 */
|
||||||
|
XML_ERR_ATTRIBUTE_WITHOUT_VALUE, /* 41 */
|
||||||
|
XML_ERR_ATTRIBUTE_REDEFINED, /* 42 */
|
||||||
|
XML_ERR_LITERAL_NOT_STARTED, /* 43 */
|
||||||
|
XML_ERR_LITERAL_NOT_FINISHED, /* 44 */
|
||||||
|
XML_ERR_COMMENT_NOT_FINISHED, /* 45 */
|
||||||
|
XML_ERR_PI_NOT_STARTED, /* 46 */
|
||||||
|
XML_ERR_PI_NOT_FINISHED, /* 47 */
|
||||||
|
XML_ERR_NOTATION_NOT_STARTED, /* 48 */
|
||||||
|
XML_ERR_NOTATION_NOT_FINISHED, /* 49 */
|
||||||
|
XML_ERR_ATTLIST_NOT_STARTED, /* 50 */
|
||||||
|
XML_ERR_ATTLIST_NOT_FINISHED, /* 51 */
|
||||||
|
XML_ERR_MIXED_NOT_STARTED, /* 52 */
|
||||||
|
XML_ERR_MIXED_NOT_FINISHED, /* 53 */
|
||||||
|
XML_ERR_ELEMCONTENT_NOT_STARTED, /* 54 */
|
||||||
|
XML_ERR_ELEMCONTENT_NOT_FINISHED, /* 55 */
|
||||||
|
XML_ERR_XMLDECL_NOT_STARTED, /* 56 */
|
||||||
|
XML_ERR_XMLDECL_NOT_FINISHED, /* 57 */
|
||||||
|
XML_ERR_CONDSEC_NOT_STARTED, /* 58 */
|
||||||
|
XML_ERR_CONDSEC_NOT_FINISHED, /* 59 */
|
||||||
|
XML_ERR_EXT_SUBSET_NOT_FINISHED, /* 60 */
|
||||||
|
XML_ERR_DOCTYPE_NOT_FINISHED, /* 61 */
|
||||||
|
XML_ERR_MISPLACED_CDATA_END, /* 62 */
|
||||||
|
XML_ERR_CDATA_NOT_FINISHED, /* 63 */
|
||||||
|
XML_ERR_RESERVED_XML_NAME, /* 64 */
|
||||||
|
XML_ERR_SPACE_REQUIRED, /* 65 */
|
||||||
|
XML_ERR_SEPARATOR_REQUIRED, /* 66 */
|
||||||
|
XML_ERR_NMTOKEN_REQUIRED, /* 67 */
|
||||||
|
XML_ERR_NAME_REQUIRED, /* 68 */
|
||||||
|
XML_ERR_PCDATA_REQUIRED, /* 69 */
|
||||||
|
XML_ERR_URI_REQUIRED, /* 70 */
|
||||||
|
XML_ERR_PUBID_REQUIRED, /* 71 */
|
||||||
|
XML_ERR_LT_REQUIRED, /* 72 */
|
||||||
|
XML_ERR_GT_REQUIRED, /* 73 */
|
||||||
|
XML_ERR_LTSLASH_REQUIRED, /* 74 */
|
||||||
|
XML_ERR_EQUAL_REQUIRED, /* 75 */
|
||||||
|
XML_ERR_TAG_NAME_MISMATCH, /* 76 */
|
||||||
|
XML_ERR_TAG_NOT_FINISHED, /* 77 */
|
||||||
|
XML_ERR_STANDALONE_VALUE, /* 78 */
|
||||||
|
XML_ERR_ENCODING_NAME, /* 79 */
|
||||||
|
XML_ERR_HYPHEN_IN_COMMENT, /* 80 */
|
||||||
|
XML_ERR_INVALID_ENCODING, /* 81 */
|
||||||
|
XML_ERR_EXT_ENTITY_STANDALONE, /* 82 */
|
||||||
|
XML_ERR_CONDSEC_INVALID, /* 83 */
|
||||||
|
XML_ERR_VALUE_REQUIRED, /* 84 */
|
||||||
|
XML_ERR_NOT_WELL_BALANCED, /* 85 */
|
||||||
|
XML_ERR_EXTRA_CONTENT, /* 86 */
|
||||||
|
XML_ERR_ENTITY_CHAR_ERROR, /* 87 */
|
||||||
|
XML_ERR_ENTITY_PE_INTERNAL, /* 88 */
|
||||||
|
XML_ERR_ENTITY_LOOP, /* 89 */
|
||||||
|
XML_ERR_ENTITY_BOUNDARY, /* 90 */
|
||||||
|
XML_ERR_INVALID_URI, /* 91 */
|
||||||
|
XML_ERR_URI_FRAGMENT, /* 92 */
|
||||||
|
XML_WAR_CATALOG_PI, /* 93 */
|
||||||
|
XML_ERR_NO_DTD, /* 94 */
|
||||||
|
XML_ERR_CONDSEC_INVALID_KEYWORD, /* 95 */
|
||||||
|
XML_ERR_VERSION_MISSING, /* 96 */
|
||||||
|
XML_WAR_UNKNOWN_VERSION, /* 97 */
|
||||||
|
XML_WAR_LANG_VALUE, /* 98 */
|
||||||
|
XML_WAR_NS_URI, /* 99 */
|
||||||
|
XML_WAR_NS_URI_RELATIVE, /* 100 */
|
||||||
|
XML_ERR_MISSING_ENCODING, /* 101 */
|
||||||
|
XML_WAR_SPACE_VALUE, /* 102 */
|
||||||
|
XML_ERR_NOT_STANDALONE, /* 103 */
|
||||||
|
XML_ERR_ENTITY_PROCESSING, /* 104 */
|
||||||
|
XML_ERR_NOTATION_PROCESSING, /* 105 */
|
||||||
|
XML_WAR_NS_COLUMN, /* 106 */
|
||||||
|
XML_WAR_ENTITY_REDEFINED, /* 107 */
|
||||||
|
XML_ERR_UNKNOWN_VERSION, /* 108 */
|
||||||
|
XML_ERR_VERSION_MISMATCH, /* 109 */
|
||||||
|
XML_NS_ERR_XML_NAMESPACE = 200,
|
||||||
|
XML_NS_ERR_UNDEFINED_NAMESPACE, /* 201 */
|
||||||
|
XML_NS_ERR_QNAME, /* 202 */
|
||||||
|
XML_NS_ERR_ATTRIBUTE_REDEFINED, /* 203 */
|
||||||
|
XML_NS_ERR_EMPTY, /* 204 */
|
||||||
|
XML_NS_ERR_COLON, /* 205 */
|
||||||
|
XML_DTD_ATTRIBUTE_DEFAULT = 500,
|
||||||
|
XML_DTD_ATTRIBUTE_REDEFINED, /* 501 */
|
||||||
|
XML_DTD_ATTRIBUTE_VALUE, /* 502 */
|
||||||
|
XML_DTD_CONTENT_ERROR, /* 503 */
|
||||||
|
XML_DTD_CONTENT_MODEL, /* 504 */
|
||||||
|
XML_DTD_CONTENT_NOT_DETERMINIST, /* 505 */
|
||||||
|
XML_DTD_DIFFERENT_PREFIX, /* 506 */
|
||||||
|
XML_DTD_ELEM_DEFAULT_NAMESPACE, /* 507 */
|
||||||
|
XML_DTD_ELEM_NAMESPACE, /* 508 */
|
||||||
|
XML_DTD_ELEM_REDEFINED, /* 509 */
|
||||||
|
XML_DTD_EMPTY_NOTATION, /* 510 */
|
||||||
|
XML_DTD_ENTITY_TYPE, /* 511 */
|
||||||
|
XML_DTD_ID_FIXED, /* 512 */
|
||||||
|
XML_DTD_ID_REDEFINED, /* 513 */
|
||||||
|
XML_DTD_ID_SUBSET, /* 514 */
|
||||||
|
XML_DTD_INVALID_CHILD, /* 515 */
|
||||||
|
XML_DTD_INVALID_DEFAULT, /* 516 */
|
||||||
|
XML_DTD_LOAD_ERROR, /* 517 */
|
||||||
|
XML_DTD_MISSING_ATTRIBUTE, /* 518 */
|
||||||
|
XML_DTD_MIXED_CORRUPT, /* 519 */
|
||||||
|
XML_DTD_MULTIPLE_ID, /* 520 */
|
||||||
|
XML_DTD_NO_DOC, /* 521 */
|
||||||
|
XML_DTD_NO_DTD, /* 522 */
|
||||||
|
XML_DTD_NO_ELEM_NAME, /* 523 */
|
||||||
|
XML_DTD_NO_PREFIX, /* 524 */
|
||||||
|
XML_DTD_NO_ROOT, /* 525 */
|
||||||
|
XML_DTD_NOTATION_REDEFINED, /* 526 */
|
||||||
|
XML_DTD_NOTATION_VALUE, /* 527 */
|
||||||
|
XML_DTD_NOT_EMPTY, /* 528 */
|
||||||
|
XML_DTD_NOT_PCDATA, /* 529 */
|
||||||
|
XML_DTD_NOT_STANDALONE, /* 530 */
|
||||||
|
XML_DTD_ROOT_NAME, /* 531 */
|
||||||
|
XML_DTD_STANDALONE_WHITE_SPACE, /* 532 */
|
||||||
|
XML_DTD_UNKNOWN_ATTRIBUTE, /* 533 */
|
||||||
|
XML_DTD_UNKNOWN_ELEM, /* 534 */
|
||||||
|
XML_DTD_UNKNOWN_ENTITY, /* 535 */
|
||||||
|
XML_DTD_UNKNOWN_ID, /* 536 */
|
||||||
|
XML_DTD_UNKNOWN_NOTATION, /* 537 */
|
||||||
|
XML_DTD_STANDALONE_DEFAULTED, /* 538 */
|
||||||
|
XML_DTD_XMLID_VALUE, /* 539 */
|
||||||
|
XML_DTD_XMLID_TYPE, /* 540 */
|
||||||
|
XML_DTD_DUP_TOKEN, /* 541 */
|
||||||
|
XML_HTML_STRUCURE_ERROR = 800,
|
||||||
|
XML_HTML_UNKNOWN_TAG, /* 801 */
|
||||||
|
XML_RNGP_ANYNAME_ATTR_ANCESTOR = 1000,
|
||||||
|
XML_RNGP_ATTR_CONFLICT, /* 1001 */
|
||||||
|
XML_RNGP_ATTRIBUTE_CHILDREN, /* 1002 */
|
||||||
|
XML_RNGP_ATTRIBUTE_CONTENT, /* 1003 */
|
||||||
|
XML_RNGP_ATTRIBUTE_EMPTY, /* 1004 */
|
||||||
|
XML_RNGP_ATTRIBUTE_NOOP, /* 1005 */
|
||||||
|
XML_RNGP_CHOICE_CONTENT, /* 1006 */
|
||||||
|
XML_RNGP_CHOICE_EMPTY, /* 1007 */
|
||||||
|
XML_RNGP_CREATE_FAILURE, /* 1008 */
|
||||||
|
XML_RNGP_DATA_CONTENT, /* 1009 */
|
||||||
|
XML_RNGP_DEF_CHOICE_AND_INTERLEAVE, /* 1010 */
|
||||||
|
XML_RNGP_DEFINE_CREATE_FAILED, /* 1011 */
|
||||||
|
XML_RNGP_DEFINE_EMPTY, /* 1012 */
|
||||||
|
XML_RNGP_DEFINE_MISSING, /* 1013 */
|
||||||
|
XML_RNGP_DEFINE_NAME_MISSING, /* 1014 */
|
||||||
|
XML_RNGP_ELEM_CONTENT_EMPTY, /* 1015 */
|
||||||
|
XML_RNGP_ELEM_CONTENT_ERROR, /* 1016 */
|
||||||
|
XML_RNGP_ELEMENT_EMPTY, /* 1017 */
|
||||||
|
XML_RNGP_ELEMENT_CONTENT, /* 1018 */
|
||||||
|
XML_RNGP_ELEMENT_NAME, /* 1019 */
|
||||||
|
XML_RNGP_ELEMENT_NO_CONTENT, /* 1020 */
|
||||||
|
XML_RNGP_ELEM_TEXT_CONFLICT, /* 1021 */
|
||||||
|
XML_RNGP_EMPTY, /* 1022 */
|
||||||
|
XML_RNGP_EMPTY_CONSTRUCT, /* 1023 */
|
||||||
|
XML_RNGP_EMPTY_CONTENT, /* 1024 */
|
||||||
|
XML_RNGP_EMPTY_NOT_EMPTY, /* 1025 */
|
||||||
|
XML_RNGP_ERROR_TYPE_LIB, /* 1026 */
|
||||||
|
XML_RNGP_EXCEPT_EMPTY, /* 1027 */
|
||||||
|
XML_RNGP_EXCEPT_MISSING, /* 1028 */
|
||||||
|
XML_RNGP_EXCEPT_MULTIPLE, /* 1029 */
|
||||||
|
XML_RNGP_EXCEPT_NO_CONTENT, /* 1030 */
|
||||||
|
XML_RNGP_EXTERNALREF_EMTPY, /* 1031 */
|
||||||
|
XML_RNGP_EXTERNAL_REF_FAILURE, /* 1032 */
|
||||||
|
XML_RNGP_EXTERNALREF_RECURSE, /* 1033 */
|
||||||
|
XML_RNGP_FORBIDDEN_ATTRIBUTE, /* 1034 */
|
||||||
|
XML_RNGP_FOREIGN_ELEMENT, /* 1035 */
|
||||||
|
XML_RNGP_GRAMMAR_CONTENT, /* 1036 */
|
||||||
|
XML_RNGP_GRAMMAR_EMPTY, /* 1037 */
|
||||||
|
XML_RNGP_GRAMMAR_MISSING, /* 1038 */
|
||||||
|
XML_RNGP_GRAMMAR_NO_START, /* 1039 */
|
||||||
|
XML_RNGP_GROUP_ATTR_CONFLICT, /* 1040 */
|
||||||
|
XML_RNGP_HREF_ERROR, /* 1041 */
|
||||||
|
XML_RNGP_INCLUDE_EMPTY, /* 1042 */
|
||||||
|
XML_RNGP_INCLUDE_FAILURE, /* 1043 */
|
||||||
|
XML_RNGP_INCLUDE_RECURSE, /* 1044 */
|
||||||
|
XML_RNGP_INTERLEAVE_ADD, /* 1045 */
|
||||||
|
XML_RNGP_INTERLEAVE_CREATE_FAILED, /* 1046 */
|
||||||
|
XML_RNGP_INTERLEAVE_EMPTY, /* 1047 */
|
||||||
|
XML_RNGP_INTERLEAVE_NO_CONTENT, /* 1048 */
|
||||||
|
XML_RNGP_INVALID_DEFINE_NAME, /* 1049 */
|
||||||
|
XML_RNGP_INVALID_URI, /* 1050 */
|
||||||
|
XML_RNGP_INVALID_VALUE, /* 1051 */
|
||||||
|
XML_RNGP_MISSING_HREF, /* 1052 */
|
||||||
|
XML_RNGP_NAME_MISSING, /* 1053 */
|
||||||
|
XML_RNGP_NEED_COMBINE, /* 1054 */
|
||||||
|
XML_RNGP_NOTALLOWED_NOT_EMPTY, /* 1055 */
|
||||||
|
XML_RNGP_NSNAME_ATTR_ANCESTOR, /* 1056 */
|
||||||
|
XML_RNGP_NSNAME_NO_NS, /* 1057 */
|
||||||
|
XML_RNGP_PARAM_FORBIDDEN, /* 1058 */
|
||||||
|
XML_RNGP_PARAM_NAME_MISSING, /* 1059 */
|
||||||
|
XML_RNGP_PARENTREF_CREATE_FAILED, /* 1060 */
|
||||||
|
XML_RNGP_PARENTREF_NAME_INVALID, /* 1061 */
|
||||||
|
XML_RNGP_PARENTREF_NO_NAME, /* 1062 */
|
||||||
|
XML_RNGP_PARENTREF_NO_PARENT, /* 1063 */
|
||||||
|
XML_RNGP_PARENTREF_NOT_EMPTY, /* 1064 */
|
||||||
|
XML_RNGP_PARSE_ERROR, /* 1065 */
|
||||||
|
XML_RNGP_PAT_ANYNAME_EXCEPT_ANYNAME, /* 1066 */
|
||||||
|
XML_RNGP_PAT_ATTR_ATTR, /* 1067 */
|
||||||
|
XML_RNGP_PAT_ATTR_ELEM, /* 1068 */
|
||||||
|
XML_RNGP_PAT_DATA_EXCEPT_ATTR, /* 1069 */
|
||||||
|
XML_RNGP_PAT_DATA_EXCEPT_ELEM, /* 1070 */
|
||||||
|
XML_RNGP_PAT_DATA_EXCEPT_EMPTY, /* 1071 */
|
||||||
|
XML_RNGP_PAT_DATA_EXCEPT_GROUP, /* 1072 */
|
||||||
|
XML_RNGP_PAT_DATA_EXCEPT_INTERLEAVE, /* 1073 */
|
||||||
|
XML_RNGP_PAT_DATA_EXCEPT_LIST, /* 1074 */
|
||||||
|
XML_RNGP_PAT_DATA_EXCEPT_ONEMORE, /* 1075 */
|
||||||
|
XML_RNGP_PAT_DATA_EXCEPT_REF, /* 1076 */
|
||||||
|
XML_RNGP_PAT_DATA_EXCEPT_TEXT, /* 1077 */
|
||||||
|
XML_RNGP_PAT_LIST_ATTR, /* 1078 */
|
||||||
|
XML_RNGP_PAT_LIST_ELEM, /* 1079 */
|
||||||
|
XML_RNGP_PAT_LIST_INTERLEAVE, /* 1080 */
|
||||||
|
XML_RNGP_PAT_LIST_LIST, /* 1081 */
|
||||||
|
XML_RNGP_PAT_LIST_REF, /* 1082 */
|
||||||
|
XML_RNGP_PAT_LIST_TEXT, /* 1083 */
|
||||||
|
XML_RNGP_PAT_NSNAME_EXCEPT_ANYNAME, /* 1084 */
|
||||||
|
XML_RNGP_PAT_NSNAME_EXCEPT_NSNAME, /* 1085 */
|
||||||
|
XML_RNGP_PAT_ONEMORE_GROUP_ATTR, /* 1086 */
|
||||||
|
XML_RNGP_PAT_ONEMORE_INTERLEAVE_ATTR, /* 1087 */
|
||||||
|
XML_RNGP_PAT_START_ATTR, /* 1088 */
|
||||||
|
XML_RNGP_PAT_START_DATA, /* 1089 */
|
||||||
|
XML_RNGP_PAT_START_EMPTY, /* 1090 */
|
||||||
|
XML_RNGP_PAT_START_GROUP, /* 1091 */
|
||||||
|
XML_RNGP_PAT_START_INTERLEAVE, /* 1092 */
|
||||||
|
XML_RNGP_PAT_START_LIST, /* 1093 */
|
||||||
|
XML_RNGP_PAT_START_ONEMORE, /* 1094 */
|
||||||
|
XML_RNGP_PAT_START_TEXT, /* 1095 */
|
||||||
|
XML_RNGP_PAT_START_VALUE, /* 1096 */
|
||||||
|
XML_RNGP_PREFIX_UNDEFINED, /* 1097 */
|
||||||
|
XML_RNGP_REF_CREATE_FAILED, /* 1098 */
|
||||||
|
XML_RNGP_REF_CYCLE, /* 1099 */
|
||||||
|
XML_RNGP_REF_NAME_INVALID, /* 1100 */
|
||||||
|
XML_RNGP_REF_NO_DEF, /* 1101 */
|
||||||
|
XML_RNGP_REF_NO_NAME, /* 1102 */
|
||||||
|
XML_RNGP_REF_NOT_EMPTY, /* 1103 */
|
||||||
|
XML_RNGP_START_CHOICE_AND_INTERLEAVE, /* 1104 */
|
||||||
|
XML_RNGP_START_CONTENT, /* 1105 */
|
||||||
|
XML_RNGP_START_EMPTY, /* 1106 */
|
||||||
|
XML_RNGP_START_MISSING, /* 1107 */
|
||||||
|
XML_RNGP_TEXT_EXPECTED, /* 1108 */
|
||||||
|
XML_RNGP_TEXT_HAS_CHILD, /* 1109 */
|
||||||
|
XML_RNGP_TYPE_MISSING, /* 1110 */
|
||||||
|
XML_RNGP_TYPE_NOT_FOUND, /* 1111 */
|
||||||
|
XML_RNGP_TYPE_VALUE, /* 1112 */
|
||||||
|
XML_RNGP_UNKNOWN_ATTRIBUTE, /* 1113 */
|
||||||
|
XML_RNGP_UNKNOWN_COMBINE, /* 1114 */
|
||||||
|
XML_RNGP_UNKNOWN_CONSTRUCT, /* 1115 */
|
||||||
|
XML_RNGP_UNKNOWN_TYPE_LIB, /* 1116 */
|
||||||
|
XML_RNGP_URI_FRAGMENT, /* 1117 */
|
||||||
|
XML_RNGP_URI_NOT_ABSOLUTE, /* 1118 */
|
||||||
|
XML_RNGP_VALUE_EMPTY, /* 1119 */
|
||||||
|
XML_RNGP_VALUE_NO_CONTENT, /* 1120 */
|
||||||
|
XML_RNGP_XMLNS_NAME, /* 1121 */
|
||||||
|
XML_RNGP_XML_NS, /* 1122 */
|
||||||
|
XML_XPATH_EXPRESSION_OK = 1200,
|
||||||
|
XML_XPATH_NUMBER_ERROR, /* 1201 */
|
||||||
|
XML_XPATH_UNFINISHED_LITERAL_ERROR, /* 1202 */
|
||||||
|
XML_XPATH_START_LITERAL_ERROR, /* 1203 */
|
||||||
|
XML_XPATH_VARIABLE_REF_ERROR, /* 1204 */
|
||||||
|
XML_XPATH_UNDEF_VARIABLE_ERROR, /* 1205 */
|
||||||
|
XML_XPATH_INVALID_PREDICATE_ERROR, /* 1206 */
|
||||||
|
XML_XPATH_EXPR_ERROR, /* 1207 */
|
||||||
|
XML_XPATH_UNCLOSED_ERROR, /* 1208 */
|
||||||
|
XML_XPATH_UNKNOWN_FUNC_ERROR, /* 1209 */
|
||||||
|
XML_XPATH_INVALID_OPERAND, /* 1210 */
|
||||||
|
XML_XPATH_INVALID_TYPE, /* 1211 */
|
||||||
|
XML_XPATH_INVALID_ARITY, /* 1212 */
|
||||||
|
XML_XPATH_INVALID_CTXT_SIZE, /* 1213 */
|
||||||
|
XML_XPATH_INVALID_CTXT_POSITION, /* 1214 */
|
||||||
|
XML_XPATH_MEMORY_ERROR, /* 1215 */
|
||||||
|
XML_XPTR_SYNTAX_ERROR, /* 1216 */
|
||||||
|
XML_XPTR_RESOURCE_ERROR, /* 1217 */
|
||||||
|
XML_XPTR_SUB_RESOURCE_ERROR, /* 1218 */
|
||||||
|
XML_XPATH_UNDEF_PREFIX_ERROR, /* 1219 */
|
||||||
|
XML_XPATH_ENCODING_ERROR, /* 1220 */
|
||||||
|
XML_XPATH_INVALID_CHAR_ERROR, /* 1221 */
|
||||||
|
XML_TREE_INVALID_HEX = 1300,
|
||||||
|
XML_TREE_INVALID_DEC, /* 1301 */
|
||||||
|
XML_TREE_UNTERMINATED_ENTITY, /* 1302 */
|
||||||
|
XML_TREE_NOT_UTF8, /* 1303 */
|
||||||
|
XML_SAVE_NOT_UTF8 = 1400,
|
||||||
|
XML_SAVE_CHAR_INVALID, /* 1401 */
|
||||||
|
XML_SAVE_NO_DOCTYPE, /* 1402 */
|
||||||
|
XML_SAVE_UNKNOWN_ENCODING, /* 1403 */
|
||||||
|
XML_REGEXP_COMPILE_ERROR = 1450,
|
||||||
|
XML_IO_UNKNOWN = 1500,
|
||||||
|
XML_IO_EACCES, /* 1501 */
|
||||||
|
XML_IO_EAGAIN, /* 1502 */
|
||||||
|
XML_IO_EBADF, /* 1503 */
|
||||||
|
XML_IO_EBADMSG, /* 1504 */
|
||||||
|
XML_IO_EBUSY, /* 1505 */
|
||||||
|
XML_IO_ECANCELED, /* 1506 */
|
||||||
|
XML_IO_ECHILD, /* 1507 */
|
||||||
|
XML_IO_EDEADLK, /* 1508 */
|
||||||
|
XML_IO_EDOM, /* 1509 */
|
||||||
|
XML_IO_EEXIST, /* 1510 */
|
||||||
|
XML_IO_EFAULT, /* 1511 */
|
||||||
|
XML_IO_EFBIG, /* 1512 */
|
||||||
|
XML_IO_EINPROGRESS, /* 1513 */
|
||||||
|
XML_IO_EINTR, /* 1514 */
|
||||||
|
XML_IO_EINVAL, /* 1515 */
|
||||||
|
XML_IO_EIO, /* 1516 */
|
||||||
|
XML_IO_EISDIR, /* 1517 */
|
||||||
|
XML_IO_EMFILE, /* 1518 */
|
||||||
|
XML_IO_EMLINK, /* 1519 */
|
||||||
|
XML_IO_EMSGSIZE, /* 1520 */
|
||||||
|
XML_IO_ENAMETOOLONG, /* 1521 */
|
||||||
|
XML_IO_ENFILE, /* 1522 */
|
||||||
|
XML_IO_ENODEV, /* 1523 */
|
||||||
|
XML_IO_ENOENT, /* 1524 */
|
||||||
|
XML_IO_ENOEXEC, /* 1525 */
|
||||||
|
XML_IO_ENOLCK, /* 1526 */
|
||||||
|
XML_IO_ENOMEM, /* 1527 */
|
||||||
|
XML_IO_ENOSPC, /* 1528 */
|
||||||
|
XML_IO_ENOSYS, /* 1529 */
|
||||||
|
XML_IO_ENOTDIR, /* 1530 */
|
||||||
|
XML_IO_ENOTEMPTY, /* 1531 */
|
||||||
|
XML_IO_ENOTSUP, /* 1532 */
|
||||||
|
XML_IO_ENOTTY, /* 1533 */
|
||||||
|
XML_IO_ENXIO, /* 1534 */
|
||||||
|
XML_IO_EPERM, /* 1535 */
|
||||||
|
XML_IO_EPIPE, /* 1536 */
|
||||||
|
XML_IO_ERANGE, /* 1537 */
|
||||||
|
XML_IO_EROFS, /* 1538 */
|
||||||
|
XML_IO_ESPIPE, /* 1539 */
|
||||||
|
XML_IO_ESRCH, /* 1540 */
|
||||||
|
XML_IO_ETIMEDOUT, /* 1541 */
|
||||||
|
XML_IO_EXDEV, /* 1542 */
|
||||||
|
XML_IO_NETWORK_ATTEMPT, /* 1543 */
|
||||||
|
XML_IO_ENCODER, /* 1544 */
|
||||||
|
XML_IO_FLUSH, /* 1545 */
|
||||||
|
XML_IO_WRITE, /* 1546 */
|
||||||
|
XML_IO_NO_INPUT, /* 1547 */
|
||||||
|
XML_IO_BUFFER_FULL, /* 1548 */
|
||||||
|
XML_IO_LOAD_ERROR, /* 1549 */
|
||||||
|
XML_IO_ENOTSOCK, /* 1550 */
|
||||||
|
XML_IO_EISCONN, /* 1551 */
|
||||||
|
XML_IO_ECONNREFUSED, /* 1552 */
|
||||||
|
XML_IO_ENETUNREACH, /* 1553 */
|
||||||
|
XML_IO_EADDRINUSE, /* 1554 */
|
||||||
|
XML_IO_EALREADY, /* 1555 */
|
||||||
|
XML_IO_EAFNOSUPPORT, /* 1556 */
|
||||||
|
XML_XINCLUDE_RECURSION=1600,
|
||||||
|
XML_XINCLUDE_PARSE_VALUE, /* 1601 */
|
||||||
|
XML_XINCLUDE_ENTITY_DEF_MISMATCH, /* 1602 */
|
||||||
|
XML_XINCLUDE_NO_HREF, /* 1603 */
|
||||||
|
XML_XINCLUDE_NO_FALLBACK, /* 1604 */
|
||||||
|
XML_XINCLUDE_HREF_URI, /* 1605 */
|
||||||
|
XML_XINCLUDE_TEXT_FRAGMENT, /* 1606 */
|
||||||
|
XML_XINCLUDE_TEXT_DOCUMENT, /* 1607 */
|
||||||
|
XML_XINCLUDE_INVALID_CHAR, /* 1608 */
|
||||||
|
XML_XINCLUDE_BUILD_FAILED, /* 1609 */
|
||||||
|
XML_XINCLUDE_UNKNOWN_ENCODING, /* 1610 */
|
||||||
|
XML_XINCLUDE_MULTIPLE_ROOT, /* 1611 */
|
||||||
|
XML_XINCLUDE_XPTR_FAILED, /* 1612 */
|
||||||
|
XML_XINCLUDE_XPTR_RESULT, /* 1613 */
|
||||||
|
XML_XINCLUDE_INCLUDE_IN_INCLUDE, /* 1614 */
|
||||||
|
XML_XINCLUDE_FALLBACKS_IN_INCLUDE, /* 1615 */
|
||||||
|
XML_XINCLUDE_FALLBACK_NOT_IN_INCLUDE, /* 1616 */
|
||||||
|
XML_XINCLUDE_DEPRECATED_NS, /* 1617 */
|
||||||
|
XML_XINCLUDE_FRAGMENT_ID, /* 1618 */
|
||||||
|
XML_CATALOG_MISSING_ATTR = 1650,
|
||||||
|
XML_CATALOG_ENTRY_BROKEN, /* 1651 */
|
||||||
|
XML_CATALOG_PREFER_VALUE, /* 1652 */
|
||||||
|
XML_CATALOG_NOT_CATALOG, /* 1653 */
|
||||||
|
XML_CATALOG_RECURSION, /* 1654 */
|
||||||
|
XML_SCHEMAP_PREFIX_UNDEFINED = 1700,
|
||||||
|
XML_SCHEMAP_ATTRFORMDEFAULT_VALUE, /* 1701 */
|
||||||
|
XML_SCHEMAP_ATTRGRP_NONAME_NOREF, /* 1702 */
|
||||||
|
XML_SCHEMAP_ATTR_NONAME_NOREF, /* 1703 */
|
||||||
|
XML_SCHEMAP_COMPLEXTYPE_NONAME_NOREF, /* 1704 */
|
||||||
|
XML_SCHEMAP_ELEMFORMDEFAULT_VALUE, /* 1705 */
|
||||||
|
XML_SCHEMAP_ELEM_NONAME_NOREF, /* 1706 */
|
||||||
|
XML_SCHEMAP_EXTENSION_NO_BASE, /* 1707 */
|
||||||
|
XML_SCHEMAP_FACET_NO_VALUE, /* 1708 */
|
||||||
|
XML_SCHEMAP_FAILED_BUILD_IMPORT, /* 1709 */
|
||||||
|
XML_SCHEMAP_GROUP_NONAME_NOREF, /* 1710 */
|
||||||
|
XML_SCHEMAP_IMPORT_NAMESPACE_NOT_URI, /* 1711 */
|
||||||
|
XML_SCHEMAP_IMPORT_REDEFINE_NSNAME, /* 1712 */
|
||||||
|
XML_SCHEMAP_IMPORT_SCHEMA_NOT_URI, /* 1713 */
|
||||||
|
XML_SCHEMAP_INVALID_BOOLEAN, /* 1714 */
|
||||||
|
XML_SCHEMAP_INVALID_ENUM, /* 1715 */
|
||||||
|
XML_SCHEMAP_INVALID_FACET, /* 1716 */
|
||||||
|
XML_SCHEMAP_INVALID_FACET_VALUE, /* 1717 */
|
||||||
|
XML_SCHEMAP_INVALID_MAXOCCURS, /* 1718 */
|
||||||
|
XML_SCHEMAP_INVALID_MINOCCURS, /* 1719 */
|
||||||
|
XML_SCHEMAP_INVALID_REF_AND_SUBTYPE, /* 1720 */
|
||||||
|
XML_SCHEMAP_INVALID_WHITE_SPACE, /* 1721 */
|
||||||
|
XML_SCHEMAP_NOATTR_NOREF, /* 1722 */
|
||||||
|
XML_SCHEMAP_NOTATION_NO_NAME, /* 1723 */
|
||||||
|
XML_SCHEMAP_NOTYPE_NOREF, /* 1724 */
|
||||||
|
XML_SCHEMAP_REF_AND_SUBTYPE, /* 1725 */
|
||||||
|
XML_SCHEMAP_RESTRICTION_NONAME_NOREF, /* 1726 */
|
||||||
|
XML_SCHEMAP_SIMPLETYPE_NONAME, /* 1727 */
|
||||||
|
XML_SCHEMAP_TYPE_AND_SUBTYPE, /* 1728 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_ALL_CHILD, /* 1729 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_ANYATTRIBUTE_CHILD, /* 1730 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_ATTR_CHILD, /* 1731 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_ATTRGRP_CHILD, /* 1732 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_ATTRIBUTE_GROUP, /* 1733 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_BASE_TYPE, /* 1734 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_CHOICE_CHILD, /* 1735 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_COMPLEXCONTENT_CHILD, /* 1736 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_COMPLEXTYPE_CHILD, /* 1737 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_ELEM_CHILD, /* 1738 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_EXTENSION_CHILD, /* 1739 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_FACET_CHILD, /* 1740 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_FACET_TYPE, /* 1741 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_GROUP_CHILD, /* 1742 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_IMPORT_CHILD, /* 1743 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_LIST_CHILD, /* 1744 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_NOTATION_CHILD, /* 1745 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_PROCESSCONTENT_CHILD, /* 1746 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_REF, /* 1747 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_RESTRICTION_CHILD, /* 1748 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_SCHEMAS_CHILD, /* 1749 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_SEQUENCE_CHILD, /* 1750 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_SIMPLECONTENT_CHILD, /* 1751 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_SIMPLETYPE_CHILD, /* 1752 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_TYPE, /* 1753 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_UNION_CHILD, /* 1754 */
|
||||||
|
XML_SCHEMAP_ELEM_DEFAULT_FIXED, /* 1755 */
|
||||||
|
XML_SCHEMAP_REGEXP_INVALID, /* 1756 */
|
||||||
|
XML_SCHEMAP_FAILED_LOAD, /* 1757 */
|
||||||
|
XML_SCHEMAP_NOTHING_TO_PARSE, /* 1758 */
|
||||||
|
XML_SCHEMAP_NOROOT, /* 1759 */
|
||||||
|
XML_SCHEMAP_REDEFINED_GROUP, /* 1760 */
|
||||||
|
XML_SCHEMAP_REDEFINED_TYPE, /* 1761 */
|
||||||
|
XML_SCHEMAP_REDEFINED_ELEMENT, /* 1762 */
|
||||||
|
XML_SCHEMAP_REDEFINED_ATTRGROUP, /* 1763 */
|
||||||
|
XML_SCHEMAP_REDEFINED_ATTR, /* 1764 */
|
||||||
|
XML_SCHEMAP_REDEFINED_NOTATION, /* 1765 */
|
||||||
|
XML_SCHEMAP_FAILED_PARSE, /* 1766 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_PREFIX, /* 1767 */
|
||||||
|
XML_SCHEMAP_DEF_AND_PREFIX, /* 1768 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_INCLUDE_CHILD, /* 1769 */
|
||||||
|
XML_SCHEMAP_INCLUDE_SCHEMA_NOT_URI, /* 1770 */
|
||||||
|
XML_SCHEMAP_INCLUDE_SCHEMA_NO_URI, /* 1771 */
|
||||||
|
XML_SCHEMAP_NOT_SCHEMA, /* 1772 */
|
||||||
|
XML_SCHEMAP_UNKNOWN_MEMBER_TYPE, /* 1773 */
|
||||||
|
XML_SCHEMAP_INVALID_ATTR_USE, /* 1774 */
|
||||||
|
XML_SCHEMAP_RECURSIVE, /* 1775 */
|
||||||
|
XML_SCHEMAP_SUPERNUMEROUS_LIST_ITEM_TYPE, /* 1776 */
|
||||||
|
XML_SCHEMAP_INVALID_ATTR_COMBINATION, /* 1777 */
|
||||||
|
XML_SCHEMAP_INVALID_ATTR_INLINE_COMBINATION, /* 1778 */
|
||||||
|
XML_SCHEMAP_MISSING_SIMPLETYPE_CHILD, /* 1779 */
|
||||||
|
XML_SCHEMAP_INVALID_ATTR_NAME, /* 1780 */
|
||||||
|
XML_SCHEMAP_REF_AND_CONTENT, /* 1781 */
|
||||||
|
XML_SCHEMAP_CT_PROPS_CORRECT_1, /* 1782 */
|
||||||
|
XML_SCHEMAP_CT_PROPS_CORRECT_2, /* 1783 */
|
||||||
|
XML_SCHEMAP_CT_PROPS_CORRECT_3, /* 1784 */
|
||||||
|
XML_SCHEMAP_CT_PROPS_CORRECT_4, /* 1785 */
|
||||||
|
XML_SCHEMAP_CT_PROPS_CORRECT_5, /* 1786 */
|
||||||
|
XML_SCHEMAP_DERIVATION_OK_RESTRICTION_1, /* 1787 */
|
||||||
|
XML_SCHEMAP_DERIVATION_OK_RESTRICTION_2_1_1, /* 1788 */
|
||||||
|
XML_SCHEMAP_DERIVATION_OK_RESTRICTION_2_1_2, /* 1789 */
|
||||||
|
XML_SCHEMAP_DERIVATION_OK_RESTRICTION_2_2, /* 1790 */
|
||||||
|
XML_SCHEMAP_DERIVATION_OK_RESTRICTION_3, /* 1791 */
|
||||||
|
XML_SCHEMAP_WILDCARD_INVALID_NS_MEMBER, /* 1792 */
|
||||||
|
XML_SCHEMAP_INTERSECTION_NOT_EXPRESSIBLE, /* 1793 */
|
||||||
|
XML_SCHEMAP_UNION_NOT_EXPRESSIBLE, /* 1794 */
|
||||||
|
XML_SCHEMAP_SRC_IMPORT_3_1, /* 1795 */
|
||||||
|
XML_SCHEMAP_SRC_IMPORT_3_2, /* 1796 */
|
||||||
|
XML_SCHEMAP_DERIVATION_OK_RESTRICTION_4_1, /* 1797 */
|
||||||
|
XML_SCHEMAP_DERIVATION_OK_RESTRICTION_4_2, /* 1798 */
|
||||||
|
XML_SCHEMAP_DERIVATION_OK_RESTRICTION_4_3, /* 1799 */
|
||||||
|
XML_SCHEMAP_COS_CT_EXTENDS_1_3, /* 1800 */
|
||||||
|
XML_SCHEMAV_NOROOT = 1801,
|
||||||
|
XML_SCHEMAV_UNDECLAREDELEM, /* 1802 */
|
||||||
|
XML_SCHEMAV_NOTTOPLEVEL, /* 1803 */
|
||||||
|
XML_SCHEMAV_MISSING, /* 1804 */
|
||||||
|
XML_SCHEMAV_WRONGELEM, /* 1805 */
|
||||||
|
XML_SCHEMAV_NOTYPE, /* 1806 */
|
||||||
|
XML_SCHEMAV_NOROLLBACK, /* 1807 */
|
||||||
|
XML_SCHEMAV_ISABSTRACT, /* 1808 */
|
||||||
|
XML_SCHEMAV_NOTEMPTY, /* 1809 */
|
||||||
|
XML_SCHEMAV_ELEMCONT, /* 1810 */
|
||||||
|
XML_SCHEMAV_HAVEDEFAULT, /* 1811 */
|
||||||
|
XML_SCHEMAV_NOTNILLABLE, /* 1812 */
|
||||||
|
XML_SCHEMAV_EXTRACONTENT, /* 1813 */
|
||||||
|
XML_SCHEMAV_INVALIDATTR, /* 1814 */
|
||||||
|
XML_SCHEMAV_INVALIDELEM, /* 1815 */
|
||||||
|
XML_SCHEMAV_NOTDETERMINIST, /* 1816 */
|
||||||
|
XML_SCHEMAV_CONSTRUCT, /* 1817 */
|
||||||
|
XML_SCHEMAV_INTERNAL, /* 1818 */
|
||||||
|
XML_SCHEMAV_NOTSIMPLE, /* 1819 */
|
||||||
|
XML_SCHEMAV_ATTRUNKNOWN, /* 1820 */
|
||||||
|
XML_SCHEMAV_ATTRINVALID, /* 1821 */
|
||||||
|
XML_SCHEMAV_VALUE, /* 1822 */
|
||||||
|
XML_SCHEMAV_FACET, /* 1823 */
|
||||||
|
XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_1, /* 1824 */
|
||||||
|
XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_2, /* 1825 */
|
||||||
|
XML_SCHEMAV_CVC_DATATYPE_VALID_1_2_3, /* 1826 */
|
||||||
|
XML_SCHEMAV_CVC_TYPE_3_1_1, /* 1827 */
|
||||||
|
XML_SCHEMAV_CVC_TYPE_3_1_2, /* 1828 */
|
||||||
|
XML_SCHEMAV_CVC_FACET_VALID, /* 1829 */
|
||||||
|
XML_SCHEMAV_CVC_LENGTH_VALID, /* 1830 */
|
||||||
|
XML_SCHEMAV_CVC_MINLENGTH_VALID, /* 1831 */
|
||||||
|
XML_SCHEMAV_CVC_MAXLENGTH_VALID, /* 1832 */
|
||||||
|
XML_SCHEMAV_CVC_MININCLUSIVE_VALID, /* 1833 */
|
||||||
|
XML_SCHEMAV_CVC_MAXINCLUSIVE_VALID, /* 1834 */
|
||||||
|
XML_SCHEMAV_CVC_MINEXCLUSIVE_VALID, /* 1835 */
|
||||||
|
XML_SCHEMAV_CVC_MAXEXCLUSIVE_VALID, /* 1836 */
|
||||||
|
XML_SCHEMAV_CVC_TOTALDIGITS_VALID, /* 1837 */
|
||||||
|
XML_SCHEMAV_CVC_FRACTIONDIGITS_VALID, /* 1838 */
|
||||||
|
XML_SCHEMAV_CVC_PATTERN_VALID, /* 1839 */
|
||||||
|
XML_SCHEMAV_CVC_ENUMERATION_VALID, /* 1840 */
|
||||||
|
XML_SCHEMAV_CVC_COMPLEX_TYPE_2_1, /* 1841 */
|
||||||
|
XML_SCHEMAV_CVC_COMPLEX_TYPE_2_2, /* 1842 */
|
||||||
|
XML_SCHEMAV_CVC_COMPLEX_TYPE_2_3, /* 1843 */
|
||||||
|
XML_SCHEMAV_CVC_COMPLEX_TYPE_2_4, /* 1844 */
|
||||||
|
XML_SCHEMAV_CVC_ELT_1, /* 1845 */
|
||||||
|
XML_SCHEMAV_CVC_ELT_2, /* 1846 */
|
||||||
|
XML_SCHEMAV_CVC_ELT_3_1, /* 1847 */
|
||||||
|
XML_SCHEMAV_CVC_ELT_3_2_1, /* 1848 */
|
||||||
|
XML_SCHEMAV_CVC_ELT_3_2_2, /* 1849 */
|
||||||
|
XML_SCHEMAV_CVC_ELT_4_1, /* 1850 */
|
||||||
|
XML_SCHEMAV_CVC_ELT_4_2, /* 1851 */
|
||||||
|
XML_SCHEMAV_CVC_ELT_4_3, /* 1852 */
|
||||||
|
XML_SCHEMAV_CVC_ELT_5_1_1, /* 1853 */
|
||||||
|
XML_SCHEMAV_CVC_ELT_5_1_2, /* 1854 */
|
||||||
|
XML_SCHEMAV_CVC_ELT_5_2_1, /* 1855 */
|
||||||
|
XML_SCHEMAV_CVC_ELT_5_2_2_1, /* 1856 */
|
||||||
|
XML_SCHEMAV_CVC_ELT_5_2_2_2_1, /* 1857 */
|
||||||
|
XML_SCHEMAV_CVC_ELT_5_2_2_2_2, /* 1858 */
|
||||||
|
XML_SCHEMAV_CVC_ELT_6, /* 1859 */
|
||||||
|
XML_SCHEMAV_CVC_ELT_7, /* 1860 */
|
||||||
|
XML_SCHEMAV_CVC_ATTRIBUTE_1, /* 1861 */
|
||||||
|
XML_SCHEMAV_CVC_ATTRIBUTE_2, /* 1862 */
|
||||||
|
XML_SCHEMAV_CVC_ATTRIBUTE_3, /* 1863 */
|
||||||
|
XML_SCHEMAV_CVC_ATTRIBUTE_4, /* 1864 */
|
||||||
|
XML_SCHEMAV_CVC_COMPLEX_TYPE_3_1, /* 1865 */
|
||||||
|
XML_SCHEMAV_CVC_COMPLEX_TYPE_3_2_1, /* 1866 */
|
||||||
|
XML_SCHEMAV_CVC_COMPLEX_TYPE_3_2_2, /* 1867 */
|
||||||
|
XML_SCHEMAV_CVC_COMPLEX_TYPE_4, /* 1868 */
|
||||||
|
XML_SCHEMAV_CVC_COMPLEX_TYPE_5_1, /* 1869 */
|
||||||
|
XML_SCHEMAV_CVC_COMPLEX_TYPE_5_2, /* 1870 */
|
||||||
|
XML_SCHEMAV_ELEMENT_CONTENT, /* 1871 */
|
||||||
|
XML_SCHEMAV_DOCUMENT_ELEMENT_MISSING, /* 1872 */
|
||||||
|
XML_SCHEMAV_CVC_COMPLEX_TYPE_1, /* 1873 */
|
||||||
|
XML_SCHEMAV_CVC_AU, /* 1874 */
|
||||||
|
XML_SCHEMAV_CVC_TYPE_1, /* 1875 */
|
||||||
|
XML_SCHEMAV_CVC_TYPE_2, /* 1876 */
|
||||||
|
XML_SCHEMAV_CVC_IDC, /* 1877 */
|
||||||
|
XML_SCHEMAV_CVC_WILDCARD, /* 1878 */
|
||||||
|
XML_SCHEMAV_MISC, /* 1879 */
|
||||||
|
XML_XPTR_UNKNOWN_SCHEME = 1900,
|
||||||
|
XML_XPTR_CHILDSEQ_START, /* 1901 */
|
||||||
|
XML_XPTR_EVAL_FAILED, /* 1902 */
|
||||||
|
XML_XPTR_EXTRA_OBJECTS, /* 1903 */
|
||||||
|
XML_C14N_CREATE_CTXT = 1950,
|
||||||
|
XML_C14N_REQUIRES_UTF8, /* 1951 */
|
||||||
|
XML_C14N_CREATE_STACK, /* 1952 */
|
||||||
|
XML_C14N_INVALID_NODE, /* 1953 */
|
||||||
|
XML_C14N_UNKNOW_NODE, /* 1954 */
|
||||||
|
XML_C14N_RELATIVE_NAMESPACE, /* 1955 */
|
||||||
|
XML_FTP_PASV_ANSWER = 2000,
|
||||||
|
XML_FTP_EPSV_ANSWER, /* 2001 */
|
||||||
|
XML_FTP_ACCNT, /* 2002 */
|
||||||
|
XML_FTP_URL_SYNTAX, /* 2003 */
|
||||||
|
XML_HTTP_URL_SYNTAX = 2020,
|
||||||
|
XML_HTTP_USE_IP, /* 2021 */
|
||||||
|
XML_HTTP_UNKNOWN_HOST, /* 2022 */
|
||||||
|
XML_SCHEMAP_SRC_SIMPLE_TYPE_1 = 3000,
|
||||||
|
XML_SCHEMAP_SRC_SIMPLE_TYPE_2, /* 3001 */
|
||||||
|
XML_SCHEMAP_SRC_SIMPLE_TYPE_3, /* 3002 */
|
||||||
|
XML_SCHEMAP_SRC_SIMPLE_TYPE_4, /* 3003 */
|
||||||
|
XML_SCHEMAP_SRC_RESOLVE, /* 3004 */
|
||||||
|
XML_SCHEMAP_SRC_RESTRICTION_BASE_OR_SIMPLETYPE, /* 3005 */
|
||||||
|
XML_SCHEMAP_SRC_LIST_ITEMTYPE_OR_SIMPLETYPE, /* 3006 */
|
||||||
|
XML_SCHEMAP_SRC_UNION_MEMBERTYPES_OR_SIMPLETYPES, /* 3007 */
|
||||||
|
XML_SCHEMAP_ST_PROPS_CORRECT_1, /* 3008 */
|
||||||
|
XML_SCHEMAP_ST_PROPS_CORRECT_2, /* 3009 */
|
||||||
|
XML_SCHEMAP_ST_PROPS_CORRECT_3, /* 3010 */
|
||||||
|
XML_SCHEMAP_COS_ST_RESTRICTS_1_1, /* 3011 */
|
||||||
|
XML_SCHEMAP_COS_ST_RESTRICTS_1_2, /* 3012 */
|
||||||
|
XML_SCHEMAP_COS_ST_RESTRICTS_1_3_1, /* 3013 */
|
||||||
|
XML_SCHEMAP_COS_ST_RESTRICTS_1_3_2, /* 3014 */
|
||||||
|
XML_SCHEMAP_COS_ST_RESTRICTS_2_1, /* 3015 */
|
||||||
|
XML_SCHEMAP_COS_ST_RESTRICTS_2_3_1_1, /* 3016 */
|
||||||
|
XML_SCHEMAP_COS_ST_RESTRICTS_2_3_1_2, /* 3017 */
|
||||||
|
XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_1, /* 3018 */
|
||||||
|
XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_2, /* 3019 */
|
||||||
|
XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_3, /* 3020 */
|
||||||
|
XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_4, /* 3021 */
|
||||||
|
XML_SCHEMAP_COS_ST_RESTRICTS_2_3_2_5, /* 3022 */
|
||||||
|
XML_SCHEMAP_COS_ST_RESTRICTS_3_1, /* 3023 */
|
||||||
|
XML_SCHEMAP_COS_ST_RESTRICTS_3_3_1, /* 3024 */
|
||||||
|
XML_SCHEMAP_COS_ST_RESTRICTS_3_3_1_2, /* 3025 */
|
||||||
|
XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_2, /* 3026 */
|
||||||
|
XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_1, /* 3027 */
|
||||||
|
XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_3, /* 3028 */
|
||||||
|
XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_4, /* 3029 */
|
||||||
|
XML_SCHEMAP_COS_ST_RESTRICTS_3_3_2_5, /* 3030 */
|
||||||
|
XML_SCHEMAP_COS_ST_DERIVED_OK_2_1, /* 3031 */
|
||||||
|
XML_SCHEMAP_COS_ST_DERIVED_OK_2_2, /* 3032 */
|
||||||
|
XML_SCHEMAP_S4S_ELEM_NOT_ALLOWED, /* 3033 */
|
||||||
|
XML_SCHEMAP_S4S_ELEM_MISSING, /* 3034 */
|
||||||
|
XML_SCHEMAP_S4S_ATTR_NOT_ALLOWED, /* 3035 */
|
||||||
|
XML_SCHEMAP_S4S_ATTR_MISSING, /* 3036 */
|
||||||
|
XML_SCHEMAP_S4S_ATTR_INVALID_VALUE, /* 3037 */
|
||||||
|
XML_SCHEMAP_SRC_ELEMENT_1, /* 3038 */
|
||||||
|
XML_SCHEMAP_SRC_ELEMENT_2_1, /* 3039 */
|
||||||
|
XML_SCHEMAP_SRC_ELEMENT_2_2, /* 3040 */
|
||||||
|
XML_SCHEMAP_SRC_ELEMENT_3, /* 3041 */
|
||||||
|
XML_SCHEMAP_P_PROPS_CORRECT_1, /* 3042 */
|
||||||
|
XML_SCHEMAP_P_PROPS_CORRECT_2_1, /* 3043 */
|
||||||
|
XML_SCHEMAP_P_PROPS_CORRECT_2_2, /* 3044 */
|
||||||
|
XML_SCHEMAP_E_PROPS_CORRECT_2, /* 3045 */
|
||||||
|
XML_SCHEMAP_E_PROPS_CORRECT_3, /* 3046 */
|
||||||
|
XML_SCHEMAP_E_PROPS_CORRECT_4, /* 3047 */
|
||||||
|
XML_SCHEMAP_E_PROPS_CORRECT_5, /* 3048 */
|
||||||
|
XML_SCHEMAP_E_PROPS_CORRECT_6, /* 3049 */
|
||||||
|
XML_SCHEMAP_SRC_INCLUDE, /* 3050 */
|
||||||
|
XML_SCHEMAP_SRC_ATTRIBUTE_1, /* 3051 */
|
||||||
|
XML_SCHEMAP_SRC_ATTRIBUTE_2, /* 3052 */
|
||||||
|
XML_SCHEMAP_SRC_ATTRIBUTE_3_1, /* 3053 */
|
||||||
|
XML_SCHEMAP_SRC_ATTRIBUTE_3_2, /* 3054 */
|
||||||
|
XML_SCHEMAP_SRC_ATTRIBUTE_4, /* 3055 */
|
||||||
|
XML_SCHEMAP_NO_XMLNS, /* 3056 */
|
||||||
|
XML_SCHEMAP_NO_XSI, /* 3057 */
|
||||||
|
XML_SCHEMAP_COS_VALID_DEFAULT_1, /* 3058 */
|
||||||
|
XML_SCHEMAP_COS_VALID_DEFAULT_2_1, /* 3059 */
|
||||||
|
XML_SCHEMAP_COS_VALID_DEFAULT_2_2_1, /* 3060 */
|
||||||
|
XML_SCHEMAP_COS_VALID_DEFAULT_2_2_2, /* 3061 */
|
||||||
|
XML_SCHEMAP_CVC_SIMPLE_TYPE, /* 3062 */
|
||||||
|
XML_SCHEMAP_COS_CT_EXTENDS_1_1, /* 3063 */
|
||||||
|
XML_SCHEMAP_SRC_IMPORT_1_1, /* 3064 */
|
||||||
|
XML_SCHEMAP_SRC_IMPORT_1_2, /* 3065 */
|
||||||
|
XML_SCHEMAP_SRC_IMPORT_2, /* 3066 */
|
||||||
|
XML_SCHEMAP_SRC_IMPORT_2_1, /* 3067 */
|
||||||
|
XML_SCHEMAP_SRC_IMPORT_2_2, /* 3068 */
|
||||||
|
XML_SCHEMAP_INTERNAL, /* 3069 non-W3C */
|
||||||
|
XML_SCHEMAP_NOT_DETERMINISTIC, /* 3070 non-W3C */
|
||||||
|
XML_SCHEMAP_SRC_ATTRIBUTE_GROUP_1, /* 3071 */
|
||||||
|
XML_SCHEMAP_SRC_ATTRIBUTE_GROUP_2, /* 3072 */
|
||||||
|
XML_SCHEMAP_SRC_ATTRIBUTE_GROUP_3, /* 3073 */
|
||||||
|
XML_SCHEMAP_MG_PROPS_CORRECT_1, /* 3074 */
|
||||||
|
XML_SCHEMAP_MG_PROPS_CORRECT_2, /* 3075 */
|
||||||
|
XML_SCHEMAP_SRC_CT_1, /* 3076 */
|
||||||
|
XML_SCHEMAP_DERIVATION_OK_RESTRICTION_2_1_3, /* 3077 */
|
||||||
|
XML_SCHEMAP_AU_PROPS_CORRECT_2, /* 3078 */
|
||||||
|
XML_SCHEMAP_A_PROPS_CORRECT_2, /* 3079 */
|
||||||
|
XML_SCHEMAP_C_PROPS_CORRECT, /* 3080 */
|
||||||
|
XML_SCHEMAP_SRC_REDEFINE, /* 3081 */
|
||||||
|
XML_SCHEMAP_SRC_IMPORT, /* 3082 */
|
||||||
|
XML_SCHEMAP_WARN_SKIP_SCHEMA, /* 3083 */
|
||||||
|
XML_SCHEMAP_WARN_UNLOCATED_SCHEMA, /* 3084 */
|
||||||
|
XML_SCHEMAP_WARN_ATTR_REDECL_PROH, /* 3085 */
|
||||||
|
XML_SCHEMAP_WARN_ATTR_POINTLESS_PROH, /* 3085 */
|
||||||
|
XML_SCHEMAP_AG_PROPS_CORRECT, /* 3086 */
|
||||||
|
XML_SCHEMAP_COS_CT_EXTENDS_1_2, /* 3087 */
|
||||||
|
XML_SCHEMAP_AU_PROPS_CORRECT, /* 3088 */
|
||||||
|
XML_SCHEMAP_A_PROPS_CORRECT_3, /* 3089 */
|
||||||
|
XML_SCHEMAP_COS_ALL_LIMITED, /* 3090 */
|
||||||
|
XML_SCHEMATRONV_ASSERT = 4000, /* 4000 */
|
||||||
|
XML_SCHEMATRONV_REPORT,
|
||||||
|
XML_MODULE_OPEN = 4900, /* 4900 */
|
||||||
|
XML_MODULE_CLOSE, /* 4901 */
|
||||||
|
XML_CHECK_FOUND_ELEMENT = 5000,
|
||||||
|
XML_CHECK_FOUND_ATTRIBUTE, /* 5001 */
|
||||||
|
XML_CHECK_FOUND_TEXT, /* 5002 */
|
||||||
|
XML_CHECK_FOUND_CDATA, /* 5003 */
|
||||||
|
XML_CHECK_FOUND_ENTITYREF, /* 5004 */
|
||||||
|
XML_CHECK_FOUND_ENTITY, /* 5005 */
|
||||||
|
XML_CHECK_FOUND_PI, /* 5006 */
|
||||||
|
XML_CHECK_FOUND_COMMENT, /* 5007 */
|
||||||
|
XML_CHECK_FOUND_DOCTYPE, /* 5008 */
|
||||||
|
XML_CHECK_FOUND_FRAGMENT, /* 5009 */
|
||||||
|
XML_CHECK_FOUND_NOTATION, /* 5010 */
|
||||||
|
XML_CHECK_UNKNOWN_NODE, /* 5011 */
|
||||||
|
XML_CHECK_ENTITY_TYPE, /* 5012 */
|
||||||
|
XML_CHECK_NO_PARENT, /* 5013 */
|
||||||
|
XML_CHECK_NO_DOC, /* 5014 */
|
||||||
|
XML_CHECK_NO_NAME, /* 5015 */
|
||||||
|
XML_CHECK_NO_ELEM, /* 5016 */
|
||||||
|
XML_CHECK_WRONG_DOC, /* 5017 */
|
||||||
|
XML_CHECK_NO_PREV, /* 5018 */
|
||||||
|
XML_CHECK_WRONG_PREV, /* 5019 */
|
||||||
|
XML_CHECK_NO_NEXT, /* 5020 */
|
||||||
|
XML_CHECK_WRONG_NEXT, /* 5021 */
|
||||||
|
XML_CHECK_NOT_DTD, /* 5022 */
|
||||||
|
XML_CHECK_NOT_ATTR, /* 5023 */
|
||||||
|
XML_CHECK_NOT_ATTR_DECL, /* 5024 */
|
||||||
|
XML_CHECK_NOT_ELEM_DECL, /* 5025 */
|
||||||
|
XML_CHECK_NOT_ENTITY_DECL, /* 5026 */
|
||||||
|
XML_CHECK_NOT_NS_DECL, /* 5027 */
|
||||||
|
XML_CHECK_NO_HREF, /* 5028 */
|
||||||
|
XML_CHECK_WRONG_PARENT,/* 5029 */
|
||||||
|
XML_CHECK_NS_SCOPE, /* 5030 */
|
||||||
|
XML_CHECK_NS_ANCESTOR, /* 5031 */
|
||||||
|
XML_CHECK_NOT_UTF8, /* 5032 */
|
||||||
|
XML_CHECK_NO_DICT, /* 5033 */
|
||||||
|
XML_CHECK_NOT_NCNAME, /* 5034 */
|
||||||
|
XML_CHECK_OUTSIDE_DICT, /* 5035 */
|
||||||
|
XML_CHECK_WRONG_NAME, /* 5036 */
|
||||||
|
XML_CHECK_NAME_NOT_NULL, /* 5037 */
|
||||||
|
XML_I18N_NO_NAME = 6000,
|
||||||
|
XML_I18N_NO_HANDLER, /* 6001 */
|
||||||
|
XML_I18N_EXCESS_HANDLER, /* 6002 */
|
||||||
|
XML_I18N_CONV_FAILED, /* 6003 */
|
||||||
|
XML_I18N_NO_OUTPUT /* 6004 */
|
||||||
|
#if 0
|
||||||
|
XML_CHECK_, /* 5033 */
|
||||||
|
XML_CHECK_X /* 503 */
|
||||||
|
#endif
|
||||||
|
} xmlParserErrors;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlGenericErrorFunc:
|
||||||
|
* @ctx: a parsing context
|
||||||
|
* @msg: the message
|
||||||
|
* @...: the extra arguments of the varags to format the message
|
||||||
|
*
|
||||||
|
* Signature of the function to use when there is an error and
|
||||||
|
* no parsing or validity context available .
|
||||||
|
*/
|
||||||
|
typedef void (XMLCDECL *xmlGenericErrorFunc) (void *ctx,
|
||||||
|
const char *msg,
|
||||||
|
...) LIBXML_ATTR_FORMAT(2,3);
|
||||||
|
/**
|
||||||
|
* xmlStructuredErrorFunc:
|
||||||
|
* @userData: user provided data for the error callback
|
||||||
|
* @error: the error being raised.
|
||||||
|
*
|
||||||
|
* Signature of the function to use when there is an error and
|
||||||
|
* the module handles the new error reporting mechanism.
|
||||||
|
*/
|
||||||
|
typedef void (XMLCALL *xmlStructuredErrorFunc) (void *userData, xmlErrorPtr error);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Use the following function to reset the two global variables
|
||||||
|
* xmlGenericError and xmlGenericErrorContext.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSetGenericErrorFunc (void *ctx,
|
||||||
|
xmlGenericErrorFunc handler);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
initGenericErrorDefaultFunc (xmlGenericErrorFunc *handler);
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSetStructuredErrorFunc (void *ctx,
|
||||||
|
xmlStructuredErrorFunc handler);
|
||||||
|
/*
|
||||||
|
* Default message routines used by SAX and Valid context for error
|
||||||
|
* and warning reporting.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN void XMLCDECL
|
||||||
|
xmlParserError (void *ctx,
|
||||||
|
const char *msg,
|
||||||
|
...) LIBXML_ATTR_FORMAT(2,3);
|
||||||
|
XMLPUBFUN void XMLCDECL
|
||||||
|
xmlParserWarning (void *ctx,
|
||||||
|
const char *msg,
|
||||||
|
...) LIBXML_ATTR_FORMAT(2,3);
|
||||||
|
XMLPUBFUN void XMLCDECL
|
||||||
|
xmlParserValidityError (void *ctx,
|
||||||
|
const char *msg,
|
||||||
|
...) LIBXML_ATTR_FORMAT(2,3);
|
||||||
|
XMLPUBFUN void XMLCDECL
|
||||||
|
xmlParserValidityWarning (void *ctx,
|
||||||
|
const char *msg,
|
||||||
|
...) LIBXML_ATTR_FORMAT(2,3);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlParserPrintFileInfo (xmlParserInputPtr input);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlParserPrintFileContext (xmlParserInputPtr input);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Extended error information routines
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlErrorPtr XMLCALL
|
||||||
|
xmlGetLastError (void);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlResetLastError (void);
|
||||||
|
XMLPUBFUN xmlErrorPtr XMLCALL
|
||||||
|
xmlCtxtGetLastError (void *ctx);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlCtxtResetLastError (void *ctx);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlResetError (xmlErrorPtr err);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlCopyError (xmlErrorPtr from,
|
||||||
|
xmlErrorPtr to);
|
||||||
|
|
||||||
|
#ifdef IN_LIBXML
|
||||||
|
/*
|
||||||
|
* Internal callback reporting routine
|
||||||
|
*/
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
__xmlRaiseError (xmlStructuredErrorFunc schannel,
|
||||||
|
xmlGenericErrorFunc channel,
|
||||||
|
void *data,
|
||||||
|
void *ctx,
|
||||||
|
void *node,
|
||||||
|
int domain,
|
||||||
|
int code,
|
||||||
|
xmlErrorLevel level,
|
||||||
|
const char *file,
|
||||||
|
int line,
|
||||||
|
const char *str1,
|
||||||
|
const char *str2,
|
||||||
|
const char *str3,
|
||||||
|
int int1,
|
||||||
|
int col,
|
||||||
|
const char *msg,
|
||||||
|
...) LIBXML_ATTR_FORMAT(16,17);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
__xmlSimpleError (int domain,
|
||||||
|
int code,
|
||||||
|
xmlNodePtr node,
|
||||||
|
const char *msg,
|
||||||
|
const char *extra);
|
||||||
|
#endif
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif /* __XML_ERROR_H__ */
|
|
@ -0,0 +1,162 @@
|
||||||
|
/*
|
||||||
|
* Summary: macros for marking symbols as exportable/importable.
|
||||||
|
* Description: macros for marking symbols as exportable/importable.
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Igor Zlatovic <igor@zlatkovic.com>
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_EXPORTS_H__
|
||||||
|
#define __XML_EXPORTS_H__
|
||||||
|
|
||||||
|
/**
|
||||||
|
* XMLPUBFUN, XMLPUBVAR, XMLCALL
|
||||||
|
*
|
||||||
|
* Macros which declare an exportable function, an exportable variable and
|
||||||
|
* the calling convention used for functions.
|
||||||
|
*
|
||||||
|
* Please use an extra block for every platform/compiler combination when
|
||||||
|
* modifying this, rather than overlong #ifdef lines. This helps
|
||||||
|
* readability as well as the fact that different compilers on the same
|
||||||
|
* platform might need different definitions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* XMLPUBFUN:
|
||||||
|
*
|
||||||
|
* Macros which declare an exportable function
|
||||||
|
*/
|
||||||
|
#define XMLPUBFUN
|
||||||
|
/**
|
||||||
|
* XMLPUBVAR:
|
||||||
|
*
|
||||||
|
* Macros which declare an exportable variable
|
||||||
|
*/
|
||||||
|
#define XMLPUBVAR extern
|
||||||
|
/**
|
||||||
|
* XMLCALL:
|
||||||
|
*
|
||||||
|
* Macros which declare the called convention for exported functions
|
||||||
|
*/
|
||||||
|
#define XMLCALL
|
||||||
|
/**
|
||||||
|
* XMLCDECL:
|
||||||
|
*
|
||||||
|
* Macro which declares the calling convention for exported functions that
|
||||||
|
* use '...'.
|
||||||
|
*/
|
||||||
|
#define XMLCDECL
|
||||||
|
|
||||||
|
/** DOC_DISABLE */
|
||||||
|
|
||||||
|
/* Windows platform with MS compiler */
|
||||||
|
#if defined(_WIN32) && defined(_MSC_VER)
|
||||||
|
#undef XMLPUBFUN
|
||||||
|
#undef XMLPUBVAR
|
||||||
|
#undef XMLCALL
|
||||||
|
#undef XMLCDECL
|
||||||
|
#if defined(IN_LIBXML) && !defined(LIBXML_STATIC)
|
||||||
|
#define XMLPUBFUN __declspec(dllexport)
|
||||||
|
#define XMLPUBVAR __declspec(dllexport)
|
||||||
|
#else
|
||||||
|
#define XMLPUBFUN
|
||||||
|
#if !defined(LIBXML_STATIC)
|
||||||
|
#define XMLPUBVAR __declspec(dllimport) extern
|
||||||
|
#else
|
||||||
|
#define XMLPUBVAR extern
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
#if defined(LIBXML_FASTCALL)
|
||||||
|
#define XMLCALL __fastcall
|
||||||
|
#else
|
||||||
|
#define XMLCALL __cdecl
|
||||||
|
#endif
|
||||||
|
#define XMLCDECL __cdecl
|
||||||
|
#if !defined _REENTRANT
|
||||||
|
#define _REENTRANT
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Windows platform with Borland compiler */
|
||||||
|
#if defined(_WIN32) && defined(__BORLANDC__)
|
||||||
|
#undef XMLPUBFUN
|
||||||
|
#undef XMLPUBVAR
|
||||||
|
#undef XMLCALL
|
||||||
|
#undef XMLCDECL
|
||||||
|
#if defined(IN_LIBXML) && !defined(LIBXML_STATIC)
|
||||||
|
#define XMLPUBFUN __declspec(dllexport)
|
||||||
|
#define XMLPUBVAR __declspec(dllexport) extern
|
||||||
|
#else
|
||||||
|
#define XMLPUBFUN
|
||||||
|
#if !defined(LIBXML_STATIC)
|
||||||
|
#define XMLPUBVAR __declspec(dllimport) extern
|
||||||
|
#else
|
||||||
|
#define XMLPUBVAR extern
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
#define XMLCALL __cdecl
|
||||||
|
#define XMLCDECL __cdecl
|
||||||
|
#if !defined _REENTRANT
|
||||||
|
#define _REENTRANT
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Windows platform with GNU compiler (Mingw) */
|
||||||
|
#if defined(_WIN32) && defined(__MINGW32__)
|
||||||
|
#undef XMLPUBFUN
|
||||||
|
#undef XMLPUBVAR
|
||||||
|
#undef XMLCALL
|
||||||
|
#undef XMLCDECL
|
||||||
|
/*
|
||||||
|
* if defined(IN_LIBXML) this raises problems on mingw with msys
|
||||||
|
* _imp__xmlFree listed as missing. Try to workaround the problem
|
||||||
|
* by also making that declaration when compiling client code.
|
||||||
|
*/
|
||||||
|
#if defined(IN_LIBXML) && !defined(LIBXML_STATIC)
|
||||||
|
#define XMLPUBFUN __declspec(dllexport)
|
||||||
|
#define XMLPUBVAR __declspec(dllexport)
|
||||||
|
#else
|
||||||
|
#define XMLPUBFUN
|
||||||
|
#if !defined(LIBXML_STATIC)
|
||||||
|
#define XMLPUBVAR __declspec(dllimport) extern
|
||||||
|
#else
|
||||||
|
#define XMLPUBVAR extern
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
#define XMLCALL __cdecl
|
||||||
|
#define XMLCDECL __cdecl
|
||||||
|
#if !defined _REENTRANT
|
||||||
|
#define _REENTRANT
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Cygwin platform, GNU compiler */
|
||||||
|
#if defined(_WIN32) && defined(__CYGWIN__)
|
||||||
|
#undef XMLPUBFUN
|
||||||
|
#undef XMLPUBVAR
|
||||||
|
#undef XMLCALL
|
||||||
|
#undef XMLCDECL
|
||||||
|
#if defined(IN_LIBXML) && !defined(LIBXML_STATIC)
|
||||||
|
#define XMLPUBFUN __declspec(dllexport)
|
||||||
|
#define XMLPUBVAR __declspec(dllexport)
|
||||||
|
#else
|
||||||
|
#define XMLPUBFUN
|
||||||
|
#if !defined(LIBXML_STATIC)
|
||||||
|
#define XMLPUBVAR __declspec(dllimport) extern
|
||||||
|
#else
|
||||||
|
#define XMLPUBVAR
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
#define XMLCALL __cdecl
|
||||||
|
#define XMLCDECL __cdecl
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Compatibility */
|
||||||
|
#if !defined(LIBXML_DLL_IMPORT)
|
||||||
|
#define LIBXML_DLL_IMPORT XMLPUBVAR
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* __XML_EXPORTS_H__ */
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,224 @@
|
||||||
|
/*
|
||||||
|
* Summary: interface for the memory allocator
|
||||||
|
* Description: provides interfaces for the memory allocator,
|
||||||
|
* including debugging capabilities.
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef __DEBUG_MEMORY_ALLOC__
|
||||||
|
#define __DEBUG_MEMORY_ALLOC__
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
|
||||||
|
/**
|
||||||
|
* DEBUG_MEMORY:
|
||||||
|
*
|
||||||
|
* DEBUG_MEMORY replaces the allocator with a collect and debug
|
||||||
|
* shell to the libc allocator.
|
||||||
|
* DEBUG_MEMORY should only be activated when debugging
|
||||||
|
* libxml i.e. if libxml has been configured with --with-debug-mem too.
|
||||||
|
*/
|
||||||
|
/* #define DEBUG_MEMORY_FREED */
|
||||||
|
/* #define DEBUG_MEMORY_LOCATION */
|
||||||
|
|
||||||
|
#ifdef DEBUG
|
||||||
|
#ifndef DEBUG_MEMORY
|
||||||
|
#define DEBUG_MEMORY
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* DEBUG_MEMORY_LOCATION:
|
||||||
|
*
|
||||||
|
* DEBUG_MEMORY_LOCATION should be activated only when debugging
|
||||||
|
* libxml i.e. if libxml has been configured with --with-debug-mem too.
|
||||||
|
*/
|
||||||
|
#ifdef DEBUG_MEMORY_LOCATION
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The XML memory wrapper support 4 basic overloadable functions.
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* xmlFreeFunc:
|
||||||
|
* @mem: an already allocated block of memory
|
||||||
|
*
|
||||||
|
* Signature for a free() implementation.
|
||||||
|
*/
|
||||||
|
typedef void (XMLCALL *xmlFreeFunc)(void *mem);
|
||||||
|
/**
|
||||||
|
* xmlMallocFunc:
|
||||||
|
* @size: the size requested in bytes
|
||||||
|
*
|
||||||
|
* Signature for a malloc() implementation.
|
||||||
|
*
|
||||||
|
* Returns a pointer to the newly allocated block or NULL in case of error.
|
||||||
|
*/
|
||||||
|
typedef void *(LIBXML_ATTR_ALLOC_SIZE(1) XMLCALL *xmlMallocFunc)(size_t size);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlReallocFunc:
|
||||||
|
* @mem: an already allocated block of memory
|
||||||
|
* @size: the new size requested in bytes
|
||||||
|
*
|
||||||
|
* Signature for a realloc() implementation.
|
||||||
|
*
|
||||||
|
* Returns a pointer to the newly reallocated block or NULL in case of error.
|
||||||
|
*/
|
||||||
|
typedef void *(XMLCALL *xmlReallocFunc)(void *mem, size_t size);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlStrdupFunc:
|
||||||
|
* @str: a zero terminated string
|
||||||
|
*
|
||||||
|
* Signature for an strdup() implementation.
|
||||||
|
*
|
||||||
|
* Returns the copy of the string or NULL in case of error.
|
||||||
|
*/
|
||||||
|
typedef char *(XMLCALL *xmlStrdupFunc)(const char *str);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The 4 interfaces used for all memory handling within libxml.
|
||||||
|
LIBXML_DLL_IMPORT xmlFreeFunc xmlFree;
|
||||||
|
LIBXML_DLL_IMPORT xmlMallocFunc xmlMalloc;
|
||||||
|
LIBXML_DLL_IMPORT xmlMallocFunc xmlMallocAtomic;
|
||||||
|
LIBXML_DLL_IMPORT xmlReallocFunc xmlRealloc;
|
||||||
|
LIBXML_DLL_IMPORT xmlStrdupFunc xmlMemStrdup;
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The way to overload the existing functions.
|
||||||
|
* The xmlGc function have an extra entry for atomic block
|
||||||
|
* allocations useful for garbage collected memory allocators
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlMemSetup (xmlFreeFunc freeFunc,
|
||||||
|
xmlMallocFunc mallocFunc,
|
||||||
|
xmlReallocFunc reallocFunc,
|
||||||
|
xmlStrdupFunc strdupFunc);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlMemGet (xmlFreeFunc *freeFunc,
|
||||||
|
xmlMallocFunc *mallocFunc,
|
||||||
|
xmlReallocFunc *reallocFunc,
|
||||||
|
xmlStrdupFunc *strdupFunc);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlGcMemSetup (xmlFreeFunc freeFunc,
|
||||||
|
xmlMallocFunc mallocFunc,
|
||||||
|
xmlMallocFunc mallocAtomicFunc,
|
||||||
|
xmlReallocFunc reallocFunc,
|
||||||
|
xmlStrdupFunc strdupFunc);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlGcMemGet (xmlFreeFunc *freeFunc,
|
||||||
|
xmlMallocFunc *mallocFunc,
|
||||||
|
xmlMallocFunc *mallocAtomicFunc,
|
||||||
|
xmlReallocFunc *reallocFunc,
|
||||||
|
xmlStrdupFunc *strdupFunc);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Initialization of the memory layer.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlInitMemory (void);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Cleanup of the memory layer.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlCleanupMemory (void);
|
||||||
|
/*
|
||||||
|
* These are specific to the XML debug memory wrapper.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlMemUsed (void);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlMemBlocks (void);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlMemDisplay (FILE *fp);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlMemDisplayLast(FILE *fp, long nbBytes);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlMemShow (FILE *fp, int nr);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlMemoryDump (void);
|
||||||
|
XMLPUBFUN void * XMLCALL
|
||||||
|
xmlMemMalloc (size_t size) LIBXML_ATTR_ALLOC_SIZE(1);
|
||||||
|
XMLPUBFUN void * XMLCALL
|
||||||
|
xmlMemRealloc (void *ptr,size_t size);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlMemFree (void *ptr);
|
||||||
|
XMLPUBFUN char * XMLCALL
|
||||||
|
xmlMemoryStrdup (const char *str);
|
||||||
|
XMLPUBFUN void * XMLCALL
|
||||||
|
xmlMallocLoc (size_t size, const char *file, int line) LIBXML_ATTR_ALLOC_SIZE(1);
|
||||||
|
XMLPUBFUN void * XMLCALL
|
||||||
|
xmlReallocLoc (void *ptr, size_t size, const char *file, int line);
|
||||||
|
XMLPUBFUN void * XMLCALL
|
||||||
|
xmlMallocAtomicLoc (size_t size, const char *file, int line) LIBXML_ATTR_ALLOC_SIZE(1);
|
||||||
|
XMLPUBFUN char * XMLCALL
|
||||||
|
xmlMemStrdupLoc (const char *str, const char *file, int line);
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef DEBUG_MEMORY_LOCATION
|
||||||
|
/**
|
||||||
|
* xmlMalloc:
|
||||||
|
* @size: number of bytes to allocate
|
||||||
|
*
|
||||||
|
* Wrapper for the malloc() function used in the XML library.
|
||||||
|
*
|
||||||
|
* Returns the pointer to the allocated area or NULL in case of error.
|
||||||
|
*/
|
||||||
|
#define xmlMalloc(size) xmlMallocLoc((size), __FILE__, __LINE__)
|
||||||
|
/**
|
||||||
|
* xmlMallocAtomic:
|
||||||
|
* @size: number of bytes to allocate
|
||||||
|
*
|
||||||
|
* Wrapper for the malloc() function used in the XML library for allocation
|
||||||
|
* of block not containing pointers to other areas.
|
||||||
|
*
|
||||||
|
* Returns the pointer to the allocated area or NULL in case of error.
|
||||||
|
*/
|
||||||
|
#define xmlMallocAtomic(size) xmlMallocAtomicLoc((size), __FILE__, __LINE__)
|
||||||
|
/**
|
||||||
|
* xmlRealloc:
|
||||||
|
* @ptr: pointer to the existing allocated area
|
||||||
|
* @size: number of bytes to allocate
|
||||||
|
*
|
||||||
|
* Wrapper for the realloc() function used in the XML library.
|
||||||
|
*
|
||||||
|
* Returns the pointer to the allocated area or NULL in case of error.
|
||||||
|
*/
|
||||||
|
#define xmlRealloc(ptr, size) xmlReallocLoc((ptr), (size), __FILE__, __LINE__)
|
||||||
|
/**
|
||||||
|
* xmlMemStrdup:
|
||||||
|
* @str: pointer to the existing string
|
||||||
|
*
|
||||||
|
* Wrapper for the strdup() function, xmlStrdup() is usually preferred.
|
||||||
|
*
|
||||||
|
* Returns the pointer to the allocated area or NULL in case of error.
|
||||||
|
*/
|
||||||
|
#define xmlMemStrdup(str) xmlMemStrdupLoc((str), __FILE__, __LINE__)
|
||||||
|
|
||||||
|
#endif /* DEBUG_MEMORY_LOCATION */
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif /* __cplusplus */
|
||||||
|
|
||||||
|
#ifndef __XML_GLOBALS_H
|
||||||
|
#ifndef __XML_THREADS_H__
|
||||||
|
#include <libxml/threads.h>
|
||||||
|
#include <libxml/globals.h>
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* __DEBUG_MEMORY_ALLOC__ */
|
||||||
|
|
|
@ -0,0 +1,57 @@
|
||||||
|
/*
|
||||||
|
* Summary: dynamic module loading
|
||||||
|
* Description: basic API for dynamic module loading, used by
|
||||||
|
* libexslt added in 2.6.17
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Joel W. Reed
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_MODULE_H__
|
||||||
|
#define __XML_MODULE_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
|
||||||
|
#ifdef LIBXML_MODULES_ENABLED
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlModulePtr:
|
||||||
|
*
|
||||||
|
* A handle to a dynamically loaded module
|
||||||
|
*/
|
||||||
|
typedef struct _xmlModule xmlModule;
|
||||||
|
typedef xmlModule *xmlModulePtr;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlModuleOption:
|
||||||
|
*
|
||||||
|
* enumeration of options that can be passed down to xmlModuleOpen()
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
XML_MODULE_LAZY = 1, /* lazy binding */
|
||||||
|
XML_MODULE_LOCAL= 2 /* local binding */
|
||||||
|
} xmlModuleOption;
|
||||||
|
|
||||||
|
XMLPUBFUN xmlModulePtr XMLCALL xmlModuleOpen (const char *filename,
|
||||||
|
int options);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL xmlModuleSymbol (xmlModulePtr module,
|
||||||
|
const char* name,
|
||||||
|
void **result);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL xmlModuleClose (xmlModulePtr module);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL xmlModuleFree (xmlModulePtr module);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* LIBXML_MODULES_ENABLED */
|
||||||
|
|
||||||
|
#endif /*__XML_MODULE_H__ */
|
|
@ -0,0 +1,424 @@
|
||||||
|
/*
|
||||||
|
* Summary: the XMLReader implementation
|
||||||
|
* Description: API of the XML streaming API based on C# interfaces.
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_XMLREADER_H__
|
||||||
|
#define __XML_XMLREADER_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
#include <libxml/tree.h>
|
||||||
|
#include <libxml/xmlIO.h>
|
||||||
|
#ifdef LIBXML_SCHEMAS_ENABLED
|
||||||
|
#include <libxml/relaxng.h>
|
||||||
|
#include <libxml/xmlschemas.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlParserSeverities:
|
||||||
|
*
|
||||||
|
* How severe an error callback is when the per-reader error callback API
|
||||||
|
* is used.
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
XML_PARSER_SEVERITY_VALIDITY_WARNING = 1,
|
||||||
|
XML_PARSER_SEVERITY_VALIDITY_ERROR = 2,
|
||||||
|
XML_PARSER_SEVERITY_WARNING = 3,
|
||||||
|
XML_PARSER_SEVERITY_ERROR = 4
|
||||||
|
} xmlParserSeverities;
|
||||||
|
|
||||||
|
#ifdef LIBXML_READER_ENABLED
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlTextReaderMode:
|
||||||
|
*
|
||||||
|
* Internal state values for the reader.
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
XML_TEXTREADER_MODE_INITIAL = 0,
|
||||||
|
XML_TEXTREADER_MODE_INTERACTIVE = 1,
|
||||||
|
XML_TEXTREADER_MODE_ERROR = 2,
|
||||||
|
XML_TEXTREADER_MODE_EOF =3,
|
||||||
|
XML_TEXTREADER_MODE_CLOSED = 4,
|
||||||
|
XML_TEXTREADER_MODE_READING = 5
|
||||||
|
} xmlTextReaderMode;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlParserProperties:
|
||||||
|
*
|
||||||
|
* Some common options to use with xmlTextReaderSetParserProp, but it
|
||||||
|
* is better to use xmlParserOption and the xmlReaderNewxxx and
|
||||||
|
* xmlReaderForxxx APIs now.
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
XML_PARSER_LOADDTD = 1,
|
||||||
|
XML_PARSER_DEFAULTATTRS = 2,
|
||||||
|
XML_PARSER_VALIDATE = 3,
|
||||||
|
XML_PARSER_SUBST_ENTITIES = 4
|
||||||
|
} xmlParserProperties;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlReaderTypes:
|
||||||
|
*
|
||||||
|
* Predefined constants for the different types of nodes.
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
XML_READER_TYPE_NONE = 0,
|
||||||
|
XML_READER_TYPE_ELEMENT = 1,
|
||||||
|
XML_READER_TYPE_ATTRIBUTE = 2,
|
||||||
|
XML_READER_TYPE_TEXT = 3,
|
||||||
|
XML_READER_TYPE_CDATA = 4,
|
||||||
|
XML_READER_TYPE_ENTITY_REFERENCE = 5,
|
||||||
|
XML_READER_TYPE_ENTITY = 6,
|
||||||
|
XML_READER_TYPE_PROCESSING_INSTRUCTION = 7,
|
||||||
|
XML_READER_TYPE_COMMENT = 8,
|
||||||
|
XML_READER_TYPE_DOCUMENT = 9,
|
||||||
|
XML_READER_TYPE_DOCUMENT_TYPE = 10,
|
||||||
|
XML_READER_TYPE_DOCUMENT_FRAGMENT = 11,
|
||||||
|
XML_READER_TYPE_NOTATION = 12,
|
||||||
|
XML_READER_TYPE_WHITESPACE = 13,
|
||||||
|
XML_READER_TYPE_SIGNIFICANT_WHITESPACE = 14,
|
||||||
|
XML_READER_TYPE_END_ELEMENT = 15,
|
||||||
|
XML_READER_TYPE_END_ENTITY = 16,
|
||||||
|
XML_READER_TYPE_XML_DECLARATION = 17
|
||||||
|
} xmlReaderTypes;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlTextReader:
|
||||||
|
*
|
||||||
|
* Structure for an xmlReader context.
|
||||||
|
*/
|
||||||
|
typedef struct _xmlTextReader xmlTextReader;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlTextReaderPtr:
|
||||||
|
*
|
||||||
|
* Pointer to an xmlReader context.
|
||||||
|
*/
|
||||||
|
typedef xmlTextReader *xmlTextReaderPtr;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Constructors & Destructor
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlTextReaderPtr XMLCALL
|
||||||
|
xmlNewTextReader (xmlParserInputBufferPtr input,
|
||||||
|
const char *URI);
|
||||||
|
XMLPUBFUN xmlTextReaderPtr XMLCALL
|
||||||
|
xmlNewTextReaderFilename(const char *URI);
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlFreeTextReader (xmlTextReaderPtr reader);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderSetup(xmlTextReaderPtr reader,
|
||||||
|
xmlParserInputBufferPtr input, const char *URL,
|
||||||
|
const char *encoding, int options);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Iterators
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderRead (xmlTextReaderPtr reader);
|
||||||
|
|
||||||
|
#ifdef LIBXML_WRITER_ENABLED
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlTextReaderReadInnerXml (xmlTextReaderPtr reader);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlTextReaderReadOuterXml (xmlTextReaderPtr reader);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlTextReaderReadString (xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderReadAttributeValue (xmlTextReaderPtr reader);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Attributes of the node
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderAttributeCount(xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderDepth (xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderHasAttributes(xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderHasValue(xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderIsDefault (xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderIsEmptyElement(xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderNodeType (xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderQuoteChar (xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderReadState (xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderIsNamespaceDecl(xmlTextReaderPtr reader);
|
||||||
|
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlTextReaderConstBaseUri (xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlTextReaderConstLocalName (xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlTextReaderConstName (xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlTextReaderConstNamespaceUri(xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlTextReaderConstPrefix (xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlTextReaderConstXmlLang (xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlTextReaderConstString (xmlTextReaderPtr reader,
|
||||||
|
const xmlChar *str);
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlTextReaderConstValue (xmlTextReaderPtr reader);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* use the Const version of the routine for
|
||||||
|
* better performance and simpler code
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlTextReaderBaseUri (xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlTextReaderLocalName (xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlTextReaderName (xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlTextReaderNamespaceUri(xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlTextReaderPrefix (xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlTextReaderXmlLang (xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlTextReaderValue (xmlTextReaderPtr reader);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Methods of the XmlTextReader
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderClose (xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlTextReaderGetAttributeNo (xmlTextReaderPtr reader,
|
||||||
|
int no);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlTextReaderGetAttribute (xmlTextReaderPtr reader,
|
||||||
|
const xmlChar *name);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlTextReaderGetAttributeNs (xmlTextReaderPtr reader,
|
||||||
|
const xmlChar *localName,
|
||||||
|
const xmlChar *namespaceURI);
|
||||||
|
XMLPUBFUN xmlParserInputBufferPtr XMLCALL
|
||||||
|
xmlTextReaderGetRemainder (xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlTextReaderLookupNamespace(xmlTextReaderPtr reader,
|
||||||
|
const xmlChar *prefix);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderMoveToAttributeNo(xmlTextReaderPtr reader,
|
||||||
|
int no);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderMoveToAttribute(xmlTextReaderPtr reader,
|
||||||
|
const xmlChar *name);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderMoveToAttributeNs(xmlTextReaderPtr reader,
|
||||||
|
const xmlChar *localName,
|
||||||
|
const xmlChar *namespaceURI);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderMoveToFirstAttribute(xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderMoveToNextAttribute(xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderMoveToElement (xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderNormalization (xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlTextReaderConstEncoding (xmlTextReaderPtr reader);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Extensions
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderSetParserProp (xmlTextReaderPtr reader,
|
||||||
|
int prop,
|
||||||
|
int value);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderGetParserProp (xmlTextReaderPtr reader,
|
||||||
|
int prop);
|
||||||
|
XMLPUBFUN xmlNodePtr XMLCALL
|
||||||
|
xmlTextReaderCurrentNode (xmlTextReaderPtr reader);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderGetParserLineNumber(xmlTextReaderPtr reader);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderGetParserColumnNumber(xmlTextReaderPtr reader);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlNodePtr XMLCALL
|
||||||
|
xmlTextReaderPreserve (xmlTextReaderPtr reader);
|
||||||
|
#ifdef LIBXML_PATTERN_ENABLED
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderPreservePattern(xmlTextReaderPtr reader,
|
||||||
|
const xmlChar *pattern,
|
||||||
|
const xmlChar **namespaces);
|
||||||
|
#endif /* LIBXML_PATTERN_ENABLED */
|
||||||
|
XMLPUBFUN xmlDocPtr XMLCALL
|
||||||
|
xmlTextReaderCurrentDoc (xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN xmlNodePtr XMLCALL
|
||||||
|
xmlTextReaderExpand (xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderNext (xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderNextSibling (xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderIsValid (xmlTextReaderPtr reader);
|
||||||
|
#ifdef LIBXML_SCHEMAS_ENABLED
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderRelaxNGValidate(xmlTextReaderPtr reader,
|
||||||
|
const char *rng);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderRelaxNGSetSchema(xmlTextReaderPtr reader,
|
||||||
|
xmlRelaxNGPtr schema);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderSchemaValidate (xmlTextReaderPtr reader,
|
||||||
|
const char *xsd);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderSchemaValidateCtxt(xmlTextReaderPtr reader,
|
||||||
|
xmlSchemaValidCtxtPtr ctxt,
|
||||||
|
int options);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderSetSchema (xmlTextReaderPtr reader,
|
||||||
|
xmlSchemaPtr schema);
|
||||||
|
#endif
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlTextReaderConstXmlVersion(xmlTextReaderPtr reader);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderStandalone (xmlTextReaderPtr reader);
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Index lookup
|
||||||
|
*/
|
||||||
|
XMLPUBFUN long XMLCALL
|
||||||
|
xmlTextReaderByteConsumed (xmlTextReaderPtr reader);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* New more complete APIs for simpler creation and reuse of readers
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlTextReaderPtr XMLCALL
|
||||||
|
xmlReaderWalker (xmlDocPtr doc);
|
||||||
|
XMLPUBFUN xmlTextReaderPtr XMLCALL
|
||||||
|
xmlReaderForDoc (const xmlChar * cur,
|
||||||
|
const char *URL,
|
||||||
|
const char *encoding,
|
||||||
|
int options);
|
||||||
|
XMLPUBFUN xmlTextReaderPtr XMLCALL
|
||||||
|
xmlReaderForFile (const char *filename,
|
||||||
|
const char *encoding,
|
||||||
|
int options);
|
||||||
|
XMLPUBFUN xmlTextReaderPtr XMLCALL
|
||||||
|
xmlReaderForMemory (const char *buffer,
|
||||||
|
int size,
|
||||||
|
const char *URL,
|
||||||
|
const char *encoding,
|
||||||
|
int options);
|
||||||
|
XMLPUBFUN xmlTextReaderPtr XMLCALL
|
||||||
|
xmlReaderForFd (int fd,
|
||||||
|
const char *URL,
|
||||||
|
const char *encoding,
|
||||||
|
int options);
|
||||||
|
XMLPUBFUN xmlTextReaderPtr XMLCALL
|
||||||
|
xmlReaderForIO (xmlInputReadCallback ioread,
|
||||||
|
xmlInputCloseCallback ioclose,
|
||||||
|
void *ioctx,
|
||||||
|
const char *URL,
|
||||||
|
const char *encoding,
|
||||||
|
int options);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlReaderNewWalker (xmlTextReaderPtr reader,
|
||||||
|
xmlDocPtr doc);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlReaderNewDoc (xmlTextReaderPtr reader,
|
||||||
|
const xmlChar * cur,
|
||||||
|
const char *URL,
|
||||||
|
const char *encoding,
|
||||||
|
int options);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlReaderNewFile (xmlTextReaderPtr reader,
|
||||||
|
const char *filename,
|
||||||
|
const char *encoding,
|
||||||
|
int options);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlReaderNewMemory (xmlTextReaderPtr reader,
|
||||||
|
const char *buffer,
|
||||||
|
int size,
|
||||||
|
const char *URL,
|
||||||
|
const char *encoding,
|
||||||
|
int options);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlReaderNewFd (xmlTextReaderPtr reader,
|
||||||
|
int fd,
|
||||||
|
const char *URL,
|
||||||
|
const char *encoding,
|
||||||
|
int options);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlReaderNewIO (xmlTextReaderPtr reader,
|
||||||
|
xmlInputReadCallback ioread,
|
||||||
|
xmlInputCloseCallback ioclose,
|
||||||
|
void *ioctx,
|
||||||
|
const char *URL,
|
||||||
|
const char *encoding,
|
||||||
|
int options);
|
||||||
|
/*
|
||||||
|
* Error handling extensions
|
||||||
|
*/
|
||||||
|
typedef void * xmlTextReaderLocatorPtr;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlTextReaderErrorFunc:
|
||||||
|
* @arg: the user argument
|
||||||
|
* @msg: the message
|
||||||
|
* @severity: the severity of the error
|
||||||
|
* @locator: a locator indicating where the error occured
|
||||||
|
*
|
||||||
|
* Signature of an error callback from a reader parser
|
||||||
|
*/
|
||||||
|
typedef void (XMLCALL *xmlTextReaderErrorFunc)(void *arg,
|
||||||
|
const char *msg,
|
||||||
|
xmlParserSeverities severity,
|
||||||
|
xmlTextReaderLocatorPtr locator);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextReaderLocatorLineNumber(xmlTextReaderLocatorPtr locator);
|
||||||
|
/*int xmlTextReaderLocatorLinePosition(xmlTextReaderLocatorPtr locator);*/
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlTextReaderLocatorBaseURI (xmlTextReaderLocatorPtr locator);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlTextReaderSetErrorHandler(xmlTextReaderPtr reader,
|
||||||
|
xmlTextReaderErrorFunc f,
|
||||||
|
void *arg);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlTextReaderSetStructuredErrorHandler(xmlTextReaderPtr reader,
|
||||||
|
xmlStructuredErrorFunc f,
|
||||||
|
void *arg);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlTextReaderGetErrorHandler(xmlTextReaderPtr reader,
|
||||||
|
xmlTextReaderErrorFunc *f,
|
||||||
|
void **arg);
|
||||||
|
|
||||||
|
#endif /* LIBXML_READER_ENABLED */
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* __XML_XMLREADER_H__ */
|
||||||
|
|
|
@ -0,0 +1,222 @@
|
||||||
|
/*
|
||||||
|
* Summary: regular expressions handling
|
||||||
|
* Description: basic API for libxml regular expressions handling used
|
||||||
|
* for XML Schemas and validation.
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_REGEXP_H__
|
||||||
|
#define __XML_REGEXP_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
|
||||||
|
#ifdef LIBXML_REGEXP_ENABLED
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlRegexpPtr:
|
||||||
|
*
|
||||||
|
* A libxml regular expression, they can actually be far more complex
|
||||||
|
* thank the POSIX regex expressions.
|
||||||
|
*/
|
||||||
|
typedef struct _xmlRegexp xmlRegexp;
|
||||||
|
typedef xmlRegexp *xmlRegexpPtr;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlRegExecCtxtPtr:
|
||||||
|
*
|
||||||
|
* A libxml progressive regular expression evaluation context
|
||||||
|
*/
|
||||||
|
typedef struct _xmlRegExecCtxt xmlRegExecCtxt;
|
||||||
|
typedef xmlRegExecCtxt *xmlRegExecCtxtPtr;
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#include <libxml/tree.h>
|
||||||
|
#include <libxml/dict.h>
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The POSIX like API
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlRegexpPtr XMLCALL
|
||||||
|
xmlRegexpCompile (const xmlChar *regexp);
|
||||||
|
XMLPUBFUN void XMLCALL xmlRegFreeRegexp(xmlRegexpPtr regexp);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlRegexpExec (xmlRegexpPtr comp,
|
||||||
|
const xmlChar *value);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlRegexpPrint (FILE *output,
|
||||||
|
xmlRegexpPtr regexp);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlRegexpIsDeterminist(xmlRegexpPtr comp);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlRegExecCallbacks:
|
||||||
|
* @exec: the regular expression context
|
||||||
|
* @token: the current token string
|
||||||
|
* @transdata: transition data
|
||||||
|
* @inputdata: input data
|
||||||
|
*
|
||||||
|
* Callback function when doing a transition in the automata
|
||||||
|
*/
|
||||||
|
typedef void (*xmlRegExecCallbacks) (xmlRegExecCtxtPtr exec,
|
||||||
|
const xmlChar *token,
|
||||||
|
void *transdata,
|
||||||
|
void *inputdata);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The progressive API
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlRegExecCtxtPtr XMLCALL
|
||||||
|
xmlRegNewExecCtxt (xmlRegexpPtr comp,
|
||||||
|
xmlRegExecCallbacks callback,
|
||||||
|
void *data);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlRegFreeExecCtxt (xmlRegExecCtxtPtr exec);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlRegExecPushString(xmlRegExecCtxtPtr exec,
|
||||||
|
const xmlChar *value,
|
||||||
|
void *data);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlRegExecPushString2(xmlRegExecCtxtPtr exec,
|
||||||
|
const xmlChar *value,
|
||||||
|
const xmlChar *value2,
|
||||||
|
void *data);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlRegExecNextValues(xmlRegExecCtxtPtr exec,
|
||||||
|
int *nbval,
|
||||||
|
int *nbneg,
|
||||||
|
xmlChar **values,
|
||||||
|
int *terminal);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlRegExecErrInfo (xmlRegExecCtxtPtr exec,
|
||||||
|
const xmlChar **string,
|
||||||
|
int *nbval,
|
||||||
|
int *nbneg,
|
||||||
|
xmlChar **values,
|
||||||
|
int *terminal);
|
||||||
|
#ifdef LIBXML_EXPR_ENABLED
|
||||||
|
/*
|
||||||
|
* Formal regular expression handling
|
||||||
|
* Its goal is to do some formal work on content models
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* expressions are used within a context */
|
||||||
|
typedef struct _xmlExpCtxt xmlExpCtxt;
|
||||||
|
typedef xmlExpCtxt *xmlExpCtxtPtr;
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlExpFreeCtxt (xmlExpCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN xmlExpCtxtPtr XMLCALL
|
||||||
|
xmlExpNewCtxt (int maxNodes,
|
||||||
|
xmlDictPtr dict);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlExpCtxtNbNodes(xmlExpCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlExpCtxtNbCons(xmlExpCtxtPtr ctxt);
|
||||||
|
|
||||||
|
/* Expressions are trees but the tree is opaque */
|
||||||
|
typedef struct _xmlExpNode xmlExpNode;
|
||||||
|
typedef xmlExpNode *xmlExpNodePtr;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
XML_EXP_EMPTY = 0,
|
||||||
|
XML_EXP_FORBID = 1,
|
||||||
|
XML_EXP_ATOM = 2,
|
||||||
|
XML_EXP_SEQ = 3,
|
||||||
|
XML_EXP_OR = 4,
|
||||||
|
XML_EXP_COUNT = 5
|
||||||
|
} xmlExpNodeType;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* 2 core expressions shared by all for the empty language set
|
||||||
|
* and for the set with just the empty token
|
||||||
|
*/
|
||||||
|
XMLPUBVAR xmlExpNodePtr forbiddenExp;
|
||||||
|
XMLPUBVAR xmlExpNodePtr emptyExp;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Expressions are reference counted internally
|
||||||
|
*/
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlExpFree (xmlExpCtxtPtr ctxt,
|
||||||
|
xmlExpNodePtr expr);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlExpRef (xmlExpNodePtr expr);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* constructors can be either manual or from a string
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlExpNodePtr XMLCALL
|
||||||
|
xmlExpParse (xmlExpCtxtPtr ctxt,
|
||||||
|
const char *expr);
|
||||||
|
XMLPUBFUN xmlExpNodePtr XMLCALL
|
||||||
|
xmlExpNewAtom (xmlExpCtxtPtr ctxt,
|
||||||
|
const xmlChar *name,
|
||||||
|
int len);
|
||||||
|
XMLPUBFUN xmlExpNodePtr XMLCALL
|
||||||
|
xmlExpNewOr (xmlExpCtxtPtr ctxt,
|
||||||
|
xmlExpNodePtr left,
|
||||||
|
xmlExpNodePtr right);
|
||||||
|
XMLPUBFUN xmlExpNodePtr XMLCALL
|
||||||
|
xmlExpNewSeq (xmlExpCtxtPtr ctxt,
|
||||||
|
xmlExpNodePtr left,
|
||||||
|
xmlExpNodePtr right);
|
||||||
|
XMLPUBFUN xmlExpNodePtr XMLCALL
|
||||||
|
xmlExpNewRange (xmlExpCtxtPtr ctxt,
|
||||||
|
xmlExpNodePtr subset,
|
||||||
|
int min,
|
||||||
|
int max);
|
||||||
|
/*
|
||||||
|
* The really interesting APIs
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlExpIsNillable(xmlExpNodePtr expr);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlExpMaxToken (xmlExpNodePtr expr);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlExpGetLanguage(xmlExpCtxtPtr ctxt,
|
||||||
|
xmlExpNodePtr expr,
|
||||||
|
const xmlChar**langList,
|
||||||
|
int len);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlExpGetStart (xmlExpCtxtPtr ctxt,
|
||||||
|
xmlExpNodePtr expr,
|
||||||
|
const xmlChar**tokList,
|
||||||
|
int len);
|
||||||
|
XMLPUBFUN xmlExpNodePtr XMLCALL
|
||||||
|
xmlExpStringDerive(xmlExpCtxtPtr ctxt,
|
||||||
|
xmlExpNodePtr expr,
|
||||||
|
const xmlChar *str,
|
||||||
|
int len);
|
||||||
|
XMLPUBFUN xmlExpNodePtr XMLCALL
|
||||||
|
xmlExpExpDerive (xmlExpCtxtPtr ctxt,
|
||||||
|
xmlExpNodePtr expr,
|
||||||
|
xmlExpNodePtr sub);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlExpSubsume (xmlExpCtxtPtr ctxt,
|
||||||
|
xmlExpNodePtr expr,
|
||||||
|
xmlExpNodePtr sub);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlExpDump (xmlBufferPtr buf,
|
||||||
|
xmlExpNodePtr expr);
|
||||||
|
#endif /* LIBXML_EXPR_ENABLED */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* LIBXML_REGEXP_ENABLED */
|
||||||
|
|
||||||
|
#endif /*__XML_REGEXP_H__ */
|
|
@ -0,0 +1,88 @@
|
||||||
|
/*
|
||||||
|
* Summary: the XML document serializer
|
||||||
|
* Description: API to save document or subtree of document
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_XMLSAVE_H__
|
||||||
|
#define __XML_XMLSAVE_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
#include <libxml/tree.h>
|
||||||
|
#include <libxml/encoding.h>
|
||||||
|
#include <libxml/xmlIO.h>
|
||||||
|
|
||||||
|
#ifdef LIBXML_OUTPUT_ENABLED
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlSaveOption:
|
||||||
|
*
|
||||||
|
* This is the set of XML save options that can be passed down
|
||||||
|
* to the xmlSaveToFd() and similar calls.
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
XML_SAVE_FORMAT = 1<<0, /* format save output */
|
||||||
|
XML_SAVE_NO_DECL = 1<<1, /* drop the xml declaration */
|
||||||
|
XML_SAVE_NO_EMPTY = 1<<2, /* no empty tags */
|
||||||
|
XML_SAVE_NO_XHTML = 1<<3, /* disable XHTML1 specific rules */
|
||||||
|
XML_SAVE_XHTML = 1<<4, /* force XHTML1 specific rules */
|
||||||
|
XML_SAVE_AS_XML = 1<<5, /* force XML serialization on HTML doc */
|
||||||
|
XML_SAVE_AS_HTML = 1<<6, /* force HTML serialization on XML doc */
|
||||||
|
XML_SAVE_WSNONSIG = 1<<7 /* format with non-significant whitespace */
|
||||||
|
} xmlSaveOption;
|
||||||
|
|
||||||
|
|
||||||
|
typedef struct _xmlSaveCtxt xmlSaveCtxt;
|
||||||
|
typedef xmlSaveCtxt *xmlSaveCtxtPtr;
|
||||||
|
|
||||||
|
XMLPUBFUN xmlSaveCtxtPtr XMLCALL
|
||||||
|
xmlSaveToFd (int fd,
|
||||||
|
const char *encoding,
|
||||||
|
int options);
|
||||||
|
XMLPUBFUN xmlSaveCtxtPtr XMLCALL
|
||||||
|
xmlSaveToFilename (const char *filename,
|
||||||
|
const char *encoding,
|
||||||
|
int options);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlSaveCtxtPtr XMLCALL
|
||||||
|
xmlSaveToBuffer (xmlBufferPtr buffer,
|
||||||
|
const char *encoding,
|
||||||
|
int options);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlSaveCtxtPtr XMLCALL
|
||||||
|
xmlSaveToIO (xmlOutputWriteCallback iowrite,
|
||||||
|
xmlOutputCloseCallback ioclose,
|
||||||
|
void *ioctx,
|
||||||
|
const char *encoding,
|
||||||
|
int options);
|
||||||
|
|
||||||
|
XMLPUBFUN long XMLCALL
|
||||||
|
xmlSaveDoc (xmlSaveCtxtPtr ctxt,
|
||||||
|
xmlDocPtr doc);
|
||||||
|
XMLPUBFUN long XMLCALL
|
||||||
|
xmlSaveTree (xmlSaveCtxtPtr ctxt,
|
||||||
|
xmlNodePtr node);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSaveFlush (xmlSaveCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSaveClose (xmlSaveCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSaveSetEscape (xmlSaveCtxtPtr ctxt,
|
||||||
|
xmlCharEncodingOutputFunc escape);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSaveSetAttrEscape (xmlSaveCtxtPtr ctxt,
|
||||||
|
xmlCharEncodingOutputFunc escape);
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif /* LIBXML_OUTPUT_ENABLED */
|
||||||
|
#endif /* __XML_XMLSAVE_H__ */
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,218 @@
|
||||||
|
/*
|
||||||
|
* Summary: incomplete XML Schemas structure implementation
|
||||||
|
* Description: interface to the XML Schemas handling and schema validity
|
||||||
|
* checking, it is incomplete right now.
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef __XML_SCHEMA_H__
|
||||||
|
#define __XML_SCHEMA_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
|
||||||
|
#ifdef LIBXML_SCHEMAS_ENABLED
|
||||||
|
|
||||||
|
#include <libxml/tree.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This error codes are obsolete; not used any more.
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
XML_SCHEMAS_ERR_OK = 0,
|
||||||
|
XML_SCHEMAS_ERR_NOROOT = 1,
|
||||||
|
XML_SCHEMAS_ERR_UNDECLAREDELEM,
|
||||||
|
XML_SCHEMAS_ERR_NOTTOPLEVEL,
|
||||||
|
XML_SCHEMAS_ERR_MISSING,
|
||||||
|
XML_SCHEMAS_ERR_WRONGELEM,
|
||||||
|
XML_SCHEMAS_ERR_NOTYPE,
|
||||||
|
XML_SCHEMAS_ERR_NOROLLBACK,
|
||||||
|
XML_SCHEMAS_ERR_ISABSTRACT,
|
||||||
|
XML_SCHEMAS_ERR_NOTEMPTY,
|
||||||
|
XML_SCHEMAS_ERR_ELEMCONT,
|
||||||
|
XML_SCHEMAS_ERR_HAVEDEFAULT,
|
||||||
|
XML_SCHEMAS_ERR_NOTNILLABLE,
|
||||||
|
XML_SCHEMAS_ERR_EXTRACONTENT,
|
||||||
|
XML_SCHEMAS_ERR_INVALIDATTR,
|
||||||
|
XML_SCHEMAS_ERR_INVALIDELEM,
|
||||||
|
XML_SCHEMAS_ERR_NOTDETERMINIST,
|
||||||
|
XML_SCHEMAS_ERR_CONSTRUCT,
|
||||||
|
XML_SCHEMAS_ERR_INTERNAL,
|
||||||
|
XML_SCHEMAS_ERR_NOTSIMPLE,
|
||||||
|
XML_SCHEMAS_ERR_ATTRUNKNOWN,
|
||||||
|
XML_SCHEMAS_ERR_ATTRINVALID,
|
||||||
|
XML_SCHEMAS_ERR_VALUE,
|
||||||
|
XML_SCHEMAS_ERR_FACET,
|
||||||
|
XML_SCHEMAS_ERR_,
|
||||||
|
XML_SCHEMAS_ERR_XXX
|
||||||
|
} xmlSchemaValidError;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* ATTENTION: Change xmlSchemaSetValidOptions's check
|
||||||
|
* for invalid values, if adding to the validation
|
||||||
|
* options below.
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* xmlSchemaValidOption:
|
||||||
|
*
|
||||||
|
* This is the set of XML Schema validation options.
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
XML_SCHEMA_VAL_VC_I_CREATE = 1<<0
|
||||||
|
/* Default/fixed: create an attribute node
|
||||||
|
* or an element's text node on the instance.
|
||||||
|
*/
|
||||||
|
} xmlSchemaValidOption;
|
||||||
|
|
||||||
|
/*
|
||||||
|
XML_SCHEMA_VAL_XSI_ASSEMBLE = 1<<1,
|
||||||
|
* assemble schemata using
|
||||||
|
* xsi:schemaLocation and
|
||||||
|
* xsi:noNamespaceSchemaLocation
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The schemas related types are kept internal
|
||||||
|
*/
|
||||||
|
typedef struct _xmlSchema xmlSchema;
|
||||||
|
typedef xmlSchema *xmlSchemaPtr;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlSchemaValidityErrorFunc:
|
||||||
|
* @ctx: the validation context
|
||||||
|
* @msg: the message
|
||||||
|
* @...: extra arguments
|
||||||
|
*
|
||||||
|
* Signature of an error callback from an XSD validation
|
||||||
|
*/
|
||||||
|
typedef void (XMLCDECL *xmlSchemaValidityErrorFunc) (void *ctx, const char *msg, ...) LIBXML_ATTR_FORMAT(2,3);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlSchemaValidityWarningFunc:
|
||||||
|
* @ctx: the validation context
|
||||||
|
* @msg: the message
|
||||||
|
* @...: extra arguments
|
||||||
|
*
|
||||||
|
* Signature of a warning callback from an XSD validation
|
||||||
|
*/
|
||||||
|
typedef void (XMLCDECL *xmlSchemaValidityWarningFunc) (void *ctx, const char *msg, ...) LIBXML_ATTR_FORMAT(2,3);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A schemas validation context
|
||||||
|
*/
|
||||||
|
typedef struct _xmlSchemaParserCtxt xmlSchemaParserCtxt;
|
||||||
|
typedef xmlSchemaParserCtxt *xmlSchemaParserCtxtPtr;
|
||||||
|
|
||||||
|
typedef struct _xmlSchemaValidCtxt xmlSchemaValidCtxt;
|
||||||
|
typedef xmlSchemaValidCtxt *xmlSchemaValidCtxtPtr;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Interfaces for parsing.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlSchemaParserCtxtPtr XMLCALL
|
||||||
|
xmlSchemaNewParserCtxt (const char *URL);
|
||||||
|
XMLPUBFUN xmlSchemaParserCtxtPtr XMLCALL
|
||||||
|
xmlSchemaNewMemParserCtxt (const char *buffer,
|
||||||
|
int size);
|
||||||
|
XMLPUBFUN xmlSchemaParserCtxtPtr XMLCALL
|
||||||
|
xmlSchemaNewDocParserCtxt (xmlDocPtr doc);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSchemaFreeParserCtxt (xmlSchemaParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSchemaSetParserErrors (xmlSchemaParserCtxtPtr ctxt,
|
||||||
|
xmlSchemaValidityErrorFunc err,
|
||||||
|
xmlSchemaValidityWarningFunc warn,
|
||||||
|
void *ctx);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSchemaSetParserStructuredErrors(xmlSchemaParserCtxtPtr ctxt,
|
||||||
|
xmlStructuredErrorFunc serror,
|
||||||
|
void *ctx);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchemaGetParserErrors(xmlSchemaParserCtxtPtr ctxt,
|
||||||
|
xmlSchemaValidityErrorFunc * err,
|
||||||
|
xmlSchemaValidityWarningFunc * warn,
|
||||||
|
void **ctx);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchemaIsValid (xmlSchemaValidCtxtPtr ctxt);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlSchemaPtr XMLCALL
|
||||||
|
xmlSchemaParse (xmlSchemaParserCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSchemaFree (xmlSchemaPtr schema);
|
||||||
|
#ifdef LIBXML_OUTPUT_ENABLED
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSchemaDump (FILE *output,
|
||||||
|
xmlSchemaPtr schema);
|
||||||
|
#endif /* LIBXML_OUTPUT_ENABLED */
|
||||||
|
/*
|
||||||
|
* Interfaces for validating
|
||||||
|
*/
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSchemaSetValidErrors (xmlSchemaValidCtxtPtr ctxt,
|
||||||
|
xmlSchemaValidityErrorFunc err,
|
||||||
|
xmlSchemaValidityWarningFunc warn,
|
||||||
|
void *ctx);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSchemaSetValidStructuredErrors(xmlSchemaValidCtxtPtr ctxt,
|
||||||
|
xmlStructuredErrorFunc serror,
|
||||||
|
void *ctx);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchemaGetValidErrors (xmlSchemaValidCtxtPtr ctxt,
|
||||||
|
xmlSchemaValidityErrorFunc *err,
|
||||||
|
xmlSchemaValidityWarningFunc *warn,
|
||||||
|
void **ctx);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchemaSetValidOptions (xmlSchemaValidCtxtPtr ctxt,
|
||||||
|
int options);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchemaValidCtxtGetOptions(xmlSchemaValidCtxtPtr ctxt);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlSchemaValidCtxtPtr XMLCALL
|
||||||
|
xmlSchemaNewValidCtxt (xmlSchemaPtr schema);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSchemaFreeValidCtxt (xmlSchemaValidCtxtPtr ctxt);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchemaValidateDoc (xmlSchemaValidCtxtPtr ctxt,
|
||||||
|
xmlDocPtr instance);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchemaValidateOneElement (xmlSchemaValidCtxtPtr ctxt,
|
||||||
|
xmlNodePtr elem);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchemaValidateStream (xmlSchemaValidCtxtPtr ctxt,
|
||||||
|
xmlParserInputBufferPtr input,
|
||||||
|
xmlCharEncoding enc,
|
||||||
|
xmlSAXHandlerPtr sax,
|
||||||
|
void *user_data);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchemaValidateFile (xmlSchemaValidCtxtPtr ctxt,
|
||||||
|
const char * filename,
|
||||||
|
int options);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlParserCtxtPtr XMLCALL
|
||||||
|
xmlSchemaValidCtxtGetParserCtxt(xmlSchemaValidCtxtPtr ctxt);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Interface to insert Schemas SAX validation in a SAX stream
|
||||||
|
*/
|
||||||
|
typedef struct _xmlSchemaSAXPlug xmlSchemaSAXPlugStruct;
|
||||||
|
typedef xmlSchemaSAXPlugStruct *xmlSchemaSAXPlugPtr;
|
||||||
|
|
||||||
|
XMLPUBFUN xmlSchemaSAXPlugPtr XMLCALL
|
||||||
|
xmlSchemaSAXPlug (xmlSchemaValidCtxtPtr ctxt,
|
||||||
|
xmlSAXHandlerPtr *sax,
|
||||||
|
void **user_data);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchemaSAXUnplug (xmlSchemaSAXPlugPtr plug);
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* LIBXML_SCHEMAS_ENABLED */
|
||||||
|
#endif /* __XML_SCHEMA_H__ */
|
|
@ -0,0 +1,151 @@
|
||||||
|
/*
|
||||||
|
* Summary: implementation of XML Schema Datatypes
|
||||||
|
* Description: module providing the XML Schema Datatypes implementation
|
||||||
|
* both definition and validity checking
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef __XML_SCHEMA_TYPES_H__
|
||||||
|
#define __XML_SCHEMA_TYPES_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
|
||||||
|
#ifdef LIBXML_SCHEMAS_ENABLED
|
||||||
|
|
||||||
|
#include <libxml/schemasInternals.h>
|
||||||
|
#include <libxml/xmlschemas.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
XML_SCHEMA_WHITESPACE_UNKNOWN = 0,
|
||||||
|
XML_SCHEMA_WHITESPACE_PRESERVE = 1,
|
||||||
|
XML_SCHEMA_WHITESPACE_REPLACE = 2,
|
||||||
|
XML_SCHEMA_WHITESPACE_COLLAPSE = 3
|
||||||
|
} xmlSchemaWhitespaceValueType;
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSchemaInitTypes (void);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSchemaCleanupTypes (void);
|
||||||
|
XMLPUBFUN xmlSchemaTypePtr XMLCALL
|
||||||
|
xmlSchemaGetPredefinedType (const xmlChar *name,
|
||||||
|
const xmlChar *ns);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchemaValidatePredefinedType (xmlSchemaTypePtr type,
|
||||||
|
const xmlChar *value,
|
||||||
|
xmlSchemaValPtr *val);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchemaValPredefTypeNode (xmlSchemaTypePtr type,
|
||||||
|
const xmlChar *value,
|
||||||
|
xmlSchemaValPtr *val,
|
||||||
|
xmlNodePtr node);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchemaValidateFacet (xmlSchemaTypePtr base,
|
||||||
|
xmlSchemaFacetPtr facet,
|
||||||
|
const xmlChar *value,
|
||||||
|
xmlSchemaValPtr val);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchemaValidateFacetWhtsp (xmlSchemaFacetPtr facet,
|
||||||
|
xmlSchemaWhitespaceValueType fws,
|
||||||
|
xmlSchemaValType valType,
|
||||||
|
const xmlChar *value,
|
||||||
|
xmlSchemaValPtr val,
|
||||||
|
xmlSchemaWhitespaceValueType ws);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSchemaFreeValue (xmlSchemaValPtr val);
|
||||||
|
XMLPUBFUN xmlSchemaFacetPtr XMLCALL
|
||||||
|
xmlSchemaNewFacet (void);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchemaCheckFacet (xmlSchemaFacetPtr facet,
|
||||||
|
xmlSchemaTypePtr typeDecl,
|
||||||
|
xmlSchemaParserCtxtPtr ctxt,
|
||||||
|
const xmlChar *name);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlSchemaFreeFacet (xmlSchemaFacetPtr facet);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchemaCompareValues (xmlSchemaValPtr x,
|
||||||
|
xmlSchemaValPtr y);
|
||||||
|
XMLPUBFUN xmlSchemaTypePtr XMLCALL
|
||||||
|
xmlSchemaGetBuiltInListSimpleTypeItemType (xmlSchemaTypePtr type);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchemaValidateListSimpleTypeFacet (xmlSchemaFacetPtr facet,
|
||||||
|
const xmlChar *value,
|
||||||
|
unsigned long actualLen,
|
||||||
|
unsigned long *expectedLen);
|
||||||
|
XMLPUBFUN xmlSchemaTypePtr XMLCALL
|
||||||
|
xmlSchemaGetBuiltInType (xmlSchemaValType type);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchemaIsBuiltInTypeFacet (xmlSchemaTypePtr type,
|
||||||
|
int facetType);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlSchemaCollapseString (const xmlChar *value);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlSchemaWhiteSpaceReplace (const xmlChar *value);
|
||||||
|
XMLPUBFUN unsigned long XMLCALL
|
||||||
|
xmlSchemaGetFacetValueAsULong (xmlSchemaFacetPtr facet);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchemaValidateLengthFacet (xmlSchemaTypePtr type,
|
||||||
|
xmlSchemaFacetPtr facet,
|
||||||
|
const xmlChar *value,
|
||||||
|
xmlSchemaValPtr val,
|
||||||
|
unsigned long *length);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchemaValidateLengthFacetWhtsp(xmlSchemaFacetPtr facet,
|
||||||
|
xmlSchemaValType valType,
|
||||||
|
const xmlChar *value,
|
||||||
|
xmlSchemaValPtr val,
|
||||||
|
unsigned long *length,
|
||||||
|
xmlSchemaWhitespaceValueType ws);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchemaValPredefTypeNodeNoNorm(xmlSchemaTypePtr type,
|
||||||
|
const xmlChar *value,
|
||||||
|
xmlSchemaValPtr *val,
|
||||||
|
xmlNodePtr node);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchemaGetCanonValue (xmlSchemaValPtr val,
|
||||||
|
const xmlChar **retValue);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchemaGetCanonValueWhtsp (xmlSchemaValPtr val,
|
||||||
|
const xmlChar **retValue,
|
||||||
|
xmlSchemaWhitespaceValueType ws);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchemaValueAppend (xmlSchemaValPtr prev,
|
||||||
|
xmlSchemaValPtr cur);
|
||||||
|
XMLPUBFUN xmlSchemaValPtr XMLCALL
|
||||||
|
xmlSchemaValueGetNext (xmlSchemaValPtr cur);
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlSchemaValueGetAsString (xmlSchemaValPtr val);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchemaValueGetAsBoolean (xmlSchemaValPtr val);
|
||||||
|
XMLPUBFUN xmlSchemaValPtr XMLCALL
|
||||||
|
xmlSchemaNewStringValue (xmlSchemaValType type,
|
||||||
|
const xmlChar *value);
|
||||||
|
XMLPUBFUN xmlSchemaValPtr XMLCALL
|
||||||
|
xmlSchemaNewNOTATIONValue (const xmlChar *name,
|
||||||
|
const xmlChar *ns);
|
||||||
|
XMLPUBFUN xmlSchemaValPtr XMLCALL
|
||||||
|
xmlSchemaNewQNameValue (const xmlChar *namespaceName,
|
||||||
|
const xmlChar *localName);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlSchemaCompareValuesWhtsp (xmlSchemaValPtr x,
|
||||||
|
xmlSchemaWhitespaceValueType xws,
|
||||||
|
xmlSchemaValPtr y,
|
||||||
|
xmlSchemaWhitespaceValueType yws);
|
||||||
|
XMLPUBFUN xmlSchemaValPtr XMLCALL
|
||||||
|
xmlSchemaCopyValue (xmlSchemaValPtr val);
|
||||||
|
XMLPUBFUN xmlSchemaValType XMLCALL
|
||||||
|
xmlSchemaGetValType (xmlSchemaValPtr val);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* LIBXML_SCHEMAS_ENABLED */
|
||||||
|
#endif /* __XML_SCHEMA_TYPES_H__ */
|
|
@ -0,0 +1,140 @@
|
||||||
|
/*
|
||||||
|
* Summary: set of routines to process strings
|
||||||
|
* Description: type and interfaces needed for the internal string handling
|
||||||
|
* of the library, especially UTF8 processing.
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_STRING_H__
|
||||||
|
#define __XML_STRING_H__
|
||||||
|
|
||||||
|
#include <stdarg.h>
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlChar:
|
||||||
|
*
|
||||||
|
* This is a basic byte in an UTF-8 encoded string.
|
||||||
|
* It's unsigned allowing to pinpoint case where char * are assigned
|
||||||
|
* to xmlChar * (possibly making serialization back impossible).
|
||||||
|
*/
|
||||||
|
typedef unsigned char xmlChar;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* BAD_CAST:
|
||||||
|
*
|
||||||
|
* Macro to cast a string to an xmlChar * when one know its safe.
|
||||||
|
*/
|
||||||
|
#define BAD_CAST (xmlChar *)
|
||||||
|
|
||||||
|
/*
|
||||||
|
* xmlChar handling
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlStrdup (const xmlChar *cur);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlStrndup (const xmlChar *cur,
|
||||||
|
int len);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlCharStrndup (const char *cur,
|
||||||
|
int len);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlCharStrdup (const char *cur);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlStrsub (const xmlChar *str,
|
||||||
|
int start,
|
||||||
|
int len);
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlStrchr (const xmlChar *str,
|
||||||
|
xmlChar val);
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlStrstr (const xmlChar *str,
|
||||||
|
const xmlChar *val);
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlStrcasestr (const xmlChar *str,
|
||||||
|
const xmlChar *val);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlStrcmp (const xmlChar *str1,
|
||||||
|
const xmlChar *str2);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlStrncmp (const xmlChar *str1,
|
||||||
|
const xmlChar *str2,
|
||||||
|
int len);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlStrcasecmp (const xmlChar *str1,
|
||||||
|
const xmlChar *str2);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlStrncasecmp (const xmlChar *str1,
|
||||||
|
const xmlChar *str2,
|
||||||
|
int len);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlStrEqual (const xmlChar *str1,
|
||||||
|
const xmlChar *str2);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlStrQEqual (const xmlChar *pref,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *str);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlStrlen (const xmlChar *str);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlStrcat (xmlChar *cur,
|
||||||
|
const xmlChar *add);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlStrncat (xmlChar *cur,
|
||||||
|
const xmlChar *add,
|
||||||
|
int len);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlStrncatNew (const xmlChar *str1,
|
||||||
|
const xmlChar *str2,
|
||||||
|
int len);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlStrPrintf (xmlChar *buf,
|
||||||
|
int len,
|
||||||
|
const xmlChar *msg,
|
||||||
|
...);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlStrVPrintf (xmlChar *buf,
|
||||||
|
int len,
|
||||||
|
const xmlChar *msg,
|
||||||
|
va_list ap);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlGetUTF8Char (const unsigned char *utf,
|
||||||
|
int *len);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlCheckUTF8 (const unsigned char *utf);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlUTF8Strsize (const xmlChar *utf,
|
||||||
|
int len);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlUTF8Strndup (const xmlChar *utf,
|
||||||
|
int len);
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlUTF8Strpos (const xmlChar *utf,
|
||||||
|
int pos);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlUTF8Strloc (const xmlChar *utf,
|
||||||
|
const xmlChar *utfchar);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlUTF8Strsub (const xmlChar *utf,
|
||||||
|
int start,
|
||||||
|
int len);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlUTF8Strlen (const xmlChar *utf);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlUTF8Size (const xmlChar *utf);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlUTF8Charcmp (const xmlChar *utf1,
|
||||||
|
const xmlChar *utf2);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif /* __XML_STRING_H__ */
|
|
@ -0,0 +1,202 @@
|
||||||
|
/*
|
||||||
|
* Summary: Unicode character APIs
|
||||||
|
* Description: API for the Unicode character APIs
|
||||||
|
*
|
||||||
|
* This file is automatically generated from the
|
||||||
|
* UCS description files of the Unicode Character Database
|
||||||
|
* http://www.unicode.org/Public/4.0-Update1/UCD-4.0.1.html
|
||||||
|
* using the genUnicode.py Python script.
|
||||||
|
*
|
||||||
|
* Generation date: Mon Mar 27 11:09:52 2006
|
||||||
|
* Sources: Blocks-4.0.1.txt UnicodeData-4.0.1.txt
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_UNICODE_H__
|
||||||
|
#define __XML_UNICODE_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
|
||||||
|
#ifdef LIBXML_UNICODE_ENABLED
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsAegeanNumbers (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsAlphabeticPresentationForms (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsArabic (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsArabicPresentationFormsA (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsArabicPresentationFormsB (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsArmenian (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsArrows (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsBasicLatin (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsBengali (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsBlockElements (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsBopomofo (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsBopomofoExtended (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsBoxDrawing (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsBraillePatterns (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsBuhid (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsByzantineMusicalSymbols (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCJKCompatibility (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCJKCompatibilityForms (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCJKCompatibilityIdeographs (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCJKCompatibilityIdeographsSupplement (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCJKRadicalsSupplement (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCJKSymbolsandPunctuation (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCJKUnifiedIdeographs (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCJKUnifiedIdeographsExtensionA (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCJKUnifiedIdeographsExtensionB (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCherokee (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCombiningDiacriticalMarks (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCombiningDiacriticalMarksforSymbols (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCombiningHalfMarks (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCombiningMarksforSymbols (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsControlPictures (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCurrencySymbols (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCypriotSyllabary (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCyrillic (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCyrillicSupplement (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsDeseret (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsDevanagari (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsDingbats (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsEnclosedAlphanumerics (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsEnclosedCJKLettersandMonths (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsEthiopic (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsGeneralPunctuation (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsGeometricShapes (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsGeorgian (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsGothic (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsGreek (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsGreekExtended (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsGreekandCoptic (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsGujarati (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsGurmukhi (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsHalfwidthandFullwidthForms (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsHangulCompatibilityJamo (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsHangulJamo (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsHangulSyllables (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsHanunoo (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsHebrew (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsHighPrivateUseSurrogates (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsHighSurrogates (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsHiragana (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsIPAExtensions (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsIdeographicDescriptionCharacters (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsKanbun (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsKangxiRadicals (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsKannada (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsKatakana (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsKatakanaPhoneticExtensions (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsKhmer (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsKhmerSymbols (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsLao (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsLatin1Supplement (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsLatinExtendedA (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsLatinExtendedB (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsLatinExtendedAdditional (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsLetterlikeSymbols (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsLimbu (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsLinearBIdeograms (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsLinearBSyllabary (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsLowSurrogates (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsMalayalam (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsMathematicalAlphanumericSymbols (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsMathematicalOperators (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsMiscellaneousMathematicalSymbolsA (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsMiscellaneousMathematicalSymbolsB (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsMiscellaneousSymbols (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsMiscellaneousSymbolsandArrows (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsMiscellaneousTechnical (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsMongolian (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsMusicalSymbols (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsMyanmar (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsNumberForms (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsOgham (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsOldItalic (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsOpticalCharacterRecognition (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsOriya (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsOsmanya (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsPhoneticExtensions (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsPrivateUse (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsPrivateUseArea (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsRunic (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsShavian (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsSinhala (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsSmallFormVariants (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsSpacingModifierLetters (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsSpecials (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsSuperscriptsandSubscripts (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsSupplementalArrowsA (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsSupplementalArrowsB (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsSupplementalMathematicalOperators (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsSupplementaryPrivateUseAreaA (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsSupplementaryPrivateUseAreaB (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsSyriac (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsTagalog (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsTagbanwa (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsTags (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsTaiLe (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsTaiXuanJingSymbols (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsTamil (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsTelugu (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsThaana (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsThai (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsTibetan (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsUgaritic (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsUnifiedCanadianAboriginalSyllabics (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsVariationSelectors (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsVariationSelectorsSupplement (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsYiRadicals (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsYiSyllables (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsYijingHexagramSymbols (int code);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsBlock (int code, const char *block);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatC (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatCc (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatCf (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatCo (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatCs (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatL (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatLl (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatLm (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatLo (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatLt (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatLu (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatM (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatMc (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatMe (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatMn (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatN (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatNd (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatNl (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatNo (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatP (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatPc (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatPd (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatPe (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatPf (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatPi (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatPo (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatPs (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatS (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatSc (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatSk (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatSm (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatSo (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatZ (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatZl (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatZp (int code);
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCatZs (int code);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL xmlUCSIsCat (int code, const char *cat);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* LIBXML_UNICODE_ENABLED */
|
||||||
|
|
||||||
|
#endif /* __XML_UNICODE_H__ */
|
|
@ -0,0 +1,467 @@
|
||||||
|
/*
|
||||||
|
* Summary: compile-time version informations
|
||||||
|
* Description: compile-time version informations for the XML library
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_VERSION_H__
|
||||||
|
#define __XML_VERSION_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlexports.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* use those to be sure nothing nasty will happen if
|
||||||
|
* your library and includes mismatch
|
||||||
|
*/
|
||||||
|
#ifndef LIBXML2_COMPILING_MSCCDEF
|
||||||
|
XMLPUBFUN void XMLCALL xmlCheckVersion(int version);
|
||||||
|
#endif /* LIBXML2_COMPILING_MSCCDEF */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_DOTTED_VERSION:
|
||||||
|
*
|
||||||
|
* the version string like "1.2.3"
|
||||||
|
*/
|
||||||
|
#define LIBXML_DOTTED_VERSION "2.7.8"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_VERSION:
|
||||||
|
*
|
||||||
|
* the version number: 1.2.3 value is 10203
|
||||||
|
*/
|
||||||
|
#define LIBXML_VERSION 20708
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_VERSION_STRING:
|
||||||
|
*
|
||||||
|
* the version number string, 1.2.3 value is "10203"
|
||||||
|
*/
|
||||||
|
#define LIBXML_VERSION_STRING "20708"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_VERSION_EXTRA:
|
||||||
|
*
|
||||||
|
* extra version information, used to show a CVS compilation
|
||||||
|
*/
|
||||||
|
#define LIBXML_VERSION_EXTRA ""
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_TEST_VERSION:
|
||||||
|
*
|
||||||
|
* Macro to check that the libxml version in use is compatible with
|
||||||
|
* the version the software has been compiled against
|
||||||
|
*/
|
||||||
|
#define LIBXML_TEST_VERSION xmlCheckVersion(20708);
|
||||||
|
|
||||||
|
#ifndef VMS
|
||||||
|
#if 0
|
||||||
|
/**
|
||||||
|
* WITH_TRIO:
|
||||||
|
*
|
||||||
|
* defined if the trio support need to be configured in
|
||||||
|
*/
|
||||||
|
#define WITH_TRIO
|
||||||
|
#else
|
||||||
|
/**
|
||||||
|
* WITHOUT_TRIO:
|
||||||
|
*
|
||||||
|
* defined if the trio support should not be configured in
|
||||||
|
*/
|
||||||
|
#define WITHOUT_TRIO
|
||||||
|
#endif
|
||||||
|
#else /* VMS */
|
||||||
|
/**
|
||||||
|
* WITH_TRIO:
|
||||||
|
*
|
||||||
|
* defined if the trio support need to be configured in
|
||||||
|
*/
|
||||||
|
#define WITH_TRIO 1
|
||||||
|
#endif /* VMS */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_THREAD_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether the thread support is configured in
|
||||||
|
*/
|
||||||
|
#if 0
|
||||||
|
#if defined(_REENTRANT) || defined(__MT__) || \
|
||||||
|
(defined(_POSIX_C_SOURCE) && (_POSIX_C_SOURCE - 0 >= 199506L))
|
||||||
|
#define LIBXML_THREAD_ENABLED
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_TREE_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether the DOM like tree manipulation API support is configured in
|
||||||
|
*/
|
||||||
|
#if 1
|
||||||
|
#define LIBXML_TREE_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_OUTPUT_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether the serialization/saving support is configured in
|
||||||
|
*/
|
||||||
|
#if 1
|
||||||
|
#define LIBXML_OUTPUT_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_PUSH_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether the push parsing interfaces are configured in
|
||||||
|
*/
|
||||||
|
#if 1
|
||||||
|
#define LIBXML_PUSH_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_READER_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether the xmlReader parsing interface is configured in
|
||||||
|
*/
|
||||||
|
#if 1
|
||||||
|
#define LIBXML_READER_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_PATTERN_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether the xmlPattern node selection interface is configured in
|
||||||
|
*/
|
||||||
|
#if 1
|
||||||
|
#define LIBXML_PATTERN_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_WRITER_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether the xmlWriter saving interface is configured in
|
||||||
|
*/
|
||||||
|
#if 1
|
||||||
|
#define LIBXML_WRITER_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_SAX1_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether the older SAX1 interface is configured in
|
||||||
|
*/
|
||||||
|
#if 1
|
||||||
|
#define LIBXML_SAX1_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_FTP_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether the FTP support is configured in
|
||||||
|
*/
|
||||||
|
#if 0
|
||||||
|
#define LIBXML_FTP_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_HTTP_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether the HTTP support is configured in
|
||||||
|
*/
|
||||||
|
#if 0
|
||||||
|
#define LIBXML_HTTP_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_VALID_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether the DTD validation support is configured in
|
||||||
|
*/
|
||||||
|
#if 1
|
||||||
|
#define LIBXML_VALID_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_HTML_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether the HTML support is configured in
|
||||||
|
*/
|
||||||
|
#if 1
|
||||||
|
#define LIBXML_HTML_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_LEGACY_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether the deprecated APIs are compiled in for compatibility
|
||||||
|
*/
|
||||||
|
#if 1
|
||||||
|
#define LIBXML_LEGACY_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_C14N_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether the Canonicalization support is configured in
|
||||||
|
*/
|
||||||
|
#if 1
|
||||||
|
#define LIBXML_C14N_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_CATALOG_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether the Catalog support is configured in
|
||||||
|
*/
|
||||||
|
#if 1
|
||||||
|
#define LIBXML_CATALOG_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_DOCB_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether the SGML Docbook support is configured in
|
||||||
|
*/
|
||||||
|
#if 1
|
||||||
|
#define LIBXML_DOCB_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_XPATH_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether XPath is configured in
|
||||||
|
*/
|
||||||
|
#if 1
|
||||||
|
#define LIBXML_XPATH_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_XPTR_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether XPointer is configured in
|
||||||
|
*/
|
||||||
|
#if 1
|
||||||
|
#define LIBXML_XPTR_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_XINCLUDE_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether XInclude is configured in
|
||||||
|
*/
|
||||||
|
#if 1
|
||||||
|
#define LIBXML_XINCLUDE_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_ICONV_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether iconv support is available
|
||||||
|
*/
|
||||||
|
#if 1
|
||||||
|
#define LIBXML_ICONV_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_ICU_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether icu support is available
|
||||||
|
*/
|
||||||
|
#if 0
|
||||||
|
#define LIBXML_ICU_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_ISO8859X_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether ISO-8859-* support is made available in case iconv is not
|
||||||
|
*/
|
||||||
|
#if 1
|
||||||
|
#define LIBXML_ISO8859X_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_DEBUG_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether Debugging module is configured in
|
||||||
|
*/
|
||||||
|
#if 1
|
||||||
|
#define LIBXML_DEBUG_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* DEBUG_MEMORY_LOCATION:
|
||||||
|
*
|
||||||
|
* Whether the memory debugging is configured in
|
||||||
|
*/
|
||||||
|
#if 0
|
||||||
|
#define DEBUG_MEMORY_LOCATION
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_DEBUG_RUNTIME:
|
||||||
|
*
|
||||||
|
* Whether the runtime debugging is configured in
|
||||||
|
*/
|
||||||
|
#if 0
|
||||||
|
#define LIBXML_DEBUG_RUNTIME
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_UNICODE_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether the Unicode related interfaces are compiled in
|
||||||
|
*/
|
||||||
|
#if 1
|
||||||
|
#define LIBXML_UNICODE_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_REGEXP_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether the regular expressions interfaces are compiled in
|
||||||
|
*/
|
||||||
|
#if 1
|
||||||
|
#define LIBXML_REGEXP_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_AUTOMATA_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether the automata interfaces are compiled in
|
||||||
|
*/
|
||||||
|
#if 1
|
||||||
|
#define LIBXML_AUTOMATA_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_EXPR_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether the formal expressions interfaces are compiled in
|
||||||
|
*/
|
||||||
|
#if 1
|
||||||
|
#define LIBXML_EXPR_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_SCHEMAS_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether the Schemas validation interfaces are compiled in
|
||||||
|
*/
|
||||||
|
#if 1
|
||||||
|
#define LIBXML_SCHEMAS_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_SCHEMATRON_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether the Schematron validation interfaces are compiled in
|
||||||
|
*/
|
||||||
|
#if 1
|
||||||
|
#define LIBXML_SCHEMATRON_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_MODULES_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether the module interfaces are compiled in
|
||||||
|
*/
|
||||||
|
#if 1
|
||||||
|
#define LIBXML_MODULES_ENABLED
|
||||||
|
/**
|
||||||
|
* LIBXML_MODULE_EXTENSION:
|
||||||
|
*
|
||||||
|
* the string suffix used by dynamic modules (usually shared libraries)
|
||||||
|
*/
|
||||||
|
#define LIBXML_MODULE_EXTENSION ".so"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_ZLIB_ENABLED:
|
||||||
|
*
|
||||||
|
* Whether the Zlib support is compiled in
|
||||||
|
*/
|
||||||
|
#if 1
|
||||||
|
#define LIBXML_ZLIB_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef __GNUC__
|
||||||
|
#ifdef HAVE_ANSIDECL_H
|
||||||
|
#include <ansidecl.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ATTRIBUTE_UNUSED:
|
||||||
|
*
|
||||||
|
* Macro used to signal to GCC unused function parameters
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef ATTRIBUTE_UNUSED
|
||||||
|
#define ATTRIBUTE_UNUSED __attribute__((unused))
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_ATTR_ALLOC_SIZE:
|
||||||
|
*
|
||||||
|
* Macro used to indicate to GCC this is an allocator function
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef LIBXML_ATTR_ALLOC_SIZE
|
||||||
|
# if ((__GNUC__ > 4) || ((__GNUC__ == 4) && (__GNUC_MINOR__ >= 3)))
|
||||||
|
# define LIBXML_ATTR_ALLOC_SIZE(x) __attribute__((alloc_size(x)))
|
||||||
|
# else
|
||||||
|
# define LIBXML_ATTR_ALLOC_SIZE(x)
|
||||||
|
# endif
|
||||||
|
#else
|
||||||
|
# define LIBXML_ATTR_ALLOC_SIZE(x)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LIBXML_ATTR_FORMAT:
|
||||||
|
*
|
||||||
|
* Macro used to indicate to GCC the parameter are printf like
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef LIBXML_ATTR_FORMAT
|
||||||
|
# if ((__GNUC__ > 3) || ((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)))
|
||||||
|
# define LIBXML_ATTR_FORMAT(fmt,args) __attribute__((__format__(__printf__,fmt,args)))
|
||||||
|
# else
|
||||||
|
# define LIBXML_ATTR_FORMAT(fmt,args)
|
||||||
|
# endif
|
||||||
|
#else
|
||||||
|
# define LIBXML_ATTR_FORMAT(fmt,args)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#else /* ! __GNUC__ */
|
||||||
|
/**
|
||||||
|
* ATTRIBUTE_UNUSED:
|
||||||
|
*
|
||||||
|
* Macro used to signal to GCC unused function parameters
|
||||||
|
*/
|
||||||
|
#define ATTRIBUTE_UNUSED
|
||||||
|
/**
|
||||||
|
* LIBXML_ATTR_ALLOC_SIZE:
|
||||||
|
*
|
||||||
|
* Macro used to indicate to GCC this is an allocator function
|
||||||
|
*/
|
||||||
|
#define LIBXML_ATTR_ALLOC_SIZE(x)
|
||||||
|
/**
|
||||||
|
* LIBXML_ATTR_FORMAT:
|
||||||
|
*
|
||||||
|
* Macro used to indicate to GCC the parameter are printf like
|
||||||
|
*/
|
||||||
|
#define LIBXML_ATTR_FORMAT(fmt,args)
|
||||||
|
#endif /* __GNUC__ */
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif /* __cplusplus */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,485 @@
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Summary: text writing API for XML
|
||||||
|
* Description: text writing API for XML
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Alfred Mickautsch <alfred@mickautsch.de>
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_XMLWRITER_H__
|
||||||
|
#define __XML_XMLWRITER_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
|
||||||
|
#ifdef LIBXML_WRITER_ENABLED
|
||||||
|
|
||||||
|
#include <stdarg.h>
|
||||||
|
#include <libxml/xmlIO.h>
|
||||||
|
#include <libxml/list.h>
|
||||||
|
#include <libxml/xmlstring.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef struct _xmlTextWriter xmlTextWriter;
|
||||||
|
typedef xmlTextWriter *xmlTextWriterPtr;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Constructors & Destructor
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlTextWriterPtr XMLCALL
|
||||||
|
xmlNewTextWriter(xmlOutputBufferPtr out);
|
||||||
|
XMLPUBFUN xmlTextWriterPtr XMLCALL
|
||||||
|
xmlNewTextWriterFilename(const char *uri, int compression);
|
||||||
|
XMLPUBFUN xmlTextWriterPtr XMLCALL
|
||||||
|
xmlNewTextWriterMemory(xmlBufferPtr buf, int compression);
|
||||||
|
XMLPUBFUN xmlTextWriterPtr XMLCALL
|
||||||
|
xmlNewTextWriterPushParser(xmlParserCtxtPtr ctxt, int compression);
|
||||||
|
XMLPUBFUN xmlTextWriterPtr XMLCALL
|
||||||
|
xmlNewTextWriterDoc(xmlDocPtr * doc, int compression);
|
||||||
|
XMLPUBFUN xmlTextWriterPtr XMLCALL
|
||||||
|
xmlNewTextWriterTree(xmlDocPtr doc, xmlNodePtr node,
|
||||||
|
int compression);
|
||||||
|
XMLPUBFUN void XMLCALL xmlFreeTextWriter(xmlTextWriterPtr writer);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Functions
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Document
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterStartDocument(xmlTextWriterPtr writer,
|
||||||
|
const char *version,
|
||||||
|
const char *encoding,
|
||||||
|
const char *standalone);
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterEndDocument(xmlTextWriterPtr
|
||||||
|
writer);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Comments
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterStartComment(xmlTextWriterPtr
|
||||||
|
writer);
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterEndComment(xmlTextWriterPtr writer);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteFormatComment(xmlTextWriterPtr writer,
|
||||||
|
const char *format, ...)
|
||||||
|
LIBXML_ATTR_FORMAT(2,3);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteVFormatComment(xmlTextWriterPtr writer,
|
||||||
|
const char *format,
|
||||||
|
va_list argptr)
|
||||||
|
LIBXML_ATTR_FORMAT(2,0);
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterWriteComment(xmlTextWriterPtr
|
||||||
|
writer,
|
||||||
|
const xmlChar *
|
||||||
|
content);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Elements
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterStartElement(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * name);
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterStartElementNS(xmlTextWriterPtr
|
||||||
|
writer,
|
||||||
|
const xmlChar *
|
||||||
|
prefix,
|
||||||
|
const xmlChar * name,
|
||||||
|
const xmlChar *
|
||||||
|
namespaceURI);
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterEndElement(xmlTextWriterPtr writer);
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterFullEndElement(xmlTextWriterPtr
|
||||||
|
writer);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Elements conveniency functions
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteFormatElement(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * name,
|
||||||
|
const char *format, ...)
|
||||||
|
LIBXML_ATTR_FORMAT(3,4);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteVFormatElement(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * name,
|
||||||
|
const char *format,
|
||||||
|
va_list argptr)
|
||||||
|
LIBXML_ATTR_FORMAT(3,0);
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterWriteElement(xmlTextWriterPtr
|
||||||
|
writer,
|
||||||
|
const xmlChar * name,
|
||||||
|
const xmlChar *
|
||||||
|
content);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteFormatElementNS(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * prefix,
|
||||||
|
const xmlChar * name,
|
||||||
|
const xmlChar * namespaceURI,
|
||||||
|
const char *format, ...)
|
||||||
|
LIBXML_ATTR_FORMAT(5,6);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteVFormatElementNS(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * prefix,
|
||||||
|
const xmlChar * name,
|
||||||
|
const xmlChar * namespaceURI,
|
||||||
|
const char *format,
|
||||||
|
va_list argptr)
|
||||||
|
LIBXML_ATTR_FORMAT(5,0);
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterWriteElementNS(xmlTextWriterPtr
|
||||||
|
writer,
|
||||||
|
const xmlChar *
|
||||||
|
prefix,
|
||||||
|
const xmlChar * name,
|
||||||
|
const xmlChar *
|
||||||
|
namespaceURI,
|
||||||
|
const xmlChar *
|
||||||
|
content);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Text
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteFormatRaw(xmlTextWriterPtr writer,
|
||||||
|
const char *format, ...)
|
||||||
|
LIBXML_ATTR_FORMAT(2,3);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteVFormatRaw(xmlTextWriterPtr writer,
|
||||||
|
const char *format, va_list argptr)
|
||||||
|
LIBXML_ATTR_FORMAT(2,0);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteRawLen(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * content, int len);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteRaw(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * content);
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterWriteFormatString(xmlTextWriterPtr
|
||||||
|
writer,
|
||||||
|
const char
|
||||||
|
*format, ...)
|
||||||
|
LIBXML_ATTR_FORMAT(2,3);
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterWriteVFormatString(xmlTextWriterPtr
|
||||||
|
writer,
|
||||||
|
const char
|
||||||
|
*format,
|
||||||
|
va_list argptr)
|
||||||
|
LIBXML_ATTR_FORMAT(2,0);
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterWriteString(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar *
|
||||||
|
content);
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterWriteBase64(xmlTextWriterPtr writer,
|
||||||
|
const char *data,
|
||||||
|
int start, int len);
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterWriteBinHex(xmlTextWriterPtr writer,
|
||||||
|
const char *data,
|
||||||
|
int start, int len);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Attributes
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterStartAttribute(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * name);
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterStartAttributeNS(xmlTextWriterPtr
|
||||||
|
writer,
|
||||||
|
const xmlChar *
|
||||||
|
prefix,
|
||||||
|
const xmlChar *
|
||||||
|
name,
|
||||||
|
const xmlChar *
|
||||||
|
namespaceURI);
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterEndAttribute(xmlTextWriterPtr
|
||||||
|
writer);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Attributes conveniency functions
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteFormatAttribute(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * name,
|
||||||
|
const char *format, ...)
|
||||||
|
LIBXML_ATTR_FORMAT(3,4);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteVFormatAttribute(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * name,
|
||||||
|
const char *format,
|
||||||
|
va_list argptr)
|
||||||
|
LIBXML_ATTR_FORMAT(3,0);
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterWriteAttribute(xmlTextWriterPtr
|
||||||
|
writer,
|
||||||
|
const xmlChar * name,
|
||||||
|
const xmlChar *
|
||||||
|
content);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteFormatAttributeNS(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * prefix,
|
||||||
|
const xmlChar * name,
|
||||||
|
const xmlChar * namespaceURI,
|
||||||
|
const char *format, ...)
|
||||||
|
LIBXML_ATTR_FORMAT(5,6);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteVFormatAttributeNS(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * prefix,
|
||||||
|
const xmlChar * name,
|
||||||
|
const xmlChar * namespaceURI,
|
||||||
|
const char *format,
|
||||||
|
va_list argptr)
|
||||||
|
LIBXML_ATTR_FORMAT(5,0);
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterWriteAttributeNS(xmlTextWriterPtr
|
||||||
|
writer,
|
||||||
|
const xmlChar *
|
||||||
|
prefix,
|
||||||
|
const xmlChar *
|
||||||
|
name,
|
||||||
|
const xmlChar *
|
||||||
|
namespaceURI,
|
||||||
|
const xmlChar *
|
||||||
|
content);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* PI's
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterStartPI(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * target);
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterEndPI(xmlTextWriterPtr writer);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* PI conveniency functions
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteFormatPI(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * target,
|
||||||
|
const char *format, ...)
|
||||||
|
LIBXML_ATTR_FORMAT(3,4);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteVFormatPI(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * target,
|
||||||
|
const char *format, va_list argptr)
|
||||||
|
LIBXML_ATTR_FORMAT(3,0);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWritePI(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * target,
|
||||||
|
const xmlChar * content);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlTextWriterWriteProcessingInstruction:
|
||||||
|
*
|
||||||
|
* This macro maps to xmlTextWriterWritePI
|
||||||
|
*/
|
||||||
|
#define xmlTextWriterWriteProcessingInstruction xmlTextWriterWritePI
|
||||||
|
|
||||||
|
/*
|
||||||
|
* CDATA
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterStartCDATA(xmlTextWriterPtr writer);
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterEndCDATA(xmlTextWriterPtr writer);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* CDATA conveniency functions
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteFormatCDATA(xmlTextWriterPtr writer,
|
||||||
|
const char *format, ...)
|
||||||
|
LIBXML_ATTR_FORMAT(2,3);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteVFormatCDATA(xmlTextWriterPtr writer,
|
||||||
|
const char *format, va_list argptr)
|
||||||
|
LIBXML_ATTR_FORMAT(2,0);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteCDATA(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * content);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* DTD
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterStartDTD(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * name,
|
||||||
|
const xmlChar * pubid,
|
||||||
|
const xmlChar * sysid);
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterEndDTD(xmlTextWriterPtr writer);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* DTD conveniency functions
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteFormatDTD(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * name,
|
||||||
|
const xmlChar * pubid,
|
||||||
|
const xmlChar * sysid,
|
||||||
|
const char *format, ...)
|
||||||
|
LIBXML_ATTR_FORMAT(5,6);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteVFormatDTD(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * name,
|
||||||
|
const xmlChar * pubid,
|
||||||
|
const xmlChar * sysid,
|
||||||
|
const char *format, va_list argptr)
|
||||||
|
LIBXML_ATTR_FORMAT(5,0);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteDTD(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * name,
|
||||||
|
const xmlChar * pubid,
|
||||||
|
const xmlChar * sysid,
|
||||||
|
const xmlChar * subset);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlTextWriterWriteDocType:
|
||||||
|
*
|
||||||
|
* this macro maps to xmlTextWriterWriteDTD
|
||||||
|
*/
|
||||||
|
#define xmlTextWriterWriteDocType xmlTextWriterWriteDTD
|
||||||
|
|
||||||
|
/*
|
||||||
|
* DTD element definition
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterStartDTDElement(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * name);
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterEndDTDElement(xmlTextWriterPtr
|
||||||
|
writer);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* DTD element definition conveniency functions
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteFormatDTDElement(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * name,
|
||||||
|
const char *format, ...)
|
||||||
|
LIBXML_ATTR_FORMAT(3,4);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteVFormatDTDElement(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * name,
|
||||||
|
const char *format,
|
||||||
|
va_list argptr)
|
||||||
|
LIBXML_ATTR_FORMAT(3,0);
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterWriteDTDElement(xmlTextWriterPtr
|
||||||
|
writer,
|
||||||
|
const xmlChar *
|
||||||
|
name,
|
||||||
|
const xmlChar *
|
||||||
|
content);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* DTD attribute list definition
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterStartDTDAttlist(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * name);
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterEndDTDAttlist(xmlTextWriterPtr
|
||||||
|
writer);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* DTD attribute list definition conveniency functions
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteFormatDTDAttlist(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * name,
|
||||||
|
const char *format, ...)
|
||||||
|
LIBXML_ATTR_FORMAT(3,4);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteVFormatDTDAttlist(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * name,
|
||||||
|
const char *format,
|
||||||
|
va_list argptr)
|
||||||
|
LIBXML_ATTR_FORMAT(3,0);
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterWriteDTDAttlist(xmlTextWriterPtr
|
||||||
|
writer,
|
||||||
|
const xmlChar *
|
||||||
|
name,
|
||||||
|
const xmlChar *
|
||||||
|
content);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* DTD entity definition
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterStartDTDEntity(xmlTextWriterPtr writer,
|
||||||
|
int pe, const xmlChar * name);
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterEndDTDEntity(xmlTextWriterPtr
|
||||||
|
writer);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* DTD entity definition conveniency functions
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteFormatDTDInternalEntity(xmlTextWriterPtr writer,
|
||||||
|
int pe,
|
||||||
|
const xmlChar * name,
|
||||||
|
const char *format, ...)
|
||||||
|
LIBXML_ATTR_FORMAT(4,5);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteVFormatDTDInternalEntity(xmlTextWriterPtr writer,
|
||||||
|
int pe,
|
||||||
|
const xmlChar * name,
|
||||||
|
const char *format,
|
||||||
|
va_list argptr)
|
||||||
|
LIBXML_ATTR_FORMAT(4,0);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteDTDInternalEntity(xmlTextWriterPtr writer,
|
||||||
|
int pe,
|
||||||
|
const xmlChar * name,
|
||||||
|
const xmlChar * content);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteDTDExternalEntity(xmlTextWriterPtr writer,
|
||||||
|
int pe,
|
||||||
|
const xmlChar * name,
|
||||||
|
const xmlChar * pubid,
|
||||||
|
const xmlChar * sysid,
|
||||||
|
const xmlChar * ndataid);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteDTDExternalEntityContents(xmlTextWriterPtr
|
||||||
|
writer,
|
||||||
|
const xmlChar * pubid,
|
||||||
|
const xmlChar * sysid,
|
||||||
|
const xmlChar *
|
||||||
|
ndataid);
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterWriteDTDEntity(xmlTextWriterPtr
|
||||||
|
writer, int pe,
|
||||||
|
const xmlChar * name,
|
||||||
|
const xmlChar *
|
||||||
|
pubid,
|
||||||
|
const xmlChar *
|
||||||
|
sysid,
|
||||||
|
const xmlChar *
|
||||||
|
ndataid,
|
||||||
|
const xmlChar *
|
||||||
|
content);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* DTD notation definition
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterWriteDTDNotation(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * name,
|
||||||
|
const xmlChar * pubid,
|
||||||
|
const xmlChar * sysid);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Indentation
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterSetIndent(xmlTextWriterPtr writer, int indent);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlTextWriterSetIndentString(xmlTextWriterPtr writer,
|
||||||
|
const xmlChar * str);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* misc
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL xmlTextWriterFlush(xmlTextWriterPtr writer);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* LIBXML_WRITER_ENABLED */
|
||||||
|
|
||||||
|
#endif /* __XML_XMLWRITER_H__ */
|
|
@ -0,0 +1,546 @@
|
||||||
|
/*
|
||||||
|
* Summary: XML Path Language implementation
|
||||||
|
* Description: API for the XML Path Language implementation
|
||||||
|
*
|
||||||
|
* XML Path Language implementation
|
||||||
|
* XPath is a language for addressing parts of an XML document,
|
||||||
|
* designed to be used by both XSLT and XPointer
|
||||||
|
* http://www.w3.org/TR/xpath
|
||||||
|
*
|
||||||
|
* Implements
|
||||||
|
* W3C Recommendation 16 November 1999
|
||||||
|
* http://www.w3.org/TR/1999/REC-xpath-19991116
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_XPATH_H__
|
||||||
|
#define __XML_XPATH_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
|
||||||
|
#ifdef LIBXML_XPATH_ENABLED
|
||||||
|
|
||||||
|
#include <libxml/xmlerror.h>
|
||||||
|
#include <libxml/tree.h>
|
||||||
|
#include <libxml/hash.h>
|
||||||
|
#endif /* LIBXML_XPATH_ENABLED */
|
||||||
|
|
||||||
|
#if defined(LIBXML_XPATH_ENABLED) || defined(LIBXML_SCHEMAS_ENABLED)
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
#endif /* LIBXML_XPATH_ENABLED or LIBXML_SCHEMAS_ENABLED */
|
||||||
|
|
||||||
|
#ifdef LIBXML_XPATH_ENABLED
|
||||||
|
|
||||||
|
typedef struct _xmlXPathContext xmlXPathContext;
|
||||||
|
typedef xmlXPathContext *xmlXPathContextPtr;
|
||||||
|
typedef struct _xmlXPathParserContext xmlXPathParserContext;
|
||||||
|
typedef xmlXPathParserContext *xmlXPathParserContextPtr;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The set of XPath error codes.
|
||||||
|
*/
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
XPATH_EXPRESSION_OK = 0,
|
||||||
|
XPATH_NUMBER_ERROR,
|
||||||
|
XPATH_UNFINISHED_LITERAL_ERROR,
|
||||||
|
XPATH_START_LITERAL_ERROR,
|
||||||
|
XPATH_VARIABLE_REF_ERROR,
|
||||||
|
XPATH_UNDEF_VARIABLE_ERROR,
|
||||||
|
XPATH_INVALID_PREDICATE_ERROR,
|
||||||
|
XPATH_EXPR_ERROR,
|
||||||
|
XPATH_UNCLOSED_ERROR,
|
||||||
|
XPATH_UNKNOWN_FUNC_ERROR,
|
||||||
|
XPATH_INVALID_OPERAND,
|
||||||
|
XPATH_INVALID_TYPE,
|
||||||
|
XPATH_INVALID_ARITY,
|
||||||
|
XPATH_INVALID_CTXT_SIZE,
|
||||||
|
XPATH_INVALID_CTXT_POSITION,
|
||||||
|
XPATH_MEMORY_ERROR,
|
||||||
|
XPTR_SYNTAX_ERROR,
|
||||||
|
XPTR_RESOURCE_ERROR,
|
||||||
|
XPTR_SUB_RESOURCE_ERROR,
|
||||||
|
XPATH_UNDEF_PREFIX_ERROR,
|
||||||
|
XPATH_ENCODING_ERROR,
|
||||||
|
XPATH_INVALID_CHAR_ERROR,
|
||||||
|
XPATH_INVALID_CTXT
|
||||||
|
} xmlXPathError;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* A node-set (an unordered collection of nodes without duplicates).
|
||||||
|
*/
|
||||||
|
typedef struct _xmlNodeSet xmlNodeSet;
|
||||||
|
typedef xmlNodeSet *xmlNodeSetPtr;
|
||||||
|
struct _xmlNodeSet {
|
||||||
|
int nodeNr; /* number of nodes in the set */
|
||||||
|
int nodeMax; /* size of the array as allocated */
|
||||||
|
xmlNodePtr *nodeTab; /* array of nodes in no particular order */
|
||||||
|
/* @@ with_ns to check wether namespace nodes should be looked at @@ */
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* An expression is evaluated to yield an object, which
|
||||||
|
* has one of the following four basic types:
|
||||||
|
* - node-set
|
||||||
|
* - boolean
|
||||||
|
* - number
|
||||||
|
* - string
|
||||||
|
*
|
||||||
|
* @@ XPointer will add more types !
|
||||||
|
*/
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
XPATH_UNDEFINED = 0,
|
||||||
|
XPATH_NODESET = 1,
|
||||||
|
XPATH_BOOLEAN = 2,
|
||||||
|
XPATH_NUMBER = 3,
|
||||||
|
XPATH_STRING = 4,
|
||||||
|
XPATH_POINT = 5,
|
||||||
|
XPATH_RANGE = 6,
|
||||||
|
XPATH_LOCATIONSET = 7,
|
||||||
|
XPATH_USERS = 8,
|
||||||
|
XPATH_XSLT_TREE = 9 /* An XSLT value tree, non modifiable */
|
||||||
|
} xmlXPathObjectType;
|
||||||
|
|
||||||
|
typedef struct _xmlXPathObject xmlXPathObject;
|
||||||
|
typedef xmlXPathObject *xmlXPathObjectPtr;
|
||||||
|
struct _xmlXPathObject {
|
||||||
|
xmlXPathObjectType type;
|
||||||
|
xmlNodeSetPtr nodesetval;
|
||||||
|
int boolval;
|
||||||
|
double floatval;
|
||||||
|
xmlChar *stringval;
|
||||||
|
void *user;
|
||||||
|
int index;
|
||||||
|
void *user2;
|
||||||
|
int index2;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlXPathConvertFunc:
|
||||||
|
* @obj: an XPath object
|
||||||
|
* @type: the number of the target type
|
||||||
|
*
|
||||||
|
* A conversion function is associated to a type and used to cast
|
||||||
|
* the new type to primitive values.
|
||||||
|
*
|
||||||
|
* Returns -1 in case of error, 0 otherwise
|
||||||
|
*/
|
||||||
|
typedef int (*xmlXPathConvertFunc) (xmlXPathObjectPtr obj, int type);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Extra type: a name and a conversion function.
|
||||||
|
*/
|
||||||
|
|
||||||
|
typedef struct _xmlXPathType xmlXPathType;
|
||||||
|
typedef xmlXPathType *xmlXPathTypePtr;
|
||||||
|
struct _xmlXPathType {
|
||||||
|
const xmlChar *name; /* the type name */
|
||||||
|
xmlXPathConvertFunc func; /* the conversion function */
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Extra variable: a name and a value.
|
||||||
|
*/
|
||||||
|
|
||||||
|
typedef struct _xmlXPathVariable xmlXPathVariable;
|
||||||
|
typedef xmlXPathVariable *xmlXPathVariablePtr;
|
||||||
|
struct _xmlXPathVariable {
|
||||||
|
const xmlChar *name; /* the variable name */
|
||||||
|
xmlXPathObjectPtr value; /* the value */
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlXPathEvalFunc:
|
||||||
|
* @ctxt: an XPath parser context
|
||||||
|
* @nargs: the number of arguments passed to the function
|
||||||
|
*
|
||||||
|
* An XPath evaluation function, the parameters are on the XPath context stack.
|
||||||
|
*/
|
||||||
|
|
||||||
|
typedef void (*xmlXPathEvalFunc)(xmlXPathParserContextPtr ctxt,
|
||||||
|
int nargs);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Extra function: a name and a evaluation function.
|
||||||
|
*/
|
||||||
|
|
||||||
|
typedef struct _xmlXPathFunct xmlXPathFunct;
|
||||||
|
typedef xmlXPathFunct *xmlXPathFuncPtr;
|
||||||
|
struct _xmlXPathFunct {
|
||||||
|
const xmlChar *name; /* the function name */
|
||||||
|
xmlXPathEvalFunc func; /* the evaluation function */
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlXPathAxisFunc:
|
||||||
|
* @ctxt: the XPath interpreter context
|
||||||
|
* @cur: the previous node being explored on that axis
|
||||||
|
*
|
||||||
|
* An axis traversal function. To traverse an axis, the engine calls
|
||||||
|
* the first time with cur == NULL and repeat until the function returns
|
||||||
|
* NULL indicating the end of the axis traversal.
|
||||||
|
*
|
||||||
|
* Returns the next node in that axis or NULL if at the end of the axis.
|
||||||
|
*/
|
||||||
|
|
||||||
|
typedef xmlXPathObjectPtr (*xmlXPathAxisFunc) (xmlXPathParserContextPtr ctxt,
|
||||||
|
xmlXPathObjectPtr cur);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Extra axis: a name and an axis function.
|
||||||
|
*/
|
||||||
|
|
||||||
|
typedef struct _xmlXPathAxis xmlXPathAxis;
|
||||||
|
typedef xmlXPathAxis *xmlXPathAxisPtr;
|
||||||
|
struct _xmlXPathAxis {
|
||||||
|
const xmlChar *name; /* the axis name */
|
||||||
|
xmlXPathAxisFunc func; /* the search function */
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlXPathFunction:
|
||||||
|
* @ctxt: the XPath interprestation context
|
||||||
|
* @nargs: the number of arguments
|
||||||
|
*
|
||||||
|
* An XPath function.
|
||||||
|
* The arguments (if any) are popped out from the context stack
|
||||||
|
* and the result is pushed on the stack.
|
||||||
|
*/
|
||||||
|
|
||||||
|
typedef void (*xmlXPathFunction) (xmlXPathParserContextPtr ctxt, int nargs);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Function and Variable Lookup.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlXPathVariableLookupFunc:
|
||||||
|
* @ctxt: an XPath context
|
||||||
|
* @name: name of the variable
|
||||||
|
* @ns_uri: the namespace name hosting this variable
|
||||||
|
*
|
||||||
|
* Prototype for callbacks used to plug variable lookup in the XPath
|
||||||
|
* engine.
|
||||||
|
*
|
||||||
|
* Returns the XPath object value or NULL if not found.
|
||||||
|
*/
|
||||||
|
typedef xmlXPathObjectPtr (*xmlXPathVariableLookupFunc) (void *ctxt,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *ns_uri);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlXPathFuncLookupFunc:
|
||||||
|
* @ctxt: an XPath context
|
||||||
|
* @name: name of the function
|
||||||
|
* @ns_uri: the namespace name hosting this function
|
||||||
|
*
|
||||||
|
* Prototype for callbacks used to plug function lookup in the XPath
|
||||||
|
* engine.
|
||||||
|
*
|
||||||
|
* Returns the XPath function or NULL if not found.
|
||||||
|
*/
|
||||||
|
typedef xmlXPathFunction (*xmlXPathFuncLookupFunc) (void *ctxt,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *ns_uri);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlXPathFlags:
|
||||||
|
* Flags for XPath engine compilation and runtime
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* XML_XPATH_CHECKNS:
|
||||||
|
*
|
||||||
|
* check namespaces at compilation
|
||||||
|
*/
|
||||||
|
#define XML_XPATH_CHECKNS (1<<0)
|
||||||
|
/**
|
||||||
|
* XML_XPATH_NOVAR:
|
||||||
|
*
|
||||||
|
* forbid variables in expression
|
||||||
|
*/
|
||||||
|
#define XML_XPATH_NOVAR (1<<1)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlXPathContext:
|
||||||
|
*
|
||||||
|
* Expression evaluation occurs with respect to a context.
|
||||||
|
* he context consists of:
|
||||||
|
* - a node (the context node)
|
||||||
|
* - a node list (the context node list)
|
||||||
|
* - a set of variable bindings
|
||||||
|
* - a function library
|
||||||
|
* - the set of namespace declarations in scope for the expression
|
||||||
|
* Following the switch to hash tables, this need to be trimmed up at
|
||||||
|
* the next binary incompatible release.
|
||||||
|
* The node may be modified when the context is passed to libxml2
|
||||||
|
* for an XPath evaluation so you may need to initialize it again
|
||||||
|
* before the next call.
|
||||||
|
*/
|
||||||
|
|
||||||
|
struct _xmlXPathContext {
|
||||||
|
xmlDocPtr doc; /* The current document */
|
||||||
|
xmlNodePtr node; /* The current node */
|
||||||
|
|
||||||
|
int nb_variables_unused; /* unused (hash table) */
|
||||||
|
int max_variables_unused; /* unused (hash table) */
|
||||||
|
xmlHashTablePtr varHash; /* Hash table of defined variables */
|
||||||
|
|
||||||
|
int nb_types; /* number of defined types */
|
||||||
|
int max_types; /* max number of types */
|
||||||
|
xmlXPathTypePtr types; /* Array of defined types */
|
||||||
|
|
||||||
|
int nb_funcs_unused; /* unused (hash table) */
|
||||||
|
int max_funcs_unused; /* unused (hash table) */
|
||||||
|
xmlHashTablePtr funcHash; /* Hash table of defined funcs */
|
||||||
|
|
||||||
|
int nb_axis; /* number of defined axis */
|
||||||
|
int max_axis; /* max number of axis */
|
||||||
|
xmlXPathAxisPtr axis; /* Array of defined axis */
|
||||||
|
|
||||||
|
/* the namespace nodes of the context node */
|
||||||
|
xmlNsPtr *namespaces; /* Array of namespaces */
|
||||||
|
int nsNr; /* number of namespace in scope */
|
||||||
|
void *user; /* function to free */
|
||||||
|
|
||||||
|
/* extra variables */
|
||||||
|
int contextSize; /* the context size */
|
||||||
|
int proximityPosition; /* the proximity position */
|
||||||
|
|
||||||
|
/* extra stuff for XPointer */
|
||||||
|
int xptr; /* is this an XPointer context? */
|
||||||
|
xmlNodePtr here; /* for here() */
|
||||||
|
xmlNodePtr origin; /* for origin() */
|
||||||
|
|
||||||
|
/* the set of namespace declarations in scope for the expression */
|
||||||
|
xmlHashTablePtr nsHash; /* The namespaces hash table */
|
||||||
|
xmlXPathVariableLookupFunc varLookupFunc;/* variable lookup func */
|
||||||
|
void *varLookupData; /* variable lookup data */
|
||||||
|
|
||||||
|
/* Possibility to link in an extra item */
|
||||||
|
void *extra; /* needed for XSLT */
|
||||||
|
|
||||||
|
/* The function name and URI when calling a function */
|
||||||
|
const xmlChar *function;
|
||||||
|
const xmlChar *functionURI;
|
||||||
|
|
||||||
|
/* function lookup function and data */
|
||||||
|
xmlXPathFuncLookupFunc funcLookupFunc;/* function lookup func */
|
||||||
|
void *funcLookupData; /* function lookup data */
|
||||||
|
|
||||||
|
/* temporary namespace lists kept for walking the namespace axis */
|
||||||
|
xmlNsPtr *tmpNsList; /* Array of namespaces */
|
||||||
|
int tmpNsNr; /* number of namespaces in scope */
|
||||||
|
|
||||||
|
/* error reporting mechanism */
|
||||||
|
void *userData; /* user specific data block */
|
||||||
|
xmlStructuredErrorFunc error; /* the callback in case of errors */
|
||||||
|
xmlError lastError; /* the last error */
|
||||||
|
xmlNodePtr debugNode; /* the source node XSLT */
|
||||||
|
|
||||||
|
/* dictionary */
|
||||||
|
xmlDictPtr dict; /* dictionary if any */
|
||||||
|
|
||||||
|
int flags; /* flags to control compilation */
|
||||||
|
|
||||||
|
/* Cache for reusal of XPath objects */
|
||||||
|
void *cache;
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The structure of a compiled expression form is not public.
|
||||||
|
*/
|
||||||
|
|
||||||
|
typedef struct _xmlXPathCompExpr xmlXPathCompExpr;
|
||||||
|
typedef xmlXPathCompExpr *xmlXPathCompExprPtr;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlXPathParserContext:
|
||||||
|
*
|
||||||
|
* An XPath parser context. It contains pure parsing informations,
|
||||||
|
* an xmlXPathContext, and the stack of objects.
|
||||||
|
*/
|
||||||
|
struct _xmlXPathParserContext {
|
||||||
|
const xmlChar *cur; /* the current char being parsed */
|
||||||
|
const xmlChar *base; /* the full expression */
|
||||||
|
|
||||||
|
int error; /* error code */
|
||||||
|
|
||||||
|
xmlXPathContextPtr context; /* the evaluation context */
|
||||||
|
xmlXPathObjectPtr value; /* the current value */
|
||||||
|
int valueNr; /* number of values stacked */
|
||||||
|
int valueMax; /* max number of values stacked */
|
||||||
|
xmlXPathObjectPtr *valueTab; /* stack of values */
|
||||||
|
|
||||||
|
xmlXPathCompExprPtr comp; /* the precompiled expression */
|
||||||
|
int xptr; /* it this an XPointer expression */
|
||||||
|
xmlNodePtr ancestor; /* used for walking preceding axis */
|
||||||
|
};
|
||||||
|
|
||||||
|
/************************************************************************
|
||||||
|
* *
|
||||||
|
* Public API *
|
||||||
|
* *
|
||||||
|
************************************************************************/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Objects and Nodesets handling
|
||||||
|
*/
|
||||||
|
|
||||||
|
XMLPUBVAR double xmlXPathNAN;
|
||||||
|
XMLPUBVAR double xmlXPathPINF;
|
||||||
|
XMLPUBVAR double xmlXPathNINF;
|
||||||
|
|
||||||
|
/* These macros may later turn into functions */
|
||||||
|
/**
|
||||||
|
* xmlXPathNodeSetGetLength:
|
||||||
|
* @ns: a node-set
|
||||||
|
*
|
||||||
|
* Implement a functionality similar to the DOM NodeList.length.
|
||||||
|
*
|
||||||
|
* Returns the number of nodes in the node-set.
|
||||||
|
*/
|
||||||
|
#define xmlXPathNodeSetGetLength(ns) ((ns) ? (ns)->nodeNr : 0)
|
||||||
|
/**
|
||||||
|
* xmlXPathNodeSetItem:
|
||||||
|
* @ns: a node-set
|
||||||
|
* @index: index of a node in the set
|
||||||
|
*
|
||||||
|
* Implements a functionality similar to the DOM NodeList.item().
|
||||||
|
*
|
||||||
|
* Returns the xmlNodePtr at the given @index in @ns or NULL if
|
||||||
|
* @index is out of range (0 to length-1)
|
||||||
|
*/
|
||||||
|
#define xmlXPathNodeSetItem(ns, index) \
|
||||||
|
((((ns) != NULL) && \
|
||||||
|
((index) >= 0) && ((index) < (ns)->nodeNr)) ? \
|
||||||
|
(ns)->nodeTab[(index)] \
|
||||||
|
: NULL)
|
||||||
|
/**
|
||||||
|
* xmlXPathNodeSetIsEmpty:
|
||||||
|
* @ns: a node-set
|
||||||
|
*
|
||||||
|
* Checks whether @ns is empty or not.
|
||||||
|
*
|
||||||
|
* Returns %TRUE if @ns is an empty node-set.
|
||||||
|
*/
|
||||||
|
#define xmlXPathNodeSetIsEmpty(ns) \
|
||||||
|
(((ns) == NULL) || ((ns)->nodeNr == 0) || ((ns)->nodeTab == NULL))
|
||||||
|
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPathFreeObject (xmlXPathObjectPtr obj);
|
||||||
|
XMLPUBFUN xmlNodeSetPtr XMLCALL
|
||||||
|
xmlXPathNodeSetCreate (xmlNodePtr val);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPathFreeNodeSetList (xmlXPathObjectPtr obj);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPathFreeNodeSet (xmlNodeSetPtr obj);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPathObjectCopy (xmlXPathObjectPtr val);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlXPathCmpNodes (xmlNodePtr node1,
|
||||||
|
xmlNodePtr node2);
|
||||||
|
/**
|
||||||
|
* Conversion functions to basic types.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlXPathCastNumberToBoolean (double val);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlXPathCastStringToBoolean (const xmlChar * val);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlXPathCastNodeSetToBoolean(xmlNodeSetPtr ns);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlXPathCastToBoolean (xmlXPathObjectPtr val);
|
||||||
|
|
||||||
|
XMLPUBFUN double XMLCALL
|
||||||
|
xmlXPathCastBooleanToNumber (int val);
|
||||||
|
XMLPUBFUN double XMLCALL
|
||||||
|
xmlXPathCastStringToNumber (const xmlChar * val);
|
||||||
|
XMLPUBFUN double XMLCALL
|
||||||
|
xmlXPathCastNodeToNumber (xmlNodePtr node);
|
||||||
|
XMLPUBFUN double XMLCALL
|
||||||
|
xmlXPathCastNodeSetToNumber (xmlNodeSetPtr ns);
|
||||||
|
XMLPUBFUN double XMLCALL
|
||||||
|
xmlXPathCastToNumber (xmlXPathObjectPtr val);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlXPathCastBooleanToString (int val);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlXPathCastNumberToString (double val);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlXPathCastNodeToString (xmlNodePtr node);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlXPathCastNodeSetToString (xmlNodeSetPtr ns);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlXPathCastToString (xmlXPathObjectPtr val);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPathConvertBoolean (xmlXPathObjectPtr val);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPathConvertNumber (xmlXPathObjectPtr val);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPathConvertString (xmlXPathObjectPtr val);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Context handling.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlXPathContextPtr XMLCALL
|
||||||
|
xmlXPathNewContext (xmlDocPtr doc);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPathFreeContext (xmlXPathContextPtr ctxt);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlXPathContextSetCache(xmlXPathContextPtr ctxt,
|
||||||
|
int active,
|
||||||
|
int value,
|
||||||
|
int options);
|
||||||
|
/**
|
||||||
|
* Evaluation functions.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN long XMLCALL
|
||||||
|
xmlXPathOrderDocElems (xmlDocPtr doc);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPathEval (const xmlChar *str,
|
||||||
|
xmlXPathContextPtr ctx);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPathEvalExpression (const xmlChar *str,
|
||||||
|
xmlXPathContextPtr ctxt);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlXPathEvalPredicate (xmlXPathContextPtr ctxt,
|
||||||
|
xmlXPathObjectPtr res);
|
||||||
|
/**
|
||||||
|
* Separate compilation/evaluation entry points.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlXPathCompExprPtr XMLCALL
|
||||||
|
xmlXPathCompile (const xmlChar *str);
|
||||||
|
XMLPUBFUN xmlXPathCompExprPtr XMLCALL
|
||||||
|
xmlXPathCtxtCompile (xmlXPathContextPtr ctxt,
|
||||||
|
const xmlChar *str);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPathCompiledEval (xmlXPathCompExprPtr comp,
|
||||||
|
xmlXPathContextPtr ctx);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlXPathCompiledEvalToBoolean(xmlXPathCompExprPtr comp,
|
||||||
|
xmlXPathContextPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPathFreeCompExpr (xmlXPathCompExprPtr comp);
|
||||||
|
#endif /* LIBXML_XPATH_ENABLED */
|
||||||
|
#if defined(LIBXML_XPATH_ENABLED) || defined(LIBXML_SCHEMAS_ENABLED)
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPathInit (void);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlXPathIsNaN (double val);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlXPathIsInf (double val);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* LIBXML_XPATH_ENABLED or LIBXML_SCHEMAS_ENABLED*/
|
||||||
|
#endif /* ! __XML_XPATH_H__ */
|
|
@ -0,0 +1,630 @@
|
||||||
|
/*
|
||||||
|
* Summary: internal interfaces for XML Path Language implementation
|
||||||
|
* Description: internal interfaces for XML Path Language implementation
|
||||||
|
* used to build new modules on top of XPath like XPointer and
|
||||||
|
* XSLT
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_XPATH_INTERNALS_H__
|
||||||
|
#define __XML_XPATH_INTERNALS_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
#include <libxml/xpath.h>
|
||||||
|
|
||||||
|
#ifdef LIBXML_XPATH_ENABLED
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/************************************************************************
|
||||||
|
* *
|
||||||
|
* Helpers *
|
||||||
|
* *
|
||||||
|
************************************************************************/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Many of these macros may later turn into functions. They
|
||||||
|
* shouldn't be used in #ifdef's preprocessor instructions.
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* xmlXPathSetError:
|
||||||
|
* @ctxt: an XPath parser context
|
||||||
|
* @err: an xmlXPathError code
|
||||||
|
*
|
||||||
|
* Raises an error.
|
||||||
|
*/
|
||||||
|
#define xmlXPathSetError(ctxt, err) \
|
||||||
|
{ xmlXPatherror((ctxt), __FILE__, __LINE__, (err)); \
|
||||||
|
if ((ctxt) != NULL) (ctxt)->error = (err); }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlXPathSetArityError:
|
||||||
|
* @ctxt: an XPath parser context
|
||||||
|
*
|
||||||
|
* Raises an XPATH_INVALID_ARITY error.
|
||||||
|
*/
|
||||||
|
#define xmlXPathSetArityError(ctxt) \
|
||||||
|
xmlXPathSetError((ctxt), XPATH_INVALID_ARITY)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlXPathSetTypeError:
|
||||||
|
* @ctxt: an XPath parser context
|
||||||
|
*
|
||||||
|
* Raises an XPATH_INVALID_TYPE error.
|
||||||
|
*/
|
||||||
|
#define xmlXPathSetTypeError(ctxt) \
|
||||||
|
xmlXPathSetError((ctxt), XPATH_INVALID_TYPE)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlXPathGetError:
|
||||||
|
* @ctxt: an XPath parser context
|
||||||
|
*
|
||||||
|
* Get the error code of an XPath context.
|
||||||
|
*
|
||||||
|
* Returns the context error.
|
||||||
|
*/
|
||||||
|
#define xmlXPathGetError(ctxt) ((ctxt)->error)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlXPathCheckError:
|
||||||
|
* @ctxt: an XPath parser context
|
||||||
|
*
|
||||||
|
* Check if an XPath error was raised.
|
||||||
|
*
|
||||||
|
* Returns true if an error has been raised, false otherwise.
|
||||||
|
*/
|
||||||
|
#define xmlXPathCheckError(ctxt) ((ctxt)->error != XPATH_EXPRESSION_OK)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlXPathGetDocument:
|
||||||
|
* @ctxt: an XPath parser context
|
||||||
|
*
|
||||||
|
* Get the document of an XPath context.
|
||||||
|
*
|
||||||
|
* Returns the context document.
|
||||||
|
*/
|
||||||
|
#define xmlXPathGetDocument(ctxt) ((ctxt)->context->doc)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlXPathGetContextNode:
|
||||||
|
* @ctxt: an XPath parser context
|
||||||
|
*
|
||||||
|
* Get the context node of an XPath context.
|
||||||
|
*
|
||||||
|
* Returns the context node.
|
||||||
|
*/
|
||||||
|
#define xmlXPathGetContextNode(ctxt) ((ctxt)->context->node)
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlXPathPopBoolean (xmlXPathParserContextPtr ctxt);
|
||||||
|
XMLPUBFUN double XMLCALL
|
||||||
|
xmlXPathPopNumber (xmlXPathParserContextPtr ctxt);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlXPathPopString (xmlXPathParserContextPtr ctxt);
|
||||||
|
XMLPUBFUN xmlNodeSetPtr XMLCALL
|
||||||
|
xmlXPathPopNodeSet (xmlXPathParserContextPtr ctxt);
|
||||||
|
XMLPUBFUN void * XMLCALL
|
||||||
|
xmlXPathPopExternal (xmlXPathParserContextPtr ctxt);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlXPathReturnBoolean:
|
||||||
|
* @ctxt: an XPath parser context
|
||||||
|
* @val: a boolean
|
||||||
|
*
|
||||||
|
* Pushes the boolean @val on the context stack.
|
||||||
|
*/
|
||||||
|
#define xmlXPathReturnBoolean(ctxt, val) \
|
||||||
|
valuePush((ctxt), xmlXPathNewBoolean(val))
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlXPathReturnTrue:
|
||||||
|
* @ctxt: an XPath parser context
|
||||||
|
*
|
||||||
|
* Pushes true on the context stack.
|
||||||
|
*/
|
||||||
|
#define xmlXPathReturnTrue(ctxt) xmlXPathReturnBoolean((ctxt), 1)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlXPathReturnFalse:
|
||||||
|
* @ctxt: an XPath parser context
|
||||||
|
*
|
||||||
|
* Pushes false on the context stack.
|
||||||
|
*/
|
||||||
|
#define xmlXPathReturnFalse(ctxt) xmlXPathReturnBoolean((ctxt), 0)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlXPathReturnNumber:
|
||||||
|
* @ctxt: an XPath parser context
|
||||||
|
* @val: a double
|
||||||
|
*
|
||||||
|
* Pushes the double @val on the context stack.
|
||||||
|
*/
|
||||||
|
#define xmlXPathReturnNumber(ctxt, val) \
|
||||||
|
valuePush((ctxt), xmlXPathNewFloat(val))
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlXPathReturnString:
|
||||||
|
* @ctxt: an XPath parser context
|
||||||
|
* @str: a string
|
||||||
|
*
|
||||||
|
* Pushes the string @str on the context stack.
|
||||||
|
*/
|
||||||
|
#define xmlXPathReturnString(ctxt, str) \
|
||||||
|
valuePush((ctxt), xmlXPathWrapString(str))
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlXPathReturnEmptyString:
|
||||||
|
* @ctxt: an XPath parser context
|
||||||
|
*
|
||||||
|
* Pushes an empty string on the stack.
|
||||||
|
*/
|
||||||
|
#define xmlXPathReturnEmptyString(ctxt) \
|
||||||
|
valuePush((ctxt), xmlXPathNewCString(""))
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlXPathReturnNodeSet:
|
||||||
|
* @ctxt: an XPath parser context
|
||||||
|
* @ns: a node-set
|
||||||
|
*
|
||||||
|
* Pushes the node-set @ns on the context stack.
|
||||||
|
*/
|
||||||
|
#define xmlXPathReturnNodeSet(ctxt, ns) \
|
||||||
|
valuePush((ctxt), xmlXPathWrapNodeSet(ns))
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlXPathReturnEmptyNodeSet:
|
||||||
|
* @ctxt: an XPath parser context
|
||||||
|
*
|
||||||
|
* Pushes an empty node-set on the context stack.
|
||||||
|
*/
|
||||||
|
#define xmlXPathReturnEmptyNodeSet(ctxt) \
|
||||||
|
valuePush((ctxt), xmlXPathNewNodeSet(NULL))
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlXPathReturnExternal:
|
||||||
|
* @ctxt: an XPath parser context
|
||||||
|
* @val: user data
|
||||||
|
*
|
||||||
|
* Pushes user data on the context stack.
|
||||||
|
*/
|
||||||
|
#define xmlXPathReturnExternal(ctxt, val) \
|
||||||
|
valuePush((ctxt), xmlXPathWrapExternal(val))
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlXPathStackIsNodeSet:
|
||||||
|
* @ctxt: an XPath parser context
|
||||||
|
*
|
||||||
|
* Check if the current value on the XPath stack is a node set or
|
||||||
|
* an XSLT value tree.
|
||||||
|
*
|
||||||
|
* Returns true if the current object on the stack is a node-set.
|
||||||
|
*/
|
||||||
|
#define xmlXPathStackIsNodeSet(ctxt) \
|
||||||
|
(((ctxt)->value != NULL) \
|
||||||
|
&& (((ctxt)->value->type == XPATH_NODESET) \
|
||||||
|
|| ((ctxt)->value->type == XPATH_XSLT_TREE)))
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlXPathStackIsExternal:
|
||||||
|
* @ctxt: an XPath parser context
|
||||||
|
*
|
||||||
|
* Checks if the current value on the XPath stack is an external
|
||||||
|
* object.
|
||||||
|
*
|
||||||
|
* Returns true if the current object on the stack is an external
|
||||||
|
* object.
|
||||||
|
*/
|
||||||
|
#define xmlXPathStackIsExternal(ctxt) \
|
||||||
|
((ctxt->value != NULL) && (ctxt->value->type == XPATH_USERS))
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xmlXPathEmptyNodeSet:
|
||||||
|
* @ns: a node-set
|
||||||
|
*
|
||||||
|
* Empties a node-set.
|
||||||
|
*/
|
||||||
|
#define xmlXPathEmptyNodeSet(ns) \
|
||||||
|
{ while ((ns)->nodeNr > 0) (ns)->nodeTab[(ns)->nodeNr--] = NULL; }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* CHECK_ERROR:
|
||||||
|
*
|
||||||
|
* Macro to return from the function if an XPath error was detected.
|
||||||
|
*/
|
||||||
|
#define CHECK_ERROR \
|
||||||
|
if (ctxt->error != XPATH_EXPRESSION_OK) return
|
||||||
|
|
||||||
|
/**
|
||||||
|
* CHECK_ERROR0:
|
||||||
|
*
|
||||||
|
* Macro to return 0 from the function if an XPath error was detected.
|
||||||
|
*/
|
||||||
|
#define CHECK_ERROR0 \
|
||||||
|
if (ctxt->error != XPATH_EXPRESSION_OK) return(0)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* XP_ERROR:
|
||||||
|
* @X: the error code
|
||||||
|
*
|
||||||
|
* Macro to raise an XPath error and return.
|
||||||
|
*/
|
||||||
|
#define XP_ERROR(X) \
|
||||||
|
{ xmlXPathErr(ctxt, X); return; }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* XP_ERROR0:
|
||||||
|
* @X: the error code
|
||||||
|
*
|
||||||
|
* Macro to raise an XPath error and return 0.
|
||||||
|
*/
|
||||||
|
#define XP_ERROR0(X) \
|
||||||
|
{ xmlXPathErr(ctxt, X); return(0); }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* CHECK_TYPE:
|
||||||
|
* @typeval: the XPath type
|
||||||
|
*
|
||||||
|
* Macro to check that the value on top of the XPath stack is of a given
|
||||||
|
* type.
|
||||||
|
*/
|
||||||
|
#define CHECK_TYPE(typeval) \
|
||||||
|
if ((ctxt->value == NULL) || (ctxt->value->type != typeval)) \
|
||||||
|
XP_ERROR(XPATH_INVALID_TYPE)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* CHECK_TYPE0:
|
||||||
|
* @typeval: the XPath type
|
||||||
|
*
|
||||||
|
* Macro to check that the value on top of the XPath stack is of a given
|
||||||
|
* type. Return(0) in case of failure
|
||||||
|
*/
|
||||||
|
#define CHECK_TYPE0(typeval) \
|
||||||
|
if ((ctxt->value == NULL) || (ctxt->value->type != typeval)) \
|
||||||
|
XP_ERROR0(XPATH_INVALID_TYPE)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* CHECK_ARITY:
|
||||||
|
* @x: the number of expected args
|
||||||
|
*
|
||||||
|
* Macro to check that the number of args passed to an XPath function matches.
|
||||||
|
*/
|
||||||
|
#define CHECK_ARITY(x) \
|
||||||
|
if (ctxt == NULL) return; \
|
||||||
|
if (nargs != (x)) \
|
||||||
|
XP_ERROR(XPATH_INVALID_ARITY);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* CAST_TO_STRING:
|
||||||
|
*
|
||||||
|
* Macro to try to cast the value on the top of the XPath stack to a string.
|
||||||
|
*/
|
||||||
|
#define CAST_TO_STRING \
|
||||||
|
if ((ctxt->value != NULL) && (ctxt->value->type != XPATH_STRING)) \
|
||||||
|
xmlXPathStringFunction(ctxt, 1);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* CAST_TO_NUMBER:
|
||||||
|
*
|
||||||
|
* Macro to try to cast the value on the top of the XPath stack to a number.
|
||||||
|
*/
|
||||||
|
#define CAST_TO_NUMBER \
|
||||||
|
if ((ctxt->value != NULL) && (ctxt->value->type != XPATH_NUMBER)) \
|
||||||
|
xmlXPathNumberFunction(ctxt, 1);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* CAST_TO_BOOLEAN:
|
||||||
|
*
|
||||||
|
* Macro to try to cast the value on the top of the XPath stack to a boolean.
|
||||||
|
*/
|
||||||
|
#define CAST_TO_BOOLEAN \
|
||||||
|
if ((ctxt->value != NULL) && (ctxt->value->type != XPATH_BOOLEAN)) \
|
||||||
|
xmlXPathBooleanFunction(ctxt, 1);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Variable Lookup forwarding.
|
||||||
|
*/
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPathRegisterVariableLookup (xmlXPathContextPtr ctxt,
|
||||||
|
xmlXPathVariableLookupFunc f,
|
||||||
|
void *data);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Function Lookup forwarding.
|
||||||
|
*/
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPathRegisterFuncLookup (xmlXPathContextPtr ctxt,
|
||||||
|
xmlXPathFuncLookupFunc f,
|
||||||
|
void *funcCtxt);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Error reporting.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPatherror (xmlXPathParserContextPtr ctxt,
|
||||||
|
const char *file,
|
||||||
|
int line,
|
||||||
|
int no);
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPathErr (xmlXPathParserContextPtr ctxt,
|
||||||
|
int error);
|
||||||
|
|
||||||
|
#ifdef LIBXML_DEBUG_ENABLED
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPathDebugDumpObject (FILE *output,
|
||||||
|
xmlXPathObjectPtr cur,
|
||||||
|
int depth);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPathDebugDumpCompExpr(FILE *output,
|
||||||
|
xmlXPathCompExprPtr comp,
|
||||||
|
int depth);
|
||||||
|
#endif
|
||||||
|
/**
|
||||||
|
* NodeSet handling.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlXPathNodeSetContains (xmlNodeSetPtr cur,
|
||||||
|
xmlNodePtr val);
|
||||||
|
XMLPUBFUN xmlNodeSetPtr XMLCALL
|
||||||
|
xmlXPathDifference (xmlNodeSetPtr nodes1,
|
||||||
|
xmlNodeSetPtr nodes2);
|
||||||
|
XMLPUBFUN xmlNodeSetPtr XMLCALL
|
||||||
|
xmlXPathIntersection (xmlNodeSetPtr nodes1,
|
||||||
|
xmlNodeSetPtr nodes2);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlNodeSetPtr XMLCALL
|
||||||
|
xmlXPathDistinctSorted (xmlNodeSetPtr nodes);
|
||||||
|
XMLPUBFUN xmlNodeSetPtr XMLCALL
|
||||||
|
xmlXPathDistinct (xmlNodeSetPtr nodes);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlXPathHasSameNodes (xmlNodeSetPtr nodes1,
|
||||||
|
xmlNodeSetPtr nodes2);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlNodeSetPtr XMLCALL
|
||||||
|
xmlXPathNodeLeadingSorted (xmlNodeSetPtr nodes,
|
||||||
|
xmlNodePtr node);
|
||||||
|
XMLPUBFUN xmlNodeSetPtr XMLCALL
|
||||||
|
xmlXPathLeadingSorted (xmlNodeSetPtr nodes1,
|
||||||
|
xmlNodeSetPtr nodes2);
|
||||||
|
XMLPUBFUN xmlNodeSetPtr XMLCALL
|
||||||
|
xmlXPathNodeLeading (xmlNodeSetPtr nodes,
|
||||||
|
xmlNodePtr node);
|
||||||
|
XMLPUBFUN xmlNodeSetPtr XMLCALL
|
||||||
|
xmlXPathLeading (xmlNodeSetPtr nodes1,
|
||||||
|
xmlNodeSetPtr nodes2);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlNodeSetPtr XMLCALL
|
||||||
|
xmlXPathNodeTrailingSorted (xmlNodeSetPtr nodes,
|
||||||
|
xmlNodePtr node);
|
||||||
|
XMLPUBFUN xmlNodeSetPtr XMLCALL
|
||||||
|
xmlXPathTrailingSorted (xmlNodeSetPtr nodes1,
|
||||||
|
xmlNodeSetPtr nodes2);
|
||||||
|
XMLPUBFUN xmlNodeSetPtr XMLCALL
|
||||||
|
xmlXPathNodeTrailing (xmlNodeSetPtr nodes,
|
||||||
|
xmlNodePtr node);
|
||||||
|
XMLPUBFUN xmlNodeSetPtr XMLCALL
|
||||||
|
xmlXPathTrailing (xmlNodeSetPtr nodes1,
|
||||||
|
xmlNodeSetPtr nodes2);
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Extending a context.
|
||||||
|
*/
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlXPathRegisterNs (xmlXPathContextPtr ctxt,
|
||||||
|
const xmlChar *prefix,
|
||||||
|
const xmlChar *ns_uri);
|
||||||
|
XMLPUBFUN const xmlChar * XMLCALL
|
||||||
|
xmlXPathNsLookup (xmlXPathContextPtr ctxt,
|
||||||
|
const xmlChar *prefix);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPathRegisteredNsCleanup (xmlXPathContextPtr ctxt);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlXPathRegisterFunc (xmlXPathContextPtr ctxt,
|
||||||
|
const xmlChar *name,
|
||||||
|
xmlXPathFunction f);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlXPathRegisterFuncNS (xmlXPathContextPtr ctxt,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *ns_uri,
|
||||||
|
xmlXPathFunction f);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlXPathRegisterVariable (xmlXPathContextPtr ctxt,
|
||||||
|
const xmlChar *name,
|
||||||
|
xmlXPathObjectPtr value);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlXPathRegisterVariableNS (xmlXPathContextPtr ctxt,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *ns_uri,
|
||||||
|
xmlXPathObjectPtr value);
|
||||||
|
XMLPUBFUN xmlXPathFunction XMLCALL
|
||||||
|
xmlXPathFunctionLookup (xmlXPathContextPtr ctxt,
|
||||||
|
const xmlChar *name);
|
||||||
|
XMLPUBFUN xmlXPathFunction XMLCALL
|
||||||
|
xmlXPathFunctionLookupNS (xmlXPathContextPtr ctxt,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *ns_uri);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPathRegisteredFuncsCleanup (xmlXPathContextPtr ctxt);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPathVariableLookup (xmlXPathContextPtr ctxt,
|
||||||
|
const xmlChar *name);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPathVariableLookupNS (xmlXPathContextPtr ctxt,
|
||||||
|
const xmlChar *name,
|
||||||
|
const xmlChar *ns_uri);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPathRegisteredVariablesCleanup(xmlXPathContextPtr ctxt);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Utilities to extend XPath.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlXPathParserContextPtr XMLCALL
|
||||||
|
xmlXPathNewParserContext (const xmlChar *str,
|
||||||
|
xmlXPathContextPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPathFreeParserContext (xmlXPathParserContextPtr ctxt);
|
||||||
|
|
||||||
|
/* TODO: remap to xmlXPathValuePop and Push. */
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
valuePop (xmlXPathParserContextPtr ctxt);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
valuePush (xmlXPathParserContextPtr ctxt,
|
||||||
|
xmlXPathObjectPtr value);
|
||||||
|
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPathNewString (const xmlChar *val);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPathNewCString (const char *val);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPathWrapString (xmlChar *val);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPathWrapCString (char * val);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPathNewFloat (double val);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPathNewBoolean (int val);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPathNewNodeSet (xmlNodePtr val);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPathNewValueTree (xmlNodePtr val);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPathNodeSetAdd (xmlNodeSetPtr cur,
|
||||||
|
xmlNodePtr val);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPathNodeSetAddUnique (xmlNodeSetPtr cur,
|
||||||
|
xmlNodePtr val);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPathNodeSetAddNs (xmlNodeSetPtr cur,
|
||||||
|
xmlNodePtr node,
|
||||||
|
xmlNsPtr ns);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPathNodeSetSort (xmlNodeSetPtr set);
|
||||||
|
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPathRoot (xmlXPathParserContextPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPathEvalExpr (xmlXPathParserContextPtr ctxt);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlXPathParseName (xmlXPathParserContextPtr ctxt);
|
||||||
|
XMLPUBFUN xmlChar * XMLCALL
|
||||||
|
xmlXPathParseNCName (xmlXPathParserContextPtr ctxt);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Existing functions.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN double XMLCALL
|
||||||
|
xmlXPathStringEvalNumber (const xmlChar *str);
|
||||||
|
XMLPUBFUN int XMLCALL
|
||||||
|
xmlXPathEvaluatePredicateResult (xmlXPathParserContextPtr ctxt,
|
||||||
|
xmlXPathObjectPtr res);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPathRegisterAllFunctions (xmlXPathContextPtr ctxt);
|
||||||
|
XMLPUBFUN xmlNodeSetPtr XMLCALL
|
||||||
|
xmlXPathNodeSetMerge (xmlNodeSetPtr val1,
|
||||||
|
xmlNodeSetPtr val2);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPathNodeSetDel (xmlNodeSetPtr cur,
|
||||||
|
xmlNodePtr val);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPathNodeSetRemove (xmlNodeSetPtr cur,
|
||||||
|
int val);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPathNewNodeSetList (xmlNodeSetPtr val);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPathWrapNodeSet (xmlNodeSetPtr val);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPathWrapExternal (void *val);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL xmlXPathEqualValues(xmlXPathParserContextPtr ctxt);
|
||||||
|
XMLPUBFUN int XMLCALL xmlXPathNotEqualValues(xmlXPathParserContextPtr ctxt);
|
||||||
|
XMLPUBFUN int XMLCALL xmlXPathCompareValues(xmlXPathParserContextPtr ctxt, int inf, int strict);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathValueFlipSign(xmlXPathParserContextPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathAddValues(xmlXPathParserContextPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathSubValues(xmlXPathParserContextPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathMultValues(xmlXPathParserContextPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathDivValues(xmlXPathParserContextPtr ctxt);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathModValues(xmlXPathParserContextPtr ctxt);
|
||||||
|
|
||||||
|
XMLPUBFUN int XMLCALL xmlXPathIsNodeType(const xmlChar *name);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Some of the axis navigation routines.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlNodePtr XMLCALL xmlXPathNextSelf(xmlXPathParserContextPtr ctxt,
|
||||||
|
xmlNodePtr cur);
|
||||||
|
XMLPUBFUN xmlNodePtr XMLCALL xmlXPathNextChild(xmlXPathParserContextPtr ctxt,
|
||||||
|
xmlNodePtr cur);
|
||||||
|
XMLPUBFUN xmlNodePtr XMLCALL xmlXPathNextDescendant(xmlXPathParserContextPtr ctxt,
|
||||||
|
xmlNodePtr cur);
|
||||||
|
XMLPUBFUN xmlNodePtr XMLCALL xmlXPathNextDescendantOrSelf(xmlXPathParserContextPtr ctxt,
|
||||||
|
xmlNodePtr cur);
|
||||||
|
XMLPUBFUN xmlNodePtr XMLCALL xmlXPathNextParent(xmlXPathParserContextPtr ctxt,
|
||||||
|
xmlNodePtr cur);
|
||||||
|
XMLPUBFUN xmlNodePtr XMLCALL xmlXPathNextAncestorOrSelf(xmlXPathParserContextPtr ctxt,
|
||||||
|
xmlNodePtr cur);
|
||||||
|
XMLPUBFUN xmlNodePtr XMLCALL xmlXPathNextFollowingSibling(xmlXPathParserContextPtr ctxt,
|
||||||
|
xmlNodePtr cur);
|
||||||
|
XMLPUBFUN xmlNodePtr XMLCALL xmlXPathNextFollowing(xmlXPathParserContextPtr ctxt,
|
||||||
|
xmlNodePtr cur);
|
||||||
|
XMLPUBFUN xmlNodePtr XMLCALL xmlXPathNextNamespace(xmlXPathParserContextPtr ctxt,
|
||||||
|
xmlNodePtr cur);
|
||||||
|
XMLPUBFUN xmlNodePtr XMLCALL xmlXPathNextAttribute(xmlXPathParserContextPtr ctxt,
|
||||||
|
xmlNodePtr cur);
|
||||||
|
XMLPUBFUN xmlNodePtr XMLCALL xmlXPathNextPreceding(xmlXPathParserContextPtr ctxt,
|
||||||
|
xmlNodePtr cur);
|
||||||
|
XMLPUBFUN xmlNodePtr XMLCALL xmlXPathNextAncestor(xmlXPathParserContextPtr ctxt,
|
||||||
|
xmlNodePtr cur);
|
||||||
|
XMLPUBFUN xmlNodePtr XMLCALL xmlXPathNextPrecedingSibling(xmlXPathParserContextPtr ctxt,
|
||||||
|
xmlNodePtr cur);
|
||||||
|
/*
|
||||||
|
* The official core of XPath functions.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathLastFunction(xmlXPathParserContextPtr ctxt, int nargs);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathPositionFunction(xmlXPathParserContextPtr ctxt, int nargs);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathCountFunction(xmlXPathParserContextPtr ctxt, int nargs);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathIdFunction(xmlXPathParserContextPtr ctxt, int nargs);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathLocalNameFunction(xmlXPathParserContextPtr ctxt, int nargs);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathNamespaceURIFunction(xmlXPathParserContextPtr ctxt, int nargs);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathStringFunction(xmlXPathParserContextPtr ctxt, int nargs);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathStringLengthFunction(xmlXPathParserContextPtr ctxt, int nargs);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathConcatFunction(xmlXPathParserContextPtr ctxt, int nargs);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathContainsFunction(xmlXPathParserContextPtr ctxt, int nargs);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathStartsWithFunction(xmlXPathParserContextPtr ctxt, int nargs);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathSubstringFunction(xmlXPathParserContextPtr ctxt, int nargs);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathSubstringBeforeFunction(xmlXPathParserContextPtr ctxt, int nargs);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathSubstringAfterFunction(xmlXPathParserContextPtr ctxt, int nargs);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathNormalizeFunction(xmlXPathParserContextPtr ctxt, int nargs);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathTranslateFunction(xmlXPathParserContextPtr ctxt, int nargs);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathNotFunction(xmlXPathParserContextPtr ctxt, int nargs);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathTrueFunction(xmlXPathParserContextPtr ctxt, int nargs);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathFalseFunction(xmlXPathParserContextPtr ctxt, int nargs);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathLangFunction(xmlXPathParserContextPtr ctxt, int nargs);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathNumberFunction(xmlXPathParserContextPtr ctxt, int nargs);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathSumFunction(xmlXPathParserContextPtr ctxt, int nargs);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathFloorFunction(xmlXPathParserContextPtr ctxt, int nargs);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathCeilingFunction(xmlXPathParserContextPtr ctxt, int nargs);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathRoundFunction(xmlXPathParserContextPtr ctxt, int nargs);
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathBooleanFunction(xmlXPathParserContextPtr ctxt, int nargs);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Really internal functions
|
||||||
|
*/
|
||||||
|
XMLPUBFUN void XMLCALL xmlXPathNodeSetFreeNs(xmlNsPtr ns);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* LIBXML_XPATH_ENABLED */
|
||||||
|
#endif /* ! __XML_XPATH_INTERNALS_H__ */
|
|
@ -0,0 +1,114 @@
|
||||||
|
/*
|
||||||
|
* Summary: API to handle XML Pointers
|
||||||
|
* Description: API to handle XML Pointers
|
||||||
|
* Base implementation was made accordingly to
|
||||||
|
* W3C Candidate Recommendation 7 June 2000
|
||||||
|
* http://www.w3.org/TR/2000/CR-xptr-20000607
|
||||||
|
*
|
||||||
|
* Added support for the element() scheme described in:
|
||||||
|
* W3C Proposed Recommendation 13 November 2002
|
||||||
|
* http://www.w3.org/TR/2002/PR-xptr-element-20021113/
|
||||||
|
*
|
||||||
|
* Copy: See Copyright for the status of this software.
|
||||||
|
*
|
||||||
|
* Author: Daniel Veillard
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __XML_XPTR_H__
|
||||||
|
#define __XML_XPTR_H__
|
||||||
|
|
||||||
|
#include <libxml/xmlversion.h>
|
||||||
|
|
||||||
|
#ifdef LIBXML_XPTR_ENABLED
|
||||||
|
|
||||||
|
#include <libxml/tree.h>
|
||||||
|
#include <libxml/xpath.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* A Location Set
|
||||||
|
*/
|
||||||
|
typedef struct _xmlLocationSet xmlLocationSet;
|
||||||
|
typedef xmlLocationSet *xmlLocationSetPtr;
|
||||||
|
struct _xmlLocationSet {
|
||||||
|
int locNr; /* number of locations in the set */
|
||||||
|
int locMax; /* size of the array as allocated */
|
||||||
|
xmlXPathObjectPtr *locTab;/* array of locations */
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Handling of location sets.
|
||||||
|
*/
|
||||||
|
|
||||||
|
XMLPUBFUN xmlLocationSetPtr XMLCALL
|
||||||
|
xmlXPtrLocationSetCreate (xmlXPathObjectPtr val);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPtrFreeLocationSet (xmlLocationSetPtr obj);
|
||||||
|
XMLPUBFUN xmlLocationSetPtr XMLCALL
|
||||||
|
xmlXPtrLocationSetMerge (xmlLocationSetPtr val1,
|
||||||
|
xmlLocationSetPtr val2);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPtrNewRange (xmlNodePtr start,
|
||||||
|
int startindex,
|
||||||
|
xmlNodePtr end,
|
||||||
|
int endindex);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPtrNewRangePoints (xmlXPathObjectPtr start,
|
||||||
|
xmlXPathObjectPtr end);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPtrNewRangeNodePoint (xmlNodePtr start,
|
||||||
|
xmlXPathObjectPtr end);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPtrNewRangePointNode (xmlXPathObjectPtr start,
|
||||||
|
xmlNodePtr end);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPtrNewRangeNodes (xmlNodePtr start,
|
||||||
|
xmlNodePtr end);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPtrNewLocationSetNodes (xmlNodePtr start,
|
||||||
|
xmlNodePtr end);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPtrNewLocationSetNodeSet(xmlNodeSetPtr set);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPtrNewRangeNodeObject (xmlNodePtr start,
|
||||||
|
xmlXPathObjectPtr end);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPtrNewCollapsedRange (xmlNodePtr start);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPtrLocationSetAdd (xmlLocationSetPtr cur,
|
||||||
|
xmlXPathObjectPtr val);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPtrWrapLocationSet (xmlLocationSetPtr val);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPtrLocationSetDel (xmlLocationSetPtr cur,
|
||||||
|
xmlXPathObjectPtr val);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPtrLocationSetRemove (xmlLocationSetPtr cur,
|
||||||
|
int val);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Functions.
|
||||||
|
*/
|
||||||
|
XMLPUBFUN xmlXPathContextPtr XMLCALL
|
||||||
|
xmlXPtrNewContext (xmlDocPtr doc,
|
||||||
|
xmlNodePtr here,
|
||||||
|
xmlNodePtr origin);
|
||||||
|
XMLPUBFUN xmlXPathObjectPtr XMLCALL
|
||||||
|
xmlXPtrEval (const xmlChar *str,
|
||||||
|
xmlXPathContextPtr ctx);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPtrRangeToFunction (xmlXPathParserContextPtr ctxt,
|
||||||
|
int nargs);
|
||||||
|
XMLPUBFUN xmlNodePtr XMLCALL
|
||||||
|
xmlXPtrBuildNodeList (xmlXPathObjectPtr obj);
|
||||||
|
XMLPUBFUN void XMLCALL
|
||||||
|
xmlXPtrEvalRangePredicate (xmlXPathParserContextPtr ctxt);
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* LIBXML_XPTR_ENABLED */
|
||||||
|
#endif /* __XML_XPTR_H__ */
|
Loading…
Reference in New Issue