| Index: third_party/libxslt/libxslt/xsltInternals.h | 
| diff --git a/third_party/libxslt/libxslt/xsltInternals.h b/third_party/libxslt/libxslt/xsltInternals.h | 
| deleted file mode 100644 | 
| index 47125b3651005cfc7dc9986af7a72ae47e246451..0000000000000000000000000000000000000000 | 
| --- a/third_party/libxslt/libxslt/xsltInternals.h | 
| +++ /dev/null | 
| @@ -1,1982 +0,0 @@ | 
| -/* | 
| - * Summary: internal data structures, constants and functions | 
| - * Description: Internal data structures, constants and functions used | 
| - *              by the XSLT engine. | 
| - *              They are not part of the API or ABI, i.e. they can change | 
| - *              without prior notice, use carefully. | 
| - * | 
| - * Copy: See Copyright for the status of this software. | 
| - * | 
| - * Author: Daniel Veillard | 
| - */ | 
| - | 
| -#ifndef __XML_XSLT_INTERNALS_H__ | 
| -#define __XML_XSLT_INTERNALS_H__ | 
| - | 
| -#include <libxml/tree.h> | 
| -#include <libxml/hash.h> | 
| -#include <libxml/xpath.h> | 
| -#include <libxml/xmlerror.h> | 
| -#include <libxml/dict.h> | 
| -#include <libxml/xmlstring.h> | 
| -#include <libxslt/xslt.h> | 
| -#include "xsltexports.h" | 
| -#include "xsltlocale.h" | 
| -#include "numbersInternals.h" | 
| - | 
| -#ifdef __cplusplus | 
| -extern "C" { | 
| -#endif | 
| - | 
| -/* #define XSLT_DEBUG_PROFILE_CACHE */ | 
| - | 
| -/** | 
| - * XSLT_IS_TEXT_NODE: | 
| - * | 
| - * check if the argument is a text node | 
| - */ | 
| -#define XSLT_IS_TEXT_NODE(n) ((n != NULL) && \ | 
| -    (((n)->type == XML_TEXT_NODE) || \ | 
| -     ((n)->type == XML_CDATA_SECTION_NODE))) | 
| - | 
| - | 
| -/** | 
| - * XSLT_MARK_RES_TREE_FRAG: | 
| - * | 
| - * internal macro to set up tree fragments | 
| - */ | 
| -#define XSLT_MARK_RES_TREE_FRAG(n) \ | 
| -    (n)->name = (char *) xmlStrdup(BAD_CAST " fake node libxslt"); | 
| - | 
| -/** | 
| - * XSLT_IS_RES_TREE_FRAG: | 
| - * | 
| - * internal macro to test tree fragments | 
| - */ | 
| -#define XSLT_IS_RES_TREE_FRAG(n) \ | 
| -    ((n != NULL) && ((n)->type == XML_DOCUMENT_NODE) && \ | 
| -     ((n)->name != NULL) && ((n)->name[0] == ' ')) | 
| - | 
| -/** | 
| - * XSLT_REFACTORED_KEYCOMP: | 
| - * | 
| - * Internal define to enable on-demand xsl:key computation. | 
| - * That's the only mode now but the define is kept for compatibility | 
| - */ | 
| -#define XSLT_REFACTORED_KEYCOMP | 
| - | 
| -/** | 
| - * XSLT_FAST_IF: | 
| - * | 
| - * Internal define to enable usage of xmlXPathCompiledEvalToBoolean() | 
| - * for XSLT "tests"; e.g. in <xsl:if test="/foo/bar"> | 
| - */ | 
| -#define XSLT_FAST_IF | 
| - | 
| -/** | 
| - * XSLT_REFACTORED: | 
| - * | 
| - * Internal define to enable the refactored parts of Libxslt. | 
| - */ | 
| -/* #define XSLT_REFACTORED */ | 
| -/* ==================================================================== */ | 
| - | 
| -/** | 
| - * XSLT_REFACTORED_VARS: | 
| - * | 
| - * Internal define to enable the refactored variable part of libxslt | 
| - */ | 
| -#define XSLT_REFACTORED_VARS | 
| - | 
| -#ifdef XSLT_REFACTORED | 
| - | 
| -extern const xmlChar *xsltXSLTAttrMarker; | 
| - | 
| - | 
| -/* TODO: REMOVE: #define XSLT_REFACTORED_EXCLRESNS */ | 
| - | 
| -/* TODO: REMOVE: #define XSLT_REFACTORED_NSALIAS */ | 
| - | 
| -/** | 
| - * XSLT_REFACTORED_XSLT_NSCOMP | 
| - * | 
| - * Internal define to enable the pointer-comparison of | 
| - * namespaces of XSLT elements. | 
| - */ | 
| -/* #define XSLT_REFACTORED_XSLT_NSCOMP */ | 
| - | 
| -/** | 
| - * XSLT_REFACTORED_XPATHCOMP: | 
| - * | 
| - * Internal define to enable the optimization of the | 
| - * compilation of XPath expressions. | 
| - */ | 
| -#define XSLT_REFACTORED_XPATHCOMP | 
| - | 
| -#ifdef XSLT_REFACTORED_XSLT_NSCOMP | 
| - | 
| -extern const xmlChar *xsltConstNamespaceNameXSLT; | 
| - | 
| -/** | 
| - * IS_XSLT_ELEM_FAST: | 
| - * | 
| - * quick test to detect XSLT elements | 
| - */ | 
| -#define IS_XSLT_ELEM_FAST(n) \ | 
| -    (((n) != NULL) && ((n)->ns != NULL) && \ | 
| -    ((n)->ns->href == xsltConstNamespaceNameXSLT)) | 
| - | 
| -/** | 
| - * IS_XSLT_ATTR_FAST: | 
| - * | 
| - * quick test to detect XSLT attributes | 
| - */ | 
| -#define IS_XSLT_ATTR_FAST(a) \ | 
| -    (((a) != NULL) && ((a)->ns != NULL) && \ | 
| -    ((a)->ns->href == xsltConstNamespaceNameXSLT)) | 
| - | 
| -/** | 
| - * XSLT_HAS_INTERNAL_NSMAP: | 
| - * | 
| - * check for namespace mapping | 
| - */ | 
| -#define XSLT_HAS_INTERNAL_NSMAP(s) \ | 
| -    (((s) != NULL) && ((s)->principal) && \ | 
| -     ((s)->principal->principalData) && \ | 
| -     ((s)->principal->principalData->nsMap)) | 
| - | 
| -/** | 
| - * XSLT_GET_INTERNAL_NSMAP: | 
| - * | 
| - * get pointer to namespace map | 
| - */ | 
| -#define XSLT_GET_INTERNAL_NSMAP(s) ((s)->principal->principalData->nsMap) | 
| - | 
| -#else /* XSLT_REFACTORED_XSLT_NSCOMP */ | 
| - | 
| -/** | 
| - * IS_XSLT_ELEM_FAST: | 
| - * | 
| - * quick check whether this is an xslt element | 
| - */ | 
| -#define IS_XSLT_ELEM_FAST(n) \ | 
| -    (((n) != NULL) && ((n)->ns != NULL) && \ | 
| -     (xmlStrEqual((n)->ns->href, XSLT_NAMESPACE))) | 
| - | 
| -/** | 
| - * IS_XSLT_ATTR_FAST: | 
| - * | 
| - * quick check for xslt namespace attribute | 
| - */ | 
| -#define IS_XSLT_ATTR_FAST(a) \ | 
| -    (((a) != NULL) && ((a)->ns != NULL) && \ | 
| -     (xmlStrEqual((a)->ns->href, XSLT_NAMESPACE))) | 
| - | 
| - | 
| -#endif /* XSLT_REFACTORED_XSLT_NSCOMP */ | 
| - | 
| - | 
| -/** | 
| - * XSLT_REFACTORED_MANDATORY_VERSION: | 
| - * | 
| - * TODO: Currently disabled to surpress regression test failures, since | 
| - *  the old behaviour was that a missing version attribute | 
| - *  produced a only a warning and not an error, which was incerrect. | 
| - *  So the regression tests need to be fixed if this is enabled. | 
| - */ | 
| -/* #define XSLT_REFACTORED_MANDATORY_VERSION */ | 
| - | 
| -/** | 
| - * xsltPointerList: | 
| - * | 
| - * Pointer-list for various purposes. | 
| - */ | 
| -typedef struct _xsltPointerList xsltPointerList; | 
| -typedef xsltPointerList *xsltPointerListPtr; | 
| -struct _xsltPointerList { | 
| -    void **items; | 
| -    int number; | 
| -    int size; | 
| -}; | 
| - | 
| -#endif | 
| - | 
| -/** | 
| - * XSLT_REFACTORED_PARSING: | 
| - * | 
| - * Internal define to enable the refactored parts of Libxslt | 
| - * related to parsing. | 
| - */ | 
| -/* #define XSLT_REFACTORED_PARSING */ | 
| - | 
| -/** | 
| - * XSLT_MAX_SORT: | 
| - * | 
| - * Max number of specified xsl:sort on an element. | 
| - */ | 
| -#define XSLT_MAX_SORT 15 | 
| - | 
| -/** | 
| - * XSLT_PAT_NO_PRIORITY: | 
| - * | 
| - * Specific value for pattern without priority expressed. | 
| - */ | 
| -#define XSLT_PAT_NO_PRIORITY -12345789 | 
| - | 
| -/** | 
| - * xsltRuntimeExtra: | 
| - * | 
| - * Extra information added to the transformation context. | 
| - */ | 
| -typedef struct _xsltRuntimeExtra xsltRuntimeExtra; | 
| -typedef xsltRuntimeExtra *xsltRuntimeExtraPtr; | 
| -struct _xsltRuntimeExtra { | 
| -    void       *info;		/* pointer to the extra data */ | 
| -    xmlFreeFunc deallocate;	/* pointer to the deallocation routine */ | 
| -    union {			/* dual-purpose field */ | 
| -        void   *ptr;		/* data not needing deallocation */ | 
| -	int    ival;		/* integer value storage */ | 
| -    } val; | 
| -}; | 
| - | 
| -/** | 
| - * XSLT_RUNTIME_EXTRA_LST: | 
| - * @ctxt: the transformation context | 
| - * @nr: the index | 
| - * | 
| - * Macro used to access extra information stored in the context | 
| - */ | 
| -#define XSLT_RUNTIME_EXTRA_LST(ctxt, nr) (ctxt)->extras[(nr)].info | 
| -/** | 
| - * XSLT_RUNTIME_EXTRA_FREE: | 
| - * @ctxt: the transformation context | 
| - * @nr: the index | 
| - * | 
| - * Macro used to free extra information stored in the context | 
| - */ | 
| -#define XSLT_RUNTIME_EXTRA_FREE(ctxt, nr) (ctxt)->extras[(nr)].deallocate | 
| -/** | 
| - * XSLT_RUNTIME_EXTRA: | 
| - * @ctxt: the transformation context | 
| - * @nr: the index | 
| - * | 
| - * Macro used to define extra information stored in the context | 
| - */ | 
| -#define	XSLT_RUNTIME_EXTRA(ctxt, nr, typ) (ctxt)->extras[(nr)].val.typ | 
| - | 
| -/** | 
| - * xsltTemplate: | 
| - * | 
| - * The in-memory structure corresponding to an XSLT Template. | 
| - */ | 
| -typedef struct _xsltTemplate xsltTemplate; | 
| -typedef xsltTemplate *xsltTemplatePtr; | 
| -struct _xsltTemplate { | 
| -    struct _xsltTemplate *next;/* chained list sorted by priority */ | 
| -    struct _xsltStylesheet *style;/* the containing stylesheet */ | 
| -    xmlChar *match;	/* the matching string */ | 
| -    float priority;	/* as given from the stylesheet, not computed */ | 
| -    const xmlChar *name; /* the local part of the name QName */ | 
| -    const xmlChar *nameURI; /* the URI part of the name QName */ | 
| -    const xmlChar *mode;/* the local part of the mode QName */ | 
| -    const xmlChar *modeURI;/* the URI part of the mode QName */ | 
| -    xmlNodePtr content;	/* the template replacement value */ | 
| -    xmlNodePtr elem;	/* the source element */ | 
| - | 
| -    /* | 
| -    * TODO: @inheritedNsNr and @inheritedNs won't be used in the | 
| -    *  refactored code. | 
| -    */ | 
| -    int inheritedNsNr;  /* number of inherited namespaces */ | 
| -    xmlNsPtr *inheritedNs;/* inherited non-excluded namespaces */ | 
| - | 
| -    /* Profiling informations */ | 
| -    int nbCalls;        /* the number of time the template was called */ | 
| -    unsigned long time; /* the time spent in this template */ | 
| -    void *params;       /* xsl:param instructions */ | 
| - | 
| -    int              templNr;		/* Nb of templates in the stack */ | 
| -    int              templMax;		/* Size of the templtes stack */ | 
| -    xsltTemplatePtr *templCalledTab;	/* templates called */ | 
| -    int             *templCountTab;  /* .. and how often */ | 
| -}; | 
| - | 
| -/** | 
| - * xsltDecimalFormat: | 
| - * | 
| - * Data structure of decimal-format. | 
| - */ | 
| -typedef struct _xsltDecimalFormat xsltDecimalFormat; | 
| -typedef xsltDecimalFormat *xsltDecimalFormatPtr; | 
| -struct _xsltDecimalFormat { | 
| -    struct _xsltDecimalFormat *next; /* chained list */ | 
| -    xmlChar *name; | 
| -    /* Used for interpretation of pattern */ | 
| -    xmlChar *digit; | 
| -    xmlChar *patternSeparator; | 
| -    /* May appear in result */ | 
| -    xmlChar *minusSign; | 
| -    xmlChar *infinity; | 
| -    xmlChar *noNumber; /* Not-a-number */ | 
| -    /* Used for interpretation of pattern and may appear in result */ | 
| -    xmlChar *decimalPoint; | 
| -    xmlChar *grouping; | 
| -    xmlChar *percent; | 
| -    xmlChar *permille; | 
| -    xmlChar *zeroDigit; | 
| -    const xmlChar *nsUri; | 
| -}; | 
| - | 
| -/** | 
| - * xsltDocument: | 
| - * | 
| - * Data structure associated to a parsed document. | 
| - */ | 
| -typedef struct _xsltDocument xsltDocument; | 
| -typedef xsltDocument *xsltDocumentPtr; | 
| -struct _xsltDocument { | 
| -    struct _xsltDocument *next;	/* documents are kept in a chained list */ | 
| -    int main;			/* is this the main document */ | 
| -    xmlDocPtr doc;		/* the parsed document */ | 
| -    void *keys;			/* key tables storage */ | 
| -    struct _xsltDocument *includes; /* subsidiary includes */ | 
| -    int preproc;		/* pre-processing already done */ | 
| -    int nbKeysComputed; | 
| -}; | 
| - | 
| -/** | 
| - * xsltKeyDef: | 
| - * | 
| - * Representation of an xsl:key. | 
| - */ | 
| -typedef struct _xsltKeyDef xsltKeyDef; | 
| -typedef xsltKeyDef *xsltKeyDefPtr; | 
| -struct _xsltKeyDef { | 
| -    struct _xsltKeyDef *next; | 
| -    xmlNodePtr inst; | 
| -    xmlChar *name; | 
| -    xmlChar *nameURI; | 
| -    xmlChar *match; | 
| -    xmlChar *use; | 
| -    xmlXPathCompExprPtr comp; | 
| -    xmlXPathCompExprPtr usecomp; | 
| -    xmlNsPtr *nsList;           /* the namespaces in scope */ | 
| -    int nsNr;                   /* the number of namespaces in scope */ | 
| -}; | 
| - | 
| -/** | 
| - * xsltKeyTable: | 
| - * | 
| - * Holds the computed keys for key definitions of the same QName. | 
| - * Is owned by an xsltDocument. | 
| - */ | 
| -typedef struct _xsltKeyTable xsltKeyTable; | 
| -typedef xsltKeyTable *xsltKeyTablePtr; | 
| -struct _xsltKeyTable { | 
| -    struct _xsltKeyTable *next; | 
| -    xmlChar *name; | 
| -    xmlChar *nameURI; | 
| -    xmlHashTablePtr keys; | 
| -}; | 
| - | 
| -/* | 
| - * The in-memory structure corresponding to an XSLT Stylesheet. | 
| - * NOTE: most of the content is simply linked from the doc tree | 
| - *       structure, no specific allocation is made. | 
| - */ | 
| -typedef struct _xsltStylesheet xsltStylesheet; | 
| -typedef xsltStylesheet *xsltStylesheetPtr; | 
| - | 
| -typedef struct _xsltTransformContext xsltTransformContext; | 
| -typedef xsltTransformContext *xsltTransformContextPtr; | 
| - | 
| -/** | 
| - * xsltElemPreComp: | 
| - * | 
| - * The in-memory structure corresponding to element precomputed data, | 
| - * designed to be extended by extension implementors. | 
| - */ | 
| -typedef struct _xsltElemPreComp xsltElemPreComp; | 
| -typedef xsltElemPreComp *xsltElemPreCompPtr; | 
| - | 
| -/** | 
| - * xsltTransformFunction: | 
| - * @ctxt: the XSLT transformation context | 
| - * @node: the input node | 
| - * @inst: the stylesheet node | 
| - * @comp: the compiled information from the stylesheet | 
| - * | 
| - * Signature of the function associated to elements part of the | 
| - * stylesheet language like xsl:if or xsl:apply-templates. | 
| - */ | 
| -typedef void (*xsltTransformFunction) (xsltTransformContextPtr ctxt, | 
| -	                               xmlNodePtr node, | 
| -				       xmlNodePtr inst, | 
| -			               xsltElemPreCompPtr comp); | 
| - | 
| -/** | 
| - * xsltSortFunc: | 
| - * @ctxt:    a transformation context | 
| - * @sorts:   the node-set to sort | 
| - * @nbsorts: the number of sorts | 
| - * | 
| - * Signature of the function to use during sorting | 
| - */ | 
| -typedef void (*xsltSortFunc) (xsltTransformContextPtr ctxt, xmlNodePtr *sorts, | 
| -			      int nbsorts); | 
| - | 
| -typedef enum { | 
| -    XSLT_FUNC_COPY=1, | 
| -    XSLT_FUNC_SORT, | 
| -    XSLT_FUNC_TEXT, | 
| -    XSLT_FUNC_ELEMENT, | 
| -    XSLT_FUNC_ATTRIBUTE, | 
| -    XSLT_FUNC_COMMENT, | 
| -    XSLT_FUNC_PI, | 
| -    XSLT_FUNC_COPYOF, | 
| -    XSLT_FUNC_VALUEOF, | 
| -    XSLT_FUNC_NUMBER, | 
| -    XSLT_FUNC_APPLYIMPORTS, | 
| -    XSLT_FUNC_CALLTEMPLATE, | 
| -    XSLT_FUNC_APPLYTEMPLATES, | 
| -    XSLT_FUNC_CHOOSE, | 
| -    XSLT_FUNC_IF, | 
| -    XSLT_FUNC_FOREACH, | 
| -    XSLT_FUNC_DOCUMENT, | 
| -    XSLT_FUNC_WITHPARAM, | 
| -    XSLT_FUNC_PARAM, | 
| -    XSLT_FUNC_VARIABLE, | 
| -    XSLT_FUNC_WHEN, | 
| -    XSLT_FUNC_EXTENSION | 
| -#ifdef XSLT_REFACTORED | 
| -    , | 
| -    XSLT_FUNC_OTHERWISE, | 
| -    XSLT_FUNC_FALLBACK, | 
| -    XSLT_FUNC_MESSAGE, | 
| -    XSLT_FUNC_INCLUDE, | 
| -    XSLT_FUNC_ATTRSET, | 
| -    XSLT_FUNC_LITERAL_RESULT_ELEMENT, | 
| -    XSLT_FUNC_UNKOWN_FORWARDS_COMPAT | 
| -#endif | 
| -} xsltStyleType; | 
| - | 
| -/** | 
| - * xsltElemPreCompDeallocator: | 
| - * @comp:  the #xsltElemPreComp to free up | 
| - * | 
| - * Deallocates an #xsltElemPreComp structure. | 
| - */ | 
| -typedef void (*xsltElemPreCompDeallocator) (xsltElemPreCompPtr comp); | 
| - | 
| -/** | 
| - * xsltElemPreComp: | 
| - * | 
| - * The basic structure for compiled items of the AST of the XSLT processor. | 
| - * This structure is also intended to be extended by extension implementors. | 
| - * TODO: This is somehow not nice, since it has a "free" field, which | 
| - *   derived stylesheet-structs do not have. | 
| - */ | 
| -struct _xsltElemPreComp { | 
| -    xsltElemPreCompPtr next;		/* next item in the global chained | 
| -					   list hold by xsltStylesheet. */ | 
| -    xsltStyleType type;		/* type of the element */ | 
| -    xsltTransformFunction func;	/* handling function */ | 
| -    xmlNodePtr inst;			/* the node in the stylesheet's tree | 
| -					   corresponding to this item */ | 
| - | 
| -    /* end of common part */ | 
| -    xsltElemPreCompDeallocator free;	/* the deallocator */ | 
| -}; | 
| - | 
| -/** | 
| - * xsltStylePreComp: | 
| - * | 
| - * The abstract basic structure for items of the XSLT processor. | 
| - * This includes: | 
| - * 1) compiled forms of XSLT instructions (xsl:if, xsl:attribute, etc.) | 
| - * 2) compiled forms of literal result elements | 
| - * 3) compiled forms of extension elements | 
| - */ | 
| -typedef struct _xsltStylePreComp xsltStylePreComp; | 
| -typedef xsltStylePreComp *xsltStylePreCompPtr; | 
| - | 
| -#ifdef XSLT_REFACTORED | 
| - | 
| -/* | 
| -* Some pointer-list utility functions. | 
| -*/ | 
| -XSLTPUBFUN xsltPointerListPtr XSLTCALL | 
| -		xsltPointerListCreate		(int initialSize); | 
| -XSLTPUBFUN void XSLTCALL | 
| -		xsltPointerListFree		(xsltPointerListPtr list); | 
| -XSLTPUBFUN void XSLTCALL | 
| -		xsltPointerListClear		(xsltPointerListPtr list); | 
| -XSLTPUBFUN int XSLTCALL | 
| -		xsltPointerListAddSize		(xsltPointerListPtr list, | 
| -						 void *item, | 
| -						 int initialSize); | 
| - | 
| -/************************************************************************ | 
| - *									* | 
| - * Refactored structures                                                * | 
| - *									* | 
| - ************************************************************************/ | 
| - | 
| -typedef struct _xsltNsListContainer xsltNsListContainer; | 
| -typedef xsltNsListContainer *xsltNsListContainerPtr; | 
| -struct _xsltNsListContainer { | 
| -    xmlNsPtr *list; | 
| -    int totalNumber; | 
| -    int xpathNumber; | 
| -}; | 
| - | 
| -/** | 
| - * XSLT_ITEM_COMPATIBILITY_FIELDS: | 
| - * | 
| - * Fields for API compatibility to the structure | 
| - * _xsltElemPreComp which is used for extension functions. | 
| - * Note that @next is used for storage; it does not reflect a next | 
| - * sibling in the tree. | 
| - * TODO: Evaluate if we really need such a compatibility. | 
| - */ | 
| -#define XSLT_ITEM_COMPATIBILITY_FIELDS \ | 
| -    xsltElemPreCompPtr next;\ | 
| -    xsltStyleType type;\ | 
| -    xsltTransformFunction func;\ | 
| -    xmlNodePtr inst; | 
| - | 
| -/** | 
| - * XSLT_ITEM_NAVIGATION_FIELDS: | 
| - * | 
| - * Currently empty. | 
| - * TODO: It is intended to hold navigational fields in the future. | 
| - */ | 
| -#define XSLT_ITEM_NAVIGATION_FIELDS | 
| -/* | 
| -    xsltStylePreCompPtr parent;\ | 
| -    xsltStylePreCompPtr children;\ | 
| -    xsltStylePreCompPtr nextItem; | 
| -*/ | 
| - | 
| -/** | 
| - * XSLT_ITEM_NSINSCOPE_FIELDS: | 
| - * | 
| - * The in-scope namespaces. | 
| - */ | 
| -#define XSLT_ITEM_NSINSCOPE_FIELDS xsltNsListContainerPtr inScopeNs; | 
| - | 
| -/** | 
| - * XSLT_ITEM_COMMON_FIELDS: | 
| - * | 
| - * Common fields used for all items. | 
| - */ | 
| -#define XSLT_ITEM_COMMON_FIELDS \ | 
| -    XSLT_ITEM_COMPATIBILITY_FIELDS \ | 
| -    XSLT_ITEM_NAVIGATION_FIELDS \ | 
| -    XSLT_ITEM_NSINSCOPE_FIELDS | 
| - | 
| -/** | 
| - * _xsltStylePreComp: | 
| - * | 
| - * The abstract basic structure for items of the XSLT processor. | 
| - * This includes: | 
| - * 1) compiled forms of XSLT instructions (e.g. xsl:if, xsl:attribute, etc.) | 
| - * 2) compiled forms of literal result elements | 
| - * 3) various properties for XSLT instructions (e.g. xsl:when, | 
| - *    xsl:with-param) | 
| - * | 
| - * REVISIT TODO: Keep this structure equal to the fields | 
| - *   defined by XSLT_ITEM_COMMON_FIELDS | 
| - */ | 
| -struct _xsltStylePreComp { | 
| -    xsltElemPreCompPtr next;    /* next item in the global chained | 
| -				   list hold by xsltStylesheet */ | 
| -    xsltStyleType type;         /* type of the item */ | 
| -    xsltTransformFunction func; /* handling function */ | 
| -    xmlNodePtr inst;		/* the node in the stylesheet's tree | 
| -				   corresponding to this item. */ | 
| -    /* Currently no navigational fields. */ | 
| -    xsltNsListContainerPtr inScopeNs; | 
| -}; | 
| - | 
| -/** | 
| - * xsltStyleBasicEmptyItem: | 
| - * | 
| - * Abstract structure only used as a short-cut for | 
| - * XSLT items with no extra fields. | 
| - * NOTE that it is intended that this structure looks the same as | 
| - *  _xsltStylePreComp. | 
| - */ | 
| -typedef struct _xsltStyleBasicEmptyItem xsltStyleBasicEmptyItem; | 
| -typedef xsltStyleBasicEmptyItem *xsltStyleBasicEmptyItemPtr; | 
| - | 
| -struct _xsltStyleBasicEmptyItem { | 
| -    XSLT_ITEM_COMMON_FIELDS | 
| -}; | 
| - | 
| -/** | 
| - * xsltStyleBasicExpressionItem: | 
| - * | 
| - * Abstract structure only used as a short-cut for | 
| - * XSLT items with just an expression. | 
| - */ | 
| -typedef struct _xsltStyleBasicExpressionItem xsltStyleBasicExpressionItem; | 
| -typedef xsltStyleBasicExpressionItem *xsltStyleBasicExpressionItemPtr; | 
| - | 
| -struct _xsltStyleBasicExpressionItem { | 
| -    XSLT_ITEM_COMMON_FIELDS | 
| - | 
| -    const xmlChar *select; /* TODO: Change this to "expression". */ | 
| -    xmlXPathCompExprPtr comp; /* TODO: Change this to compExpr. */ | 
| -}; | 
| - | 
| -/************************************************************************ | 
| - *									* | 
| - * XSLT-instructions/declarations                                       * | 
| - *									* | 
| - ************************************************************************/ | 
| - | 
| -/** | 
| - * xsltStyleItemElement: | 
| - * | 
| - * <!-- Category: instruction --> | 
| - * <xsl:element | 
| - *  name = { qname } | 
| - *  namespace = { uri-reference } | 
| - *  use-attribute-sets = qnames> | 
| - *  <!-- Content: template --> | 
| - * </xsl:element> | 
| - */ | 
| -typedef struct _xsltStyleItemElement xsltStyleItemElement; | 
| -typedef xsltStyleItemElement *xsltStyleItemElementPtr; | 
| - | 
| -struct _xsltStyleItemElement { | 
| -    XSLT_ITEM_COMMON_FIELDS | 
| - | 
| -    const xmlChar *use; | 
| -    int      has_use; | 
| -    const xmlChar *name; | 
| -    int      has_name; | 
| -    const xmlChar *ns; | 
| -    const xmlChar *nsPrefix; | 
| -    int      has_ns; | 
| -}; | 
| - | 
| -/** | 
| - * xsltStyleItemAttribute: | 
| - * | 
| - * <!-- Category: instruction --> | 
| - * <xsl:attribute | 
| - *  name = { qname } | 
| - *  namespace = { uri-reference }> | 
| - *  <!-- Content: template --> | 
| - * </xsl:attribute> | 
| - */ | 
| -typedef struct _xsltStyleItemAttribute xsltStyleItemAttribute; | 
| -typedef xsltStyleItemAttribute *xsltStyleItemAttributePtr; | 
| - | 
| -struct _xsltStyleItemAttribute { | 
| -    XSLT_ITEM_COMMON_FIELDS | 
| -    const xmlChar *name; | 
| -    int      has_name; | 
| -    const xmlChar *ns; | 
| -    const xmlChar *nsPrefix; | 
| -    int      has_ns; | 
| -}; | 
| - | 
| -/** | 
| - * xsltStyleItemText: | 
| - * | 
| - * <!-- Category: instruction --> | 
| - * <xsl:text | 
| - *  disable-output-escaping = "yes" | "no"> | 
| - *  <!-- Content: #PCDATA --> | 
| - * </xsl:text> | 
| - */ | 
| -typedef struct _xsltStyleItemText xsltStyleItemText; | 
| -typedef xsltStyleItemText *xsltStyleItemTextPtr; | 
| - | 
| -struct _xsltStyleItemText { | 
| -    XSLT_ITEM_COMMON_FIELDS | 
| -    int      noescape;		/* text */ | 
| -}; | 
| - | 
| -/** | 
| - * xsltStyleItemComment: | 
| - * | 
| - * <!-- Category: instruction --> | 
| - *  <xsl:comment> | 
| - *  <!-- Content: template --> | 
| - * </xsl:comment> | 
| - */ | 
| -typedef xsltStyleBasicEmptyItem xsltStyleItemComment; | 
| -typedef xsltStyleItemComment *xsltStyleItemCommentPtr; | 
| - | 
| -/** | 
| - * xsltStyleItemPI: | 
| - * | 
| - * <!-- Category: instruction --> | 
| - *  <xsl:processing-instruction | 
| - *  name = { ncname }> | 
| - *  <!-- Content: template --> | 
| - * </xsl:processing-instruction> | 
| - */ | 
| -typedef struct _xsltStyleItemPI xsltStyleItemPI; | 
| -typedef xsltStyleItemPI *xsltStyleItemPIPtr; | 
| - | 
| -struct _xsltStyleItemPI { | 
| -    XSLT_ITEM_COMMON_FIELDS | 
| -    const xmlChar *name; | 
| -    int      has_name; | 
| -}; | 
| - | 
| -/** | 
| - * xsltStyleItemApplyImports: | 
| - * | 
| - * <!-- Category: instruction --> | 
| - * <xsl:apply-imports /> | 
| - */ | 
| -typedef xsltStyleBasicEmptyItem xsltStyleItemApplyImports; | 
| -typedef xsltStyleItemApplyImports *xsltStyleItemApplyImportsPtr; | 
| - | 
| -/** | 
| - * xsltStyleItemApplyTemplates: | 
| - * | 
| - * <!-- Category: instruction --> | 
| - *  <xsl:apply-templates | 
| - *  select = node-set-expression | 
| - *  mode = qname> | 
| - *  <!-- Content: (xsl:sort | xsl:with-param)* --> | 
| - * </xsl:apply-templates> | 
| - */ | 
| -typedef struct _xsltStyleItemApplyTemplates xsltStyleItemApplyTemplates; | 
| -typedef xsltStyleItemApplyTemplates *xsltStyleItemApplyTemplatesPtr; | 
| - | 
| -struct _xsltStyleItemApplyTemplates { | 
| -    XSLT_ITEM_COMMON_FIELDS | 
| - | 
| -    const xmlChar *mode;	/* apply-templates */ | 
| -    const xmlChar *modeURI;	/* apply-templates */ | 
| -    const xmlChar *select;	/* sort, copy-of, value-of, apply-templates */ | 
| -    xmlXPathCompExprPtr comp;	/* a precompiled XPath expression */ | 
| -    /* TODO: with-params */ | 
| -}; | 
| - | 
| -/** | 
| - * xsltStyleItemCallTemplate: | 
| - * | 
| - * <!-- Category: instruction --> | 
| - *  <xsl:call-template | 
| - *  name = qname> | 
| - *  <!-- Content: xsl:with-param* --> | 
| - * </xsl:call-template> | 
| - */ | 
| -typedef struct _xsltStyleItemCallTemplate xsltStyleItemCallTemplate; | 
| -typedef xsltStyleItemCallTemplate *xsltStyleItemCallTemplatePtr; | 
| - | 
| -struct _xsltStyleItemCallTemplate { | 
| -    XSLT_ITEM_COMMON_FIELDS | 
| - | 
| -    xsltTemplatePtr templ;	/* call-template */ | 
| -    const xmlChar *name;	/* element, attribute, pi */ | 
| -    int      has_name;		/* element, attribute, pi */ | 
| -    const xmlChar *ns;		/* element */ | 
| -    int      has_ns;		/* element */ | 
| -    /* TODO: with-params */ | 
| -}; | 
| - | 
| -/** | 
| - * xsltStyleItemCopy: | 
| - * | 
| - * <!-- Category: instruction --> | 
| - * <xsl:copy | 
| - *  use-attribute-sets = qnames> | 
| - *  <!-- Content: template --> | 
| - * </xsl:copy> | 
| - */ | 
| -typedef struct _xsltStyleItemCopy xsltStyleItemCopy; | 
| -typedef xsltStyleItemCopy *xsltStyleItemCopyPtr; | 
| - | 
| -struct _xsltStyleItemCopy { | 
| -   XSLT_ITEM_COMMON_FIELDS | 
| -    const xmlChar *use;		/* copy, element */ | 
| -    int      has_use;		/* copy, element */ | 
| -}; | 
| - | 
| -/** | 
| - * xsltStyleItemIf: | 
| - * | 
| - * <!-- Category: instruction --> | 
| - *  <xsl:if | 
| - *  test = boolean-expression> | 
| - *  <!-- Content: template --> | 
| - * </xsl:if> | 
| - */ | 
| -typedef struct _xsltStyleItemIf xsltStyleItemIf; | 
| -typedef xsltStyleItemIf *xsltStyleItemIfPtr; | 
| - | 
| -struct _xsltStyleItemIf { | 
| -    XSLT_ITEM_COMMON_FIELDS | 
| - | 
| -    const xmlChar *test;	/* if */ | 
| -    xmlXPathCompExprPtr comp;	/* a precompiled XPath expression */ | 
| -}; | 
| - | 
| - | 
| -/** | 
| - * xsltStyleItemCopyOf: | 
| - * | 
| - * <!-- Category: instruction --> | 
| - * <xsl:copy-of | 
| - *  select = expression /> | 
| - */ | 
| -typedef xsltStyleBasicExpressionItem xsltStyleItemCopyOf; | 
| -typedef xsltStyleItemCopyOf *xsltStyleItemCopyOfPtr; | 
| - | 
| -/** | 
| - * xsltStyleItemValueOf: | 
| - * | 
| - * <!-- Category: instruction --> | 
| - * <xsl:value-of | 
| - *  select = string-expression | 
| - *  disable-output-escaping = "yes" | "no" /> | 
| - */ | 
| -typedef struct _xsltStyleItemValueOf xsltStyleItemValueOf; | 
| -typedef xsltStyleItemValueOf *xsltStyleItemValueOfPtr; | 
| - | 
| -struct _xsltStyleItemValueOf { | 
| -    XSLT_ITEM_COMMON_FIELDS | 
| - | 
| -    const xmlChar *select; | 
| -    xmlXPathCompExprPtr comp;	/* a precompiled XPath expression */ | 
| -    int      noescape; | 
| -}; | 
| - | 
| -/** | 
| - * xsltStyleItemNumber: | 
| - * | 
| - * <!-- Category: instruction --> | 
| - *  <xsl:number | 
| - *  level = "single" | "multiple" | "any" | 
| - *  count = pattern | 
| - *  from = pattern | 
| - *  value = number-expression | 
| - *  format = { string } | 
| - *  lang = { nmtoken } | 
| - *  letter-value = { "alphabetic" | "traditional" } | 
| - *  grouping-separator = { char } | 
| - *  grouping-size = { number } /> | 
| - */ | 
| -typedef struct _xsltStyleItemNumber xsltStyleItemNumber; | 
| -typedef xsltStyleItemNumber *xsltStyleItemNumberPtr; | 
| - | 
| -struct _xsltStyleItemNumber { | 
| -    XSLT_ITEM_COMMON_FIELDS | 
| -    xsltNumberData numdata;	/* number */ | 
| -}; | 
| - | 
| -/** | 
| - * xsltStyleItemChoose: | 
| - * | 
| - * <!-- Category: instruction --> | 
| - *  <xsl:choose> | 
| - *  <!-- Content: (xsl:when+, xsl:otherwise?) --> | 
| - * </xsl:choose> | 
| - */ | 
| -typedef xsltStyleBasicEmptyItem xsltStyleItemChoose; | 
| -typedef xsltStyleItemChoose *xsltStyleItemChoosePtr; | 
| - | 
| -/** | 
| - * xsltStyleItemFallback: | 
| - * | 
| - * <!-- Category: instruction --> | 
| - *  <xsl:fallback> | 
| - *  <!-- Content: template --> | 
| - * </xsl:fallback> | 
| - */ | 
| -typedef xsltStyleBasicEmptyItem xsltStyleItemFallback; | 
| -typedef xsltStyleItemFallback *xsltStyleItemFallbackPtr; | 
| - | 
| -/** | 
| - * xsltStyleItemForEach: | 
| - * | 
| - * <!-- Category: instruction --> | 
| - * <xsl:for-each | 
| - *   select = node-set-expression> | 
| - *   <!-- Content: (xsl:sort*, template) --> | 
| - * </xsl:for-each> | 
| - */ | 
| -typedef xsltStyleBasicExpressionItem xsltStyleItemForEach; | 
| -typedef xsltStyleItemForEach *xsltStyleItemForEachPtr; | 
| - | 
| -/** | 
| - * xsltStyleItemMessage: | 
| - * | 
| - * <!-- Category: instruction --> | 
| - * <xsl:message | 
| - *   terminate = "yes" | "no"> | 
| - *   <!-- Content: template --> | 
| - * </xsl:message> | 
| - */ | 
| -typedef struct _xsltStyleItemMessage xsltStyleItemMessage; | 
| -typedef xsltStyleItemMessage *xsltStyleItemMessagePtr; | 
| - | 
| -struct _xsltStyleItemMessage { | 
| -    XSLT_ITEM_COMMON_FIELDS | 
| -    int terminate; | 
| -}; | 
| - | 
| -/** | 
| - * xsltStyleItemDocument: | 
| - * | 
| - * NOTE: This is not an instruction of XSLT 1.0. | 
| - */ | 
| -typedef struct _xsltStyleItemDocument xsltStyleItemDocument; | 
| -typedef xsltStyleItemDocument *xsltStyleItemDocumentPtr; | 
| - | 
| -struct _xsltStyleItemDocument { | 
| -    XSLT_ITEM_COMMON_FIELDS | 
| -    int      ver11;		/* assigned: in xsltDocumentComp; | 
| -                                  read: nowhere; | 
| -                                  TODO: Check if we need. */ | 
| -    const xmlChar *filename;	/* document URL */ | 
| -    int has_filename; | 
| -}; | 
| - | 
| -/************************************************************************ | 
| - *									* | 
| - * Non-instructions (actually properties of instructions/declarations)  * | 
| - *									* | 
| - ************************************************************************/ | 
| - | 
| -/** | 
| - * xsltStyleBasicItemVariable: | 
| - * | 
| - * Basic struct for xsl:variable, xsl:param and xsl:with-param. | 
| - * It's currently important to have equal fields, since | 
| - * xsltParseStylesheetCallerParam() is used with xsl:with-param from | 
| - * the xslt side and with xsl:param from the exslt side (in | 
| - * exsltFuncFunctionFunction()). | 
| - * | 
| - * FUTURE NOTE: In XSLT 2.0 xsl:param, xsl:variable and xsl:with-param | 
| - *   have additional different fields. | 
| - */ | 
| -typedef struct _xsltStyleBasicItemVariable xsltStyleBasicItemVariable; | 
| -typedef xsltStyleBasicItemVariable *xsltStyleBasicItemVariablePtr; | 
| - | 
| -struct _xsltStyleBasicItemVariable { | 
| -    XSLT_ITEM_COMMON_FIELDS | 
| - | 
| -    const xmlChar *select; | 
| -    xmlXPathCompExprPtr comp; | 
| - | 
| -    const xmlChar *name; | 
| -    int      has_name; | 
| -    const xmlChar *ns; | 
| -    int      has_ns; | 
| -}; | 
| - | 
| -/** | 
| - * xsltStyleItemVariable: | 
| - * | 
| - * <!-- Category: top-level-element --> | 
| - * <xsl:param | 
| - *   name = qname | 
| - *   select = expression> | 
| - *   <!-- Content: template --> | 
| - * </xsl:param> | 
| - */ | 
| -typedef xsltStyleBasicItemVariable xsltStyleItemVariable; | 
| -typedef xsltStyleItemVariable *xsltStyleItemVariablePtr; | 
| - | 
| -/** | 
| - * xsltStyleItemParam: | 
| - * | 
| - * <!-- Category: top-level-element --> | 
| - * <xsl:param | 
| - *   name = qname | 
| - *   select = expression> | 
| - *   <!-- Content: template --> | 
| - * </xsl:param> | 
| - */ | 
| -typedef struct _xsltStyleItemParam xsltStyleItemParam; | 
| -typedef xsltStyleItemParam *xsltStyleItemParamPtr; | 
| - | 
| -struct _xsltStyleItemParam { | 
| -    XSLT_ITEM_COMMON_FIELDS | 
| - | 
| -    const xmlChar *select; | 
| -    xmlXPathCompExprPtr comp; | 
| - | 
| -    const xmlChar *name; | 
| -    int      has_name; | 
| -    const xmlChar *ns; | 
| -    int      has_ns; | 
| -}; | 
| - | 
| -/** | 
| - * xsltStyleItemWithParam: | 
| - * | 
| - * <xsl:with-param | 
| - *  name = qname | 
| - *  select = expression> | 
| - *  <!-- Content: template --> | 
| - * </xsl:with-param> | 
| - */ | 
| -typedef xsltStyleBasicItemVariable xsltStyleItemWithParam; | 
| -typedef xsltStyleItemWithParam *xsltStyleItemWithParamPtr; | 
| - | 
| -/** | 
| - * xsltStyleItemSort: | 
| - * | 
| - * Reflects the XSLT xsl:sort item. | 
| - * Allowed parents: xsl:apply-templates, xsl:for-each | 
| - * <xsl:sort | 
| - *   select = string-expression | 
| - *   lang = { nmtoken } | 
| - *   data-type = { "text" | "number" | qname-but-not-ncname } | 
| - *   order = { "ascending" | "descending" } | 
| - *   case-order = { "upper-first" | "lower-first" } /> | 
| - */ | 
| -typedef struct _xsltStyleItemSort xsltStyleItemSort; | 
| -typedef xsltStyleItemSort *xsltStyleItemSortPtr; | 
| - | 
| -struct _xsltStyleItemSort { | 
| -    XSLT_ITEM_COMMON_FIELDS | 
| - | 
| -    const xmlChar *stype;       /* sort */ | 
| -    int      has_stype;		/* sort */ | 
| -    int      number;		/* sort */ | 
| -    const xmlChar *order;	/* sort */ | 
| -    int      has_order;		/* sort */ | 
| -    int      descending;	/* sort */ | 
| -    const xmlChar *lang;	/* sort */ | 
| -    int      has_lang;		/* sort */ | 
| -    xsltLocale locale;		/* sort */ | 
| -    const xmlChar *case_order;	/* sort */ | 
| -    int      lower_first;	/* sort */ | 
| - | 
| -    const xmlChar *use; | 
| -    int      has_use; | 
| - | 
| -    const xmlChar *select;	/* sort, copy-of, value-of, apply-templates */ | 
| - | 
| -    xmlXPathCompExprPtr comp;	/* a precompiled XPath expression */ | 
| -}; | 
| - | 
| - | 
| -/** | 
| - * xsltStyleItemWhen: | 
| - * | 
| - * <xsl:when | 
| - *   test = boolean-expression> | 
| - *   <!-- Content: template --> | 
| - * </xsl:when> | 
| - * Allowed parent: xsl:choose | 
| - */ | 
| -typedef struct _xsltStyleItemWhen xsltStyleItemWhen; | 
| -typedef xsltStyleItemWhen *xsltStyleItemWhenPtr; | 
| - | 
| -struct _xsltStyleItemWhen { | 
| -    XSLT_ITEM_COMMON_FIELDS | 
| - | 
| -    const xmlChar *test; | 
| -    xmlXPathCompExprPtr comp; | 
| -}; | 
| - | 
| -/** | 
| - * xsltStyleItemOtherwise: | 
| - * | 
| - * Allowed parent: xsl:choose | 
| - * <xsl:otherwise> | 
| - *   <!-- Content: template --> | 
| - * </xsl:otherwise> | 
| - */ | 
| -typedef struct _xsltStyleItemOtherwise xsltStyleItemOtherwise; | 
| -typedef xsltStyleItemOtherwise *xsltStyleItemOtherwisePtr; | 
| - | 
| -struct _xsltStyleItemOtherwise { | 
| -    XSLT_ITEM_COMMON_FIELDS | 
| -}; | 
| - | 
| -typedef struct _xsltStyleItemInclude xsltStyleItemInclude; | 
| -typedef xsltStyleItemInclude *xsltStyleItemIncludePtr; | 
| - | 
| -struct _xsltStyleItemInclude { | 
| -    XSLT_ITEM_COMMON_FIELDS | 
| -    xsltDocumentPtr include; | 
| -}; | 
| - | 
| -/************************************************************************ | 
| - *									* | 
| - *  XSLT elements in forwards-compatible mode                           * | 
| - *									* | 
| - ************************************************************************/ | 
| - | 
| -typedef struct _xsltStyleItemUknown xsltStyleItemUknown; | 
| -typedef xsltStyleItemUknown *xsltStyleItemUknownPtr; | 
| -struct _xsltStyleItemUknown { | 
| -    XSLT_ITEM_COMMON_FIELDS | 
| -}; | 
| - | 
| - | 
| -/************************************************************************ | 
| - *									* | 
| - *  Extension elements                                                  * | 
| - *									* | 
| - ************************************************************************/ | 
| - | 
| -/* | 
| - * xsltStyleItemExtElement: | 
| - * | 
| - * Reflects extension elements. | 
| - * | 
| - * NOTE: Due to the fact that the structure xsltElemPreComp is most | 
| - * probably already heavily in use out there by users, so we cannot | 
| - * easily change it, we'll create an intermediate structure which will | 
| - * hold an xsltElemPreCompPtr. | 
| - * BIG NOTE: The only problem I see here is that the user processes the | 
| - *  content of the stylesheet tree, possibly he'll lookup the node->psvi | 
| - *  fields in order to find subsequent extension functions. | 
| - *  In this case, the user's code will break, since the node->psvi | 
| - *  field will hold now the xsltStyleItemExtElementPtr and not | 
| - *  the xsltElemPreCompPtr. | 
| - *  However the place where the structure is anchored in the node-tree, | 
| - *  namely node->psvi, has beed already once been moved from node->_private | 
| - *  to node->psvi, so we have a precedent here, which, I think, should allow | 
| - *  us to change such semantics without headaches. | 
| - */ | 
| -typedef struct _xsltStyleItemExtElement xsltStyleItemExtElement; | 
| -typedef xsltStyleItemExtElement *xsltStyleItemExtElementPtr; | 
| -struct _xsltStyleItemExtElement { | 
| -    XSLT_ITEM_COMMON_FIELDS | 
| -    xsltElemPreCompPtr item; | 
| -}; | 
| - | 
| -/************************************************************************ | 
| - *									* | 
| - *  Literal result elements                                             * | 
| - *									* | 
| - ************************************************************************/ | 
| - | 
| -typedef struct _xsltEffectiveNs xsltEffectiveNs; | 
| -typedef xsltEffectiveNs *xsltEffectiveNsPtr; | 
| -struct _xsltEffectiveNs { | 
| -    xsltEffectiveNsPtr nextInStore; /* storage next */ | 
| -    xsltEffectiveNsPtr next; /* next item in the list */ | 
| -    const xmlChar *prefix; | 
| -    const xmlChar *nsName; | 
| -    /* | 
| -    * Indicates if eclared on the literal result element; dunno if really | 
| -    * needed. | 
| -    */ | 
| -    int holdByElem; | 
| -}; | 
| - | 
| -/* | 
| - * Info for literal result elements. | 
| - * This will be set on the elem->psvi field and will be | 
| - * shared by literal result elements, which have the same | 
| - * excluded result namespaces; i.e., this *won't* be created uniquely | 
| - * for every literal result element. | 
| - */ | 
| -typedef struct _xsltStyleItemLRElementInfo xsltStyleItemLRElementInfo; | 
| -typedef xsltStyleItemLRElementInfo *xsltStyleItemLRElementInfoPtr; | 
| -struct _xsltStyleItemLRElementInfo { | 
| -    XSLT_ITEM_COMMON_FIELDS | 
| -    /* | 
| -    * @effectiveNs is the set of effective ns-nodes | 
| -    *  on the literal result element, which will be added to the result | 
| -    *  element if not already existing in the result tree. | 
| -    *  This means that excluded namespaces (via exclude-result-prefixes, | 
| -    *  extension-element-prefixes and the XSLT namespace) not added | 
| -    *  to the set. | 
| -    *  Namespace-aliasing was applied on the @effectiveNs. | 
| -    */ | 
| -    xsltEffectiveNsPtr effectiveNs; | 
| - | 
| -}; | 
| - | 
| -#ifdef XSLT_REFACTORED | 
| - | 
| -typedef struct _xsltNsAlias xsltNsAlias; | 
| -typedef xsltNsAlias *xsltNsAliasPtr; | 
| -struct _xsltNsAlias { | 
| -    xsltNsAliasPtr next; /* next in the list */ | 
| -    xmlNsPtr literalNs; | 
| -    xmlNsPtr targetNs; | 
| -    xmlDocPtr docOfTargetNs; | 
| -}; | 
| -#endif | 
| - | 
| -#ifdef XSLT_REFACTORED_XSLT_NSCOMP | 
| - | 
| -typedef struct _xsltNsMap xsltNsMap; | 
| -typedef xsltNsMap *xsltNsMapPtr; | 
| -struct _xsltNsMap { | 
| -    xsltNsMapPtr next; /* next in the list */ | 
| -    xmlDocPtr doc; | 
| -    xmlNodePtr elem; /* the element holding the ns-decl */ | 
| -    xmlNsPtr ns; /* the xmlNs structure holding the XML namespace name */ | 
| -    const xmlChar *origNsName; /* the original XML namespace name */ | 
| -    const xmlChar *newNsName; /* the mapped XML namespace name */ | 
| -}; | 
| -#endif | 
| - | 
| -/************************************************************************ | 
| - *									* | 
| - *  Compile-time structures for *internal* use only                     * | 
| - *									* | 
| - ************************************************************************/ | 
| - | 
| -typedef struct _xsltPrincipalStylesheetData xsltPrincipalStylesheetData; | 
| -typedef xsltPrincipalStylesheetData *xsltPrincipalStylesheetDataPtr; | 
| - | 
| -typedef struct _xsltNsList xsltNsList; | 
| -typedef xsltNsList *xsltNsListPtr; | 
| -struct _xsltNsList { | 
| -    xsltNsListPtr next; /* next in the list */ | 
| -    xmlNsPtr ns; | 
| -}; | 
| - | 
| -/* | 
| -* xsltVarInfo: | 
| -* | 
| -* Used at compilation time for parameters and variables. | 
| -*/ | 
| -typedef struct _xsltVarInfo xsltVarInfo; | 
| -typedef xsltVarInfo *xsltVarInfoPtr; | 
| -struct _xsltVarInfo { | 
| -    xsltVarInfoPtr next; /* next in the list */ | 
| -    xsltVarInfoPtr prev; | 
| -    int depth; /* the depth in the tree */ | 
| -    const xmlChar *name; | 
| -    const xmlChar *nsName; | 
| -}; | 
| - | 
| -/** | 
| - * xsltCompilerNodeInfo: | 
| - * | 
| - * Per-node information during compile-time. | 
| - */ | 
| -typedef struct _xsltCompilerNodeInfo xsltCompilerNodeInfo; | 
| -typedef xsltCompilerNodeInfo *xsltCompilerNodeInfoPtr; | 
| -struct _xsltCompilerNodeInfo { | 
| -    xsltCompilerNodeInfoPtr next; | 
| -    xsltCompilerNodeInfoPtr prev; | 
| -    xmlNodePtr node; | 
| -    int depth; | 
| -    xsltTemplatePtr templ;   /* The owning template */ | 
| -    int category;	     /* XSLT element, LR-element or | 
| -                                extension element */ | 
| -    xsltStyleType type; | 
| -    xsltElemPreCompPtr item; /* The compiled information */ | 
| -    /* The current in-scope namespaces */ | 
| -    xsltNsListContainerPtr inScopeNs; | 
| -    /* The current excluded result namespaces */ | 
| -    xsltPointerListPtr exclResultNs; | 
| -    /* The current extension instruction namespaces */ | 
| -    xsltPointerListPtr extElemNs; | 
| - | 
| -    /* The current info for literal result elements. */ | 
| -    xsltStyleItemLRElementInfoPtr litResElemInfo; | 
| -    /* | 
| -    * Set to 1 if in-scope namespaces changed, | 
| -    *  or excluded result namespaces changed, | 
| -    *  or extension element namespaces changed. | 
| -    * This will trigger creation of new infos | 
| -    *  for literal result elements. | 
| -    */ | 
| -    int nsChanged; | 
| -    int preserveWhitespace; | 
| -    int stripWhitespace; | 
| -    int isRoot; /* whether this is the stylesheet's root node */ | 
| -    int forwardsCompat; /* whether forwards-compatible mode is enabled */ | 
| -    /* whether the content of an extension element was processed */ | 
| -    int extContentHandled; | 
| -    /* the type of the current child */ | 
| -    xsltStyleType curChildType; | 
| -}; | 
| - | 
| -/** | 
| - * XSLT_CCTXT: | 
| - * | 
| - * get pointer to compiler context | 
| - */ | 
| -#define XSLT_CCTXT(style) ((xsltCompilerCtxtPtr) style->compCtxt) | 
| - | 
| -typedef enum { | 
| -    XSLT_ERROR_SEVERITY_ERROR = 0, | 
| -    XSLT_ERROR_SEVERITY_WARNING | 
| -} xsltErrorSeverityType; | 
| - | 
| -typedef struct _xsltCompilerCtxt xsltCompilerCtxt; | 
| -typedef xsltCompilerCtxt *xsltCompilerCtxtPtr; | 
| -struct _xsltCompilerCtxt { | 
| -    void *errorCtxt;            /* user specific error context */ | 
| -    /* | 
| -    * used for error/warning reports; e.g. XSLT_ERROR_SEVERITY_WARNING */ | 
| -    xsltErrorSeverityType errSeverity; | 
| -    int warnings;		/* TODO: number of warnings found at | 
| -                                   compilation */ | 
| -    int errors;			/* TODO: number of errors found at | 
| -                                   compilation */ | 
| -    xmlDictPtr dict; | 
| -    xsltStylesheetPtr style; | 
| -    int simplified; /* whether this is a simplified stylesheet */ | 
| -    /* TODO: structured/unstructured error contexts. */ | 
| -    int depth; /* Current depth of processing */ | 
| - | 
| -    xsltCompilerNodeInfoPtr inode; | 
| -    xsltCompilerNodeInfoPtr inodeList; | 
| -    xsltCompilerNodeInfoPtr inodeLast; | 
| -    xsltPointerListPtr tmpList; /* Used for various purposes */ | 
| -    /* | 
| -    * The XSLT version as specified by the stylesheet's root element. | 
| -    */ | 
| -    int isInclude; | 
| -    int hasForwardsCompat; /* whether forwards-compatible mode was used | 
| -			     in a parsing episode */ | 
| -    int maxNodeInfos; /* TEMP TODO: just for the interest */ | 
| -    int maxLREs;  /* TEMP TODO: just for the interest */ | 
| -    /* | 
| -    * In order to keep the old behaviour, applying strict rules of | 
| -    * the spec can be turned off. This has effect only on special | 
| -    * mechanisms like whitespace-stripping in the stylesheet. | 
| -    */ | 
| -    int strict; | 
| -    xsltPrincipalStylesheetDataPtr psData; | 
| -#ifdef XSLT_REFACTORED_XPATHCOMP | 
| -    xmlXPathContextPtr xpathCtxt; | 
| -#endif | 
| -    xsltStyleItemUknownPtr unknownItem; | 
| -    int hasNsAliases; /* Indicator if there was an xsl:namespace-alias. */ | 
| -    xsltNsAliasPtr nsAliases; | 
| -    xsltVarInfoPtr ivars; /* Storage of local in-scope variables/params. */ | 
| -    xsltVarInfoPtr ivar; /* topmost local variable/param. */ | 
| -}; | 
| - | 
| -#else /* XSLT_REFACTORED */ | 
| -/* | 
| -* The old structures before refactoring. | 
| -*/ | 
| - | 
| -/** | 
| - * _xsltStylePreComp: | 
| - * | 
| - * The in-memory structure corresponding to XSLT stylesheet constructs | 
| - * precomputed data. | 
| - */ | 
| -struct _xsltStylePreComp { | 
| -    xsltElemPreCompPtr next;	/* chained list */ | 
| -    xsltStyleType type;		/* type of the element */ | 
| -    xsltTransformFunction func; /* handling function */ | 
| -    xmlNodePtr inst;		/* the instruction */ | 
| - | 
| -    /* | 
| -     * Pre computed values. | 
| -     */ | 
| - | 
| -    const xmlChar *stype;       /* sort */ | 
| -    int      has_stype;		/* sort */ | 
| -    int      number;		/* sort */ | 
| -    const xmlChar *order;	/* sort */ | 
| -    int      has_order;		/* sort */ | 
| -    int      descending;	/* sort */ | 
| -    const xmlChar *lang;	/* sort */ | 
| -    int      has_lang;		/* sort */ | 
| -    xsltLocale locale;		/* sort */ | 
| -    const xmlChar *case_order;	/* sort */ | 
| -    int      lower_first;	/* sort */ | 
| - | 
| -    const xmlChar *use;		/* copy, element */ | 
| -    int      has_use;		/* copy, element */ | 
| - | 
| -    int      noescape;		/* text */ | 
| - | 
| -    const xmlChar *name;	/* element, attribute, pi */ | 
| -    int      has_name;		/* element, attribute, pi */ | 
| -    const xmlChar *ns;		/* element */ | 
| -    int      has_ns;		/* element */ | 
| - | 
| -    const xmlChar *mode;	/* apply-templates */ | 
| -    const xmlChar *modeURI;	/* apply-templates */ | 
| - | 
| -    const xmlChar *test;	/* if */ | 
| - | 
| -    xsltTemplatePtr templ;	/* call-template */ | 
| - | 
| -    const xmlChar *select;	/* sort, copy-of, value-of, apply-templates */ | 
| - | 
| -    int      ver11;		/* document */ | 
| -    const xmlChar *filename;	/* document URL */ | 
| -    int      has_filename;	/* document */ | 
| - | 
| -    xsltNumberData numdata;	/* number */ | 
| - | 
| -    xmlXPathCompExprPtr comp;	/* a precompiled XPath expression */ | 
| -    xmlNsPtr *nsList;		/* the namespaces in scope */ | 
| -    int nsNr;			/* the number of namespaces in scope */ | 
| -}; | 
| - | 
| -#endif /* XSLT_REFACTORED */ | 
| - | 
| - | 
| -/* | 
| - * The in-memory structure corresponding to an XSLT Variable | 
| - * or Param. | 
| - */ | 
| -typedef struct _xsltStackElem xsltStackElem; | 
| -typedef xsltStackElem *xsltStackElemPtr; | 
| -struct _xsltStackElem { | 
| -    struct _xsltStackElem *next;/* chained list */ | 
| -    xsltStylePreCompPtr comp;   /* the compiled form */ | 
| -    int computed;		/* was the evaluation done */ | 
| -    const xmlChar *name;	/* the local part of the name QName */ | 
| -    const xmlChar *nameURI;	/* the URI part of the name QName */ | 
| -    const xmlChar *select;	/* the eval string */ | 
| -    xmlNodePtr tree;		/* the sequence constructor if no eval | 
| -				    string or the location */ | 
| -    xmlXPathObjectPtr value;	/* The value if computed */ | 
| -    xmlDocPtr fragment;		/* The Result Tree Fragments (needed for XSLT 1.0) | 
| -				   which are bound to the variable's lifetime. */ | 
| -    int level;                  /* the depth in the tree; | 
| -                                   -1 if persistent (e.g. a given xsl:with-param) */ | 
| -    xsltTransformContextPtr context; /* The transformation context; needed to cache | 
| -                                        the variables */ | 
| -    int flags; | 
| -}; | 
| - | 
| -#ifdef XSLT_REFACTORED | 
| - | 
| -struct _xsltPrincipalStylesheetData { | 
| -    /* | 
| -    * Namespace dictionary for ns-prefixes and ns-names: | 
| -    * TODO: Shared between stylesheets, and XPath mechanisms. | 
| -    *   Not used yet. | 
| -    */ | 
| -    xmlDictPtr namespaceDict; | 
| -    /* | 
| -    * Global list of in-scope namespaces. | 
| -    */ | 
| -    xsltPointerListPtr inScopeNamespaces; | 
| -    /* | 
| -    * Global list of information for [xsl:]excluded-result-prefixes. | 
| -    */ | 
| -    xsltPointerListPtr exclResultNamespaces; | 
| -    /* | 
| -    * Global list of information for [xsl:]extension-element-prefixes. | 
| -    */ | 
| -    xsltPointerListPtr extElemNamespaces; | 
| -    xsltEffectiveNsPtr effectiveNs; | 
| -#ifdef XSLT_REFACTORED_XSLT_NSCOMP | 
| -    /* | 
| -    * Namespace name map to get rid of string comparison of namespace names. | 
| -    */ | 
| -    xsltNsMapPtr nsMap; | 
| -#endif | 
| -}; | 
| - | 
| - | 
| -#endif | 
| -/* | 
| - * Note that we added a @compCtxt field to anchor an stylesheet compilation | 
| - * context, since, due to historical reasons, various compile-time function | 
| - * take only the stylesheet as argument and not a compilation context. | 
| - */ | 
| -struct _xsltStylesheet { | 
| -    /* | 
| -     * The stylesheet import relation is kept as a tree. | 
| -     */ | 
| -    struct _xsltStylesheet *parent; | 
| -    struct _xsltStylesheet *next; | 
| -    struct _xsltStylesheet *imports; | 
| - | 
| -    xsltDocumentPtr docList;		/* the include document list */ | 
| - | 
| -    /* | 
| -     * General data on the style sheet document. | 
| -     */ | 
| -    xmlDocPtr doc;		/* the parsed XML stylesheet */ | 
| -    xmlHashTablePtr stripSpaces;/* the hash table of the strip-space and | 
| -				   preserve space elements */ | 
| -    int             stripAll;	/* strip-space * (1) preserve-space * (-1) */ | 
| -    xmlHashTablePtr cdataSection;/* the hash table of the cdata-section */ | 
| - | 
| -    /* | 
| -     * Global variable or parameters. | 
| -     */ | 
| -    xsltStackElemPtr variables; /* linked list of param and variables */ | 
| - | 
| -    /* | 
| -     * Template descriptions. | 
| -     */ | 
| -    xsltTemplatePtr templates;	/* the ordered list of templates */ | 
| -    void *templatesHash;	/* hash table or wherever compiled templates | 
| -				   informations are stored */ | 
| -    void *rootMatch;		/* template based on / */ | 
| -    void *keyMatch;		/* template based on key() */ | 
| -    void *elemMatch;		/* template based on * */ | 
| -    void *attrMatch;		/* template based on @* */ | 
| -    void *parentMatch;		/* template based on .. */ | 
| -    void *textMatch;		/* template based on text() */ | 
| -    void *piMatch;		/* template based on processing-instruction() */ | 
| -    void *commentMatch;		/* template based on comment() */ | 
| - | 
| -    /* | 
| -     * Namespace aliases. | 
| -     * NOTE: Not used in the refactored code. | 
| -     */ | 
| -    xmlHashTablePtr nsAliases;	/* the namespace alias hash tables */ | 
| - | 
| -    /* | 
| -     * Attribute sets. | 
| -     */ | 
| -    xmlHashTablePtr attributeSets;/* the attribute sets hash tables */ | 
| - | 
| -    /* | 
| -     * Namespaces. | 
| -     * TODO: Eliminate this. | 
| -     */ | 
| -    xmlHashTablePtr nsHash;     /* the set of namespaces in use: | 
| -                                   ATTENTION: This is used for | 
| -                                   execution of XPath expressions; unfortunately | 
| -                                   it restricts the stylesheet to have distinct | 
| -                                   prefixes. | 
| -				   TODO: We need to get rid of this. | 
| -				 */ | 
| -    void           *nsDefs;     /* ATTENTION TODO: This is currently used to store | 
| -				   xsltExtDefPtr (in extensions.c) and | 
| -                                   *not* xmlNsPtr. | 
| -				 */ | 
| - | 
| -    /* | 
| -     * Key definitions. | 
| -     */ | 
| -    void *keys;			/* key definitions */ | 
| - | 
| -    /* | 
| -     * Output related stuff. | 
| -     */ | 
| -    xmlChar *method;		/* the output method */ | 
| -    xmlChar *methodURI;		/* associated namespace if any */ | 
| -    xmlChar *version;		/* version string */ | 
| -    xmlChar *encoding;		/* encoding string */ | 
| -    int omitXmlDeclaration;     /* omit-xml-declaration = "yes" | "no" */ | 
| - | 
| -    /* | 
| -     * Number formatting. | 
| -     */ | 
| -    xsltDecimalFormatPtr decimalFormat; | 
| -    int standalone;             /* standalone = "yes" | "no" */ | 
| -    xmlChar *doctypePublic;     /* doctype-public string */ | 
| -    xmlChar *doctypeSystem;     /* doctype-system string */ | 
| -    int indent;			/* should output being indented */ | 
| -    xmlChar *mediaType;		/* media-type string */ | 
| - | 
| -    /* | 
| -     * Precomputed blocks. | 
| -     */ | 
| -    xsltElemPreCompPtr preComps;/* list of precomputed blocks */ | 
| -    int warnings;		/* number of warnings found at compilation */ | 
| -    int errors;			/* number of errors found at compilation */ | 
| - | 
| -    xmlChar  *exclPrefix;	/* last excluded prefixes */ | 
| -    xmlChar **exclPrefixTab;	/* array of excluded prefixes */ | 
| -    int       exclPrefixNr;	/* number of excluded prefixes in scope */ | 
| -    int       exclPrefixMax;	/* size of the array */ | 
| - | 
| -    void     *_private;		/* user defined data */ | 
| - | 
| -    /* | 
| -     * Extensions. | 
| -     */ | 
| -    xmlHashTablePtr extInfos;	/* the extension data */ | 
| -    int		    extrasNr;	/* the number of extras required */ | 
| - | 
| -    /* | 
| -     * For keeping track of nested includes | 
| -     */ | 
| -    xsltDocumentPtr includes;	/* points to last nested include */ | 
| - | 
| -    /* | 
| -     * dictionary: shared between stylesheet, context and documents. | 
| -     */ | 
| -    xmlDictPtr dict; | 
| -    /* | 
| -     * precompiled attribute value templates. | 
| -     */ | 
| -    void *attVTs; | 
| -    /* | 
| -     * if namespace-alias has an alias for the default stylesheet prefix | 
| -     * NOTE: Not used in the refactored code. | 
| -     */ | 
| -    const xmlChar *defaultAlias; | 
| -    /* | 
| -     * bypass pre-processing (already done) (used in imports) | 
| -     */ | 
| -    int nopreproc; | 
| -    /* | 
| -     * all document text strings were internalized | 
| -     */ | 
| -    int internalized; | 
| -    /* | 
| -     * Literal Result Element as Stylesheet c.f. section 2.3 | 
| -     */ | 
| -    int literal_result; | 
| -    /* | 
| -    * The principal stylesheet | 
| -    */ | 
| -    xsltStylesheetPtr principal; | 
| -#ifdef XSLT_REFACTORED | 
| -    /* | 
| -    * Compilation context used during compile-time. | 
| -    */ | 
| -    xsltCompilerCtxtPtr compCtxt; /* TODO: Change this to (void *). */ | 
| - | 
| -    xsltPrincipalStylesheetDataPtr principalData; | 
| -#endif | 
| -    /* | 
| -     * Forwards-compatible processing | 
| -     */ | 
| -    int forwards_compatible; | 
| - | 
| -    xmlHashTablePtr namedTemplates; /* hash table of named templates */ | 
| -}; | 
| - | 
| -typedef struct _xsltTransformCache xsltTransformCache; | 
| -typedef xsltTransformCache *xsltTransformCachePtr; | 
| -struct _xsltTransformCache { | 
| -    xmlDocPtr RVT; | 
| -    int nbRVT; | 
| -    xsltStackElemPtr stackItems; | 
| -    int nbStackItems; | 
| -#ifdef XSLT_DEBUG_PROFILE_CACHE | 
| -    int dbgCachedRVTs; | 
| -    int dbgReusedRVTs; | 
| -    int dbgCachedVars; | 
| -    int dbgReusedVars; | 
| -#endif | 
| -}; | 
| - | 
| -/* | 
| - * The in-memory structure corresponding to an XSLT Transformation. | 
| - */ | 
| -typedef enum { | 
| -    XSLT_OUTPUT_XML = 0, | 
| -    XSLT_OUTPUT_HTML, | 
| -    XSLT_OUTPUT_TEXT | 
| -} xsltOutputType; | 
| - | 
| -typedef enum { | 
| -    XSLT_STATE_OK = 0, | 
| -    XSLT_STATE_ERROR, | 
| -    XSLT_STATE_STOPPED | 
| -} xsltTransformState; | 
| - | 
| -struct _xsltTransformContext { | 
| -    xsltStylesheetPtr style;		/* the stylesheet used */ | 
| -    xsltOutputType type;		/* the type of output */ | 
| - | 
| -    xsltTemplatePtr  templ;		/* the current template */ | 
| -    int              templNr;		/* Nb of templates in the stack */ | 
| -    int              templMax;		/* Size of the templtes stack */ | 
| -    xsltTemplatePtr *templTab;		/* the template stack */ | 
| - | 
| -    xsltStackElemPtr  vars;		/* the current variable list */ | 
| -    int               varsNr;		/* Nb of variable list in the stack */ | 
| -    int               varsMax;		/* Size of the variable list stack */ | 
| -    xsltStackElemPtr *varsTab;		/* the variable list stack */ | 
| -    int               varsBase;		/* the var base for current templ */ | 
| - | 
| -    /* | 
| -     * Extensions | 
| -     */ | 
| -    xmlHashTablePtr   extFunctions;	/* the extension functions */ | 
| -    xmlHashTablePtr   extElements;	/* the extension elements */ | 
| -    xmlHashTablePtr   extInfos;		/* the extension data */ | 
| - | 
| -    const xmlChar *mode;		/* the current mode */ | 
| -    const xmlChar *modeURI;		/* the current mode URI */ | 
| - | 
| -    xsltDocumentPtr docList;		/* the document list */ | 
| - | 
| -    xsltDocumentPtr document;		/* the current source document; can be NULL if an RTF */ | 
| -    xmlNodePtr node;			/* the current node being processed */ | 
| -    xmlNodeSetPtr nodeList;		/* the current node list */ | 
| -    /* xmlNodePtr current;			the node */ | 
| - | 
| -    xmlDocPtr output;			/* the resulting document */ | 
| -    xmlNodePtr insert;			/* the insertion node */ | 
| - | 
| -    xmlXPathContextPtr xpathCtxt;	/* the XPath context */ | 
| -    xsltTransformState state;		/* the current state */ | 
| - | 
| -    /* | 
| -     * Global variables | 
| -     */ | 
| -    xmlHashTablePtr   globalVars;	/* the global variables and params */ | 
| - | 
| -    xmlNodePtr inst;			/* the instruction in the stylesheet */ | 
| - | 
| -    int xinclude;			/* should XInclude be processed */ | 
| - | 
| -    const char *      outputFile;	/* the output URI if known */ | 
| - | 
| -    int profile;                        /* is this run profiled */ | 
| -    long             prof;		/* the current profiled value */ | 
| -    int              profNr;		/* Nb of templates in the stack */ | 
| -    int              profMax;		/* Size of the templtaes stack */ | 
| -    long            *profTab;		/* the profile template stack */ | 
| - | 
| -    void            *_private;		/* user defined data */ | 
| - | 
| -    int              extrasNr;		/* the number of extras used */ | 
| -    int              extrasMax;		/* the number of extras allocated */ | 
| -    xsltRuntimeExtraPtr extras;		/* extra per runtime informations */ | 
| - | 
| -    xsltDocumentPtr  styleList;		/* the stylesheet docs list */ | 
| -    void                 * sec;		/* the security preferences if any */ | 
| - | 
| -    xmlGenericErrorFunc  error;		/* a specific error handler */ | 
| -    void              * errctx;		/* context for the error handler */ | 
| - | 
| -    xsltSortFunc      sortfunc;		/* a ctxt specific sort routine */ | 
| - | 
| -    /* | 
| -     * handling of temporary Result Value Tree | 
| -     * (XSLT 1.0 term: "Result Tree Fragment") | 
| -     */ | 
| -    xmlDocPtr       tmpRVT;		/* list of RVT without persistance */ | 
| -    xmlDocPtr       persistRVT;		/* list of persistant RVTs */ | 
| -    int             ctxtflags;          /* context processing flags */ | 
| - | 
| -    /* | 
| -     * Speed optimization when coalescing text nodes | 
| -     */ | 
| -    const xmlChar  *lasttext;		/* last text node content */ | 
| -    int             lasttsize;		/* last text node size */ | 
| -    int             lasttuse;		/* last text node use */ | 
| -    /* | 
| -     * Per Context Debugging | 
| -     */ | 
| -    int debugStatus;			/* the context level debug status */ | 
| -    unsigned long* traceCode;		/* pointer to the variable holding the mask */ | 
| - | 
| -    int parserOptions;			/* parser options xmlParserOption */ | 
| - | 
| -    /* | 
| -     * dictionary: shared between stylesheet, context and documents. | 
| -     */ | 
| -    xmlDictPtr dict; | 
| -    xmlDocPtr		tmpDoc; /* Obsolete; not used in the library. */ | 
| -    /* | 
| -     * all document text strings are internalized | 
| -     */ | 
| -    int internalized; | 
| -    int nbKeys; | 
| -    int hasTemplKeyPatterns; | 
| -    xsltTemplatePtr currentTemplateRule; /* the Current Template Rule */ | 
| -    xmlNodePtr initialContextNode; | 
| -    xmlDocPtr initialContextDoc; | 
| -    xsltTransformCachePtr cache; | 
| -    void *contextVariable; /* the current variable item */ | 
| -    xmlDocPtr localRVT; /* list of local tree fragments; will be freed when | 
| -			   the instruction which created the fragment | 
| -                           exits */ | 
| -    xmlDocPtr localRVTBase; /* Obsolete */ | 
| -    int keyInitLevel;   /* Needed to catch recursive keys issues */ | 
| -    int depth;          /* Needed to catch recursions */ | 
| -    int maxTemplateDepth; | 
| -    int maxTemplateVars; | 
| -}; | 
| - | 
| -/** | 
| - * CHECK_STOPPED: | 
| - * | 
| - * Macro to check if the XSLT processing should be stopped. | 
| - * Will return from the function. | 
| - */ | 
| -#define CHECK_STOPPED if (ctxt->state == XSLT_STATE_STOPPED) return; | 
| - | 
| -/** | 
| - * CHECK_STOPPEDE: | 
| - * | 
| - * Macro to check if the XSLT processing should be stopped. | 
| - * Will goto the error: label. | 
| - */ | 
| -#define CHECK_STOPPEDE if (ctxt->state == XSLT_STATE_STOPPED) goto error; | 
| - | 
| -/** | 
| - * CHECK_STOPPED0: | 
| - * | 
| - * Macro to check if the XSLT processing should be stopped. | 
| - * Will return from the function with a 0 value. | 
| - */ | 
| -#define CHECK_STOPPED0 if (ctxt->state == XSLT_STATE_STOPPED) return(0); | 
| - | 
| -/* | 
| - * The macro XML_CAST_FPTR is a hack to avoid a gcc warning about | 
| - * possible incompatibilities between function pointers and object | 
| - * pointers.  It is defined in libxml/hash.h within recent versions | 
| - * of libxml2, but is put here for compatibility. | 
| - */ | 
| -#ifndef XML_CAST_FPTR | 
| -/** | 
| - * 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 | 
| -#endif | 
| -/* | 
| - * Functions associated to the internal types | 
| -xsltDecimalFormatPtr	xsltDecimalFormatGetByName(xsltStylesheetPtr sheet, | 
| -						   xmlChar *name); | 
| - */ | 
| -XSLTPUBFUN xsltStylesheetPtr XSLTCALL | 
| -			xsltNewStylesheet	(void); | 
| -XSLTPUBFUN xsltStylesheetPtr XSLTCALL | 
| -			xsltParseStylesheetFile	(const xmlChar* filename); | 
| -XSLTPUBFUN void XSLTCALL | 
| -			xsltFreeStylesheet	(xsltStylesheetPtr style); | 
| -XSLTPUBFUN int XSLTCALL | 
| -			xsltIsBlank		(xmlChar *str); | 
| -XSLTPUBFUN void XSLTCALL | 
| -			xsltFreeStackElemList	(xsltStackElemPtr elem); | 
| -XSLTPUBFUN xsltDecimalFormatPtr XSLTCALL | 
| -			xsltDecimalFormatGetByName(xsltStylesheetPtr style, | 
| -						 xmlChar *name); | 
| -XSLTPUBFUN xsltDecimalFormatPtr XSLTCALL | 
| -			xsltDecimalFormatGetByQName(xsltStylesheetPtr style, | 
| -						 const xmlChar *nsUri, | 
| -                                                 const xmlChar *name); | 
| - | 
| -XSLTPUBFUN xsltStylesheetPtr XSLTCALL | 
| -			xsltParseStylesheetProcess(xsltStylesheetPtr ret, | 
| -						 xmlDocPtr doc); | 
| -XSLTPUBFUN void XSLTCALL | 
| -			xsltParseStylesheetOutput(xsltStylesheetPtr style, | 
| -						 xmlNodePtr cur); | 
| -XSLTPUBFUN xsltStylesheetPtr XSLTCALL | 
| -			xsltParseStylesheetDoc	(xmlDocPtr doc); | 
| -XSLTPUBFUN xsltStylesheetPtr XSLTCALL | 
| -			xsltParseStylesheetImportedDoc(xmlDocPtr doc, | 
| -						xsltStylesheetPtr style); | 
| -XSLTPUBFUN xsltStylesheetPtr XSLTCALL | 
| -			xsltLoadStylesheetPI	(xmlDocPtr doc); | 
| -XSLTPUBFUN void XSLTCALL | 
| -			xsltNumberFormat	(xsltTransformContextPtr ctxt, | 
| -						 xsltNumberDataPtr data, | 
| -						 xmlNodePtr node); | 
| -XSLTPUBFUN xmlXPathError XSLTCALL | 
| -			xsltFormatNumberConversion(xsltDecimalFormatPtr self, | 
| -						 xmlChar *format, | 
| -						 double number, | 
| -						 xmlChar **result); | 
| - | 
| -XSLTPUBFUN void XSLTCALL | 
| -			xsltParseTemplateContent(xsltStylesheetPtr style, | 
| -						 xmlNodePtr templ); | 
| -XSLTPUBFUN int XSLTCALL | 
| -			xsltAllocateExtra	(xsltStylesheetPtr style); | 
| -XSLTPUBFUN int XSLTCALL | 
| -			xsltAllocateExtraCtxt	(xsltTransformContextPtr ctxt); | 
| -/* | 
| - * Extra functions for Result Value Trees | 
| - */ | 
| -XSLTPUBFUN xmlDocPtr XSLTCALL | 
| -			xsltCreateRVT		(xsltTransformContextPtr ctxt); | 
| -XSLTPUBFUN int XSLTCALL | 
| -			xsltRegisterTmpRVT	(xsltTransformContextPtr ctxt, | 
| -						 xmlDocPtr RVT); | 
| -XSLTPUBFUN int XSLTCALL | 
| -			xsltRegisterLocalRVT	(xsltTransformContextPtr ctxt, | 
| -						 xmlDocPtr RVT); | 
| -XSLTPUBFUN int XSLTCALL | 
| -			xsltRegisterPersistRVT	(xsltTransformContextPtr ctxt, | 
| -						 xmlDocPtr RVT); | 
| -XSLTPUBFUN int XSLTCALL | 
| -			xsltExtensionInstructionResultRegister( | 
| -						 xsltTransformContextPtr ctxt, | 
| -						 xmlXPathObjectPtr obj); | 
| -XSLTPUBFUN int XSLTCALL | 
| -			xsltExtensionInstructionResultFinalize( | 
| -						 xsltTransformContextPtr ctxt); | 
| -XSLTPUBFUN int XSLTCALL | 
| -			xsltFlagRVTs( | 
| -						 xsltTransformContextPtr ctxt, | 
| -						 xmlXPathObjectPtr obj, | 
| -						 void *val); | 
| -XSLTPUBFUN void XSLTCALL | 
| -			xsltFreeRVTs		(xsltTransformContextPtr ctxt); | 
| -XSLTPUBFUN void XSLTCALL | 
| -			xsltReleaseRVT		(xsltTransformContextPtr ctxt, | 
| -						 xmlDocPtr RVT); | 
| -/* | 
| - * Extra functions for Attribute Value Templates | 
| - */ | 
| -XSLTPUBFUN void XSLTCALL | 
| -			xsltCompileAttr		(xsltStylesheetPtr style, | 
| -						 xmlAttrPtr attr); | 
| -XSLTPUBFUN xmlChar * XSLTCALL | 
| -			xsltEvalAVT		(xsltTransformContextPtr ctxt, | 
| -						 void *avt, | 
| -						 xmlNodePtr node); | 
| -XSLTPUBFUN void XSLTCALL | 
| -			xsltFreeAVTList		(void *avt); | 
| - | 
| -/* | 
| - * Extra function for successful xsltCleanupGlobals / xsltInit sequence. | 
| - */ | 
| - | 
| -XSLTPUBFUN void XSLTCALL | 
| -			xsltUninit		(void); | 
| - | 
| -/************************************************************************ | 
| - *									* | 
| - *  Compile-time functions for *internal* use only                      * | 
| - *									* | 
| - ************************************************************************/ | 
| - | 
| -#ifdef XSLT_REFACTORED | 
| -XSLTPUBFUN void XSLTCALL | 
| -			xsltParseSequenceConstructor( | 
| -						 xsltCompilerCtxtPtr cctxt, | 
| -						 xmlNodePtr start); | 
| -XSLTPUBFUN int XSLTCALL | 
| -			xsltParseAnyXSLTElem	(xsltCompilerCtxtPtr cctxt, | 
| -						 xmlNodePtr elem); | 
| -#ifdef XSLT_REFACTORED_XSLT_NSCOMP | 
| -XSLTPUBFUN int XSLTCALL | 
| -			xsltRestoreDocumentNamespaces( | 
| -						 xsltNsMapPtr ns, | 
| -						 xmlDocPtr doc); | 
| -#endif | 
| -#endif /* XSLT_REFACTORED */ | 
| - | 
| -/************************************************************************ | 
| - *									* | 
| - *  Transformation-time functions for *internal* use only               * | 
| - *									* | 
| - ************************************************************************/ | 
| -XSLTPUBFUN int XSLTCALL | 
| -			xsltInitCtxtKey		(xsltTransformContextPtr ctxt, | 
| -						 xsltDocumentPtr doc, | 
| -						 xsltKeyDefPtr keyd); | 
| -XSLTPUBFUN int XSLTCALL | 
| -			xsltInitAllDocKeys	(xsltTransformContextPtr ctxt); | 
| -#ifdef __cplusplus | 
| -} | 
| -#endif | 
| - | 
| -#endif /* __XML_XSLT_H__ */ | 
| - | 
|  |