xmlparse.c
上传用户:hmc_gdtv
上传日期:2013-08-04
资源大小:798k
文件大小:177k
源码类别:

Windows Mobile

开发平台:

Visual C++

  1. /* Copyright (c) 1998, 1999, 2000 Thai Open Source Software Center Ltd
  2.    See the file COPYING for copying permission.
  3. */
  4. #ifndef _WIN32_WCE
  5. #include <stddef.h>
  6. #endif
  7. #include <string.h>                     /* memset(), memcpy() */
  8. #include "winconfig.h"
  9. #define XMLPARSEAPI(type) type
  10. #include "expat.h"
  11. #ifdef XML_UNICODE
  12. #define XML_ENCODE_MAX XML_UTF16_ENCODE_MAX
  13. #define XmlConvert XmlUtf16Convert
  14. #define XmlGetInternalEncoding XmlGetUtf16InternalEncoding
  15. #define XmlGetInternalEncodingNS XmlGetUtf16InternalEncodingNS
  16. #define XmlEncode XmlUtf16Encode
  17. #define MUST_CONVERT(enc, s) (!(enc)->isUtf16 || (((unsigned long)s) & 1))
  18. typedef unsigned short ICHAR;
  19. #else
  20. #define XML_ENCODE_MAX XML_UTF8_ENCODE_MAX
  21. #define XmlConvert XmlUtf8Convert
  22. #define XmlGetInternalEncoding XmlGetUtf8InternalEncoding
  23. #define XmlGetInternalEncodingNS XmlGetUtf8InternalEncodingNS
  24. #define XmlEncode XmlUtf8Encode
  25. #define MUST_CONVERT(enc, s) (!(enc)->isUtf8)
  26. typedef char ICHAR;
  27. #endif
  28. #ifndef XML_NS
  29. #define XmlInitEncodingNS XmlInitEncoding
  30. #define XmlInitUnknownEncodingNS XmlInitUnknownEncoding
  31. #undef XmlGetInternalEncodingNS
  32. #define XmlGetInternalEncodingNS XmlGetInternalEncoding
  33. #define XmlParseXmlDeclNS XmlParseXmlDecl
  34. #endif
  35. #ifdef XML_UNICODE
  36. #ifdef XML_UNICODE_WCHAR_T
  37. #define XML_T(x) (const wchar_t)x
  38. #define XML_L(x) L ## x
  39. #else
  40. #define XML_T(x) (const unsigned short)x
  41. #define XML_L(x) x
  42. #endif
  43. #else
  44. #define XML_T(x) x
  45. #define XML_L(x) x
  46. #endif
  47. /* Round up n to be a multiple of sz, where sz is a power of 2. */
  48. #define ROUND_UP(n, sz) (((n) + ((sz) - 1)) & ~((sz) - 1))
  49. /* Handle the case where memmove() doesn't exist. */
  50. #ifndef HAVE_MEMMOVE
  51. #ifdef HAVE_BCOPY
  52. #define memmove(d,s,l) bcopy((s),(d),(l))
  53. #else
  54. #error memmove does not exist on this platform, nor is a substitute available
  55. #endif /* HAVE_BCOPY */
  56. #endif /* HAVE_MEMMOVE */
  57. #include "internal.h"
  58. #include "xmltok.h"
  59. #include "xmlrole.h"
  60. typedef const XML_Char *KEY;
  61. typedef struct {
  62.   KEY name;
  63. } NAMED;
  64. typedef struct {
  65.   NAMED **v;
  66.   size_t size;
  67.   size_t used;
  68.   size_t usedLim;
  69.   const XML_Memory_Handling_Suite *mem;
  70. } HASH_TABLE;
  71. typedef struct {
  72.   NAMED **p;
  73.   NAMED **end;
  74. } HASH_TABLE_ITER;
  75. #define INIT_TAG_BUF_SIZE 32  /* must be a multiple of sizeof(XML_Char) */
  76. #define INIT_DATA_BUF_SIZE 1024
  77. #define INIT_ATTS_SIZE 16
  78. #define INIT_BLOCK_SIZE 1024
  79. #define INIT_BUFFER_SIZE 1024
  80. #define EXPAND_SPARE 24
  81. typedef struct binding {
  82.   struct prefix *prefix;
  83.   struct binding *nextTagBinding;
  84.   struct binding *prevPrefixBinding;
  85.   const struct attribute_id *attId;
  86.   XML_Char *uri;
  87.   int uriLen;
  88.   int uriAlloc;
  89. } BINDING;
  90. typedef struct prefix {
  91.   const XML_Char *name;
  92.   BINDING *binding;
  93. } PREFIX;
  94. typedef struct {
  95.   const XML_Char *str;
  96.   const XML_Char *localPart;
  97.   const XML_Char *prefix;
  98.   int strLen;
  99.   int uriLen;
  100.   int prefixLen;
  101. } TAG_NAME;
  102. /* TAG represents an open element.
  103.    The name of the element is stored in both the document and API
  104.    encodings.  The memory buffer 'buf' is a separately-allocated
  105.    memory area which stores the name.  During the XML_Parse()/
  106.    XMLParseBuffer() when the element is open, the memory for the 'raw'
  107.    version of the name (in the document encoding) is shared with the
  108.    document buffer.  If the element is open across calls to
  109.    XML_Parse()/XML_ParseBuffer(), the buffer is re-allocated to
  110.    contain the 'raw' name as well.
  111.    A parser re-uses these structures, maintaining a list of allocated
  112.    TAG objects in a free list.
  113. */
  114. typedef struct tag {
  115.   struct tag *parent;           /* parent of this element */
  116.   const char *rawName;          /* tagName in the original encoding */
  117.   int rawNameLength;
  118.   TAG_NAME name;                /* tagName in the API encoding */
  119.   char *buf;                    /* buffer for name components */
  120.   char *bufEnd;                 /* end of the buffer */
  121.   BINDING *bindings;
  122. } TAG;
  123. typedef struct {
  124.   const XML_Char *name;
  125.   const XML_Char *textPtr;
  126.   int textLen;
  127.   const XML_Char *systemId;
  128.   const XML_Char *base;
  129.   const XML_Char *publicId;
  130.   const XML_Char *notation;
  131.   XML_Bool open;
  132.   XML_Bool is_param;
  133.   XML_Bool is_internal; /* true if declared in internal subset outside PE */
  134. } ENTITY;
  135. typedef struct {
  136.   enum XML_Content_Type         type;
  137.   enum XML_Content_Quant        quant;
  138.   const XML_Char *              name;
  139.   int                           firstchild;
  140.   int                           lastchild;
  141.   int                           childcnt;
  142.   int                           nextsib;
  143. } CONTENT_SCAFFOLD;
  144. #define INIT_SCAFFOLD_ELEMENTS 32
  145. typedef struct block {
  146.   struct block *next;
  147.   int size;
  148.   XML_Char s[1];
  149. } BLOCK;
  150. typedef struct {
  151.   BLOCK *blocks;
  152.   BLOCK *freeBlocks;
  153.   const XML_Char *end;
  154.   XML_Char *ptr;
  155.   XML_Char *start;
  156.   const XML_Memory_Handling_Suite *mem;
  157. } STRING_POOL;
  158. /* The XML_Char before the name is used to determine whether
  159.    an attribute has been specified. */
  160. typedef struct attribute_id {
  161.   XML_Char *name;
  162.   PREFIX *prefix;
  163.   XML_Bool maybeTokenized;
  164.   XML_Bool xmlns;
  165. } ATTRIBUTE_ID;
  166. typedef struct {
  167.   const ATTRIBUTE_ID *id;
  168.   XML_Bool isCdata;
  169.   const XML_Char *value;
  170. } DEFAULT_ATTRIBUTE;
  171. typedef struct {
  172.   const XML_Char *name;
  173.   PREFIX *prefix;
  174.   const ATTRIBUTE_ID *idAtt;
  175.   int nDefaultAtts;
  176.   int allocDefaultAtts;
  177.   DEFAULT_ATTRIBUTE *defaultAtts;
  178. } ELEMENT_TYPE;
  179. typedef struct {
  180.   HASH_TABLE generalEntities;
  181.   HASH_TABLE elementTypes;
  182.   HASH_TABLE attributeIds;
  183.   HASH_TABLE prefixes;
  184.   STRING_POOL pool;
  185.   STRING_POOL entityValuePool;
  186.   /* false once a parameter entity reference has been skipped */
  187.   XML_Bool keepProcessing;
  188.   /* true once an internal or external PE reference has been encountered;
  189.      this includes the reference to an external subset */
  190.   XML_Bool hasParamEntityRefs;
  191.   XML_Bool standalone;
  192. #ifdef XML_DTD
  193.   /* indicates if external PE has been read */
  194.   XML_Bool paramEntityRead;
  195.   HASH_TABLE paramEntities;
  196. #endif /* XML_DTD */
  197.   PREFIX defaultPrefix;
  198.   /* === scaffolding for building content model === */
  199.   XML_Bool in_eldecl;
  200.   CONTENT_SCAFFOLD *scaffold;
  201.   unsigned contentStringLen;
  202.   unsigned scaffSize;
  203.   unsigned scaffCount;
  204.   int scaffLevel;
  205.   int *scaffIndex;
  206. } DTD;
  207. typedef struct open_internal_entity {
  208.   const char *internalEventPtr;
  209.   const char *internalEventEndPtr;
  210.   struct open_internal_entity *next;
  211.   ENTITY *entity;
  212. } OPEN_INTERNAL_ENTITY;
  213. typedef enum XML_Error PTRCALL Processor(XML_Parser parser,
  214.                                          const char *start,
  215.                                          const char *end,
  216.                                          const char **endPtr);
  217. static Processor prologProcessor;
  218. static Processor prologInitProcessor;
  219. static Processor contentProcessor;
  220. static Processor cdataSectionProcessor;
  221. #ifdef XML_DTD
  222. static Processor ignoreSectionProcessor;
  223. static Processor externalParEntProcessor;
  224. static Processor externalParEntInitProcessor;
  225. static Processor entityValueProcessor;
  226. static Processor entityValueInitProcessor;
  227. #endif /* XML_DTD */
  228. static Processor epilogProcessor;
  229. static Processor errorProcessor;
  230. static Processor externalEntityInitProcessor;
  231. static Processor externalEntityInitProcessor2;
  232. static Processor externalEntityInitProcessor3;
  233. static Processor externalEntityContentProcessor;
  234. static enum XML_Error
  235. handleUnknownEncoding(XML_Parser parser, const XML_Char *encodingName);
  236. static enum XML_Error
  237. processXmlDecl(XML_Parser parser, int isGeneralTextEntity,
  238.                const char *, const char *);
  239. static enum XML_Error
  240. initializeEncoding(XML_Parser parser);
  241. static enum XML_Error
  242. doProlog(XML_Parser parser, const ENCODING *enc, const char *s,
  243.          const char *end, int tok, const char *next, const char **nextPtr);
  244. static enum XML_Error
  245. processInternalParamEntity(XML_Parser parser, ENTITY *entity);
  246. static enum XML_Error
  247. doContent(XML_Parser parser, int startTagLevel, const ENCODING *enc,
  248.           const char *start, const char *end, const char **endPtr);
  249. static enum XML_Error
  250. doCdataSection(XML_Parser parser, const ENCODING *, const char **startPtr,
  251.                const char *end, const char **nextPtr);
  252. #ifdef XML_DTD
  253. static enum XML_Error
  254. doIgnoreSection(XML_Parser parser, const ENCODING *, const char **startPtr,
  255.                 const char *end, const char **nextPtr);
  256. #endif /* XML_DTD */
  257. static enum XML_Error
  258. storeAtts(XML_Parser parser, const ENCODING *,
  259.           const char *s, TAG_NAME *tagNamePtr, BINDING **bindingsPtr);
  260. static int
  261. addBinding(XML_Parser parser, PREFIX *prefix, const ATTRIBUTE_ID *attId,
  262.            const XML_Char *uri, BINDING **bindingsPtr);
  263. static int
  264. defineAttribute(ELEMENT_TYPE *type, ATTRIBUTE_ID *,
  265.                 XML_Bool isCdata, XML_Bool isId, const XML_Char *dfltValue,
  266.                 XML_Parser parser);
  267. static enum XML_Error
  268. storeAttributeValue(XML_Parser parser, const ENCODING *, XML_Bool isCdata,
  269.                     const char *, const char *, STRING_POOL *);
  270. static enum XML_Error
  271. appendAttributeValue(XML_Parser parser, const ENCODING *, XML_Bool isCdata,
  272.                      const char *, const char *, STRING_POOL *);
  273. static ATTRIBUTE_ID *
  274. getAttributeId(XML_Parser parser, const ENCODING *enc, const char *start,
  275.                const char *end);
  276. static int
  277. setElementTypePrefix(XML_Parser parser, ELEMENT_TYPE *);
  278. static enum XML_Error
  279. storeEntityValue(XML_Parser parser, const ENCODING *enc, const char *start,
  280.                  const char *end);
  281. static int
  282. reportProcessingInstruction(XML_Parser parser, const ENCODING *enc,
  283.                             const char *start, const char *end);
  284. static int
  285. reportComment(XML_Parser parser, const ENCODING *enc, const char *start,
  286.               const char *end);
  287. static void
  288. reportDefault(XML_Parser parser, const ENCODING *enc, const char *start,
  289.               const char *end);
  290. static const XML_Char * getContext(XML_Parser parser);
  291. static XML_Bool
  292. setContext(XML_Parser parser, const XML_Char *context);
  293. static void FASTCALL normalizePublicId(XML_Char *s);
  294. static DTD * dtdCreate(const XML_Memory_Handling_Suite *ms);
  295. /* do not call if parentParser != NULL */
  296. static void dtdReset(DTD *p, const XML_Memory_Handling_Suite *ms);
  297. static void
  298. dtdDestroy(DTD *p, XML_Bool isDocEntity, const XML_Memory_Handling_Suite *ms);
  299. static int
  300. dtdCopy(DTD *newDtd, const DTD *oldDtd, const XML_Memory_Handling_Suite *ms);
  301. static int
  302. copyEntityTable(HASH_TABLE *, STRING_POOL *, const HASH_TABLE *);
  303. static NAMED *
  304. lookup(HASH_TABLE *table, KEY name, size_t createSize);
  305. static void FASTCALL
  306. hashTableInit(HASH_TABLE *, const XML_Memory_Handling_Suite *ms);
  307. static void FASTCALL hashTableClear(HASH_TABLE *);
  308. static void FASTCALL hashTableDestroy(HASH_TABLE *);
  309. static void FASTCALL
  310. hashTableIterInit(HASH_TABLE_ITER *, const HASH_TABLE *);
  311. static NAMED * FASTCALL hashTableIterNext(HASH_TABLE_ITER *);
  312. static void FASTCALL
  313. poolInit(STRING_POOL *, const XML_Memory_Handling_Suite *ms);
  314. static void FASTCALL poolClear(STRING_POOL *);
  315. static void FASTCALL poolDestroy(STRING_POOL *);
  316. static XML_Char *
  317. poolAppend(STRING_POOL *pool, const ENCODING *enc,
  318.            const char *ptr, const char *end);
  319. static XML_Char *
  320. poolStoreString(STRING_POOL *pool, const ENCODING *enc,
  321.                 const char *ptr, const char *end);
  322. static XML_Bool FASTCALL poolGrow(STRING_POOL *pool);
  323. static const XML_Char * FASTCALL
  324. poolCopyString(STRING_POOL *pool, const XML_Char *s);
  325. static const XML_Char *
  326. poolCopyStringN(STRING_POOL *pool, const XML_Char *s, int n);
  327. static const XML_Char * FASTCALL
  328. poolAppendString(STRING_POOL *pool, const XML_Char *s);
  329. static int FASTCALL nextScaffoldPart(XML_Parser parser);
  330. static XML_Content * build_model(XML_Parser parser);
  331. static ELEMENT_TYPE *
  332. getElementType(XML_Parser parser, const ENCODING *enc,
  333.                const char *ptr, const char *end);
  334. static XML_Parser
  335. parserCreate(const XML_Char *encodingName,
  336.              const XML_Memory_Handling_Suite *memsuite,
  337.              const XML_Char *nameSep,
  338.              DTD *dtd);
  339. static void
  340. parserInit(XML_Parser parser, const XML_Char *encodingName);
  341. #define poolStart(pool) ((pool)->start)
  342. #define poolEnd(pool) ((pool)->ptr)
  343. #define poolLength(pool) ((pool)->ptr - (pool)->start)
  344. #define poolChop(pool) ((void)--(pool->ptr))
  345. #define poolLastChar(pool) (((pool)->ptr)[-1])
  346. #define poolDiscard(pool) ((pool)->ptr = (pool)->start)
  347. #define poolFinish(pool) ((pool)->start = (pool)->ptr)
  348. #define poolAppendChar(pool, c) 
  349.   (((pool)->ptr == (pool)->end && !poolGrow(pool)) 
  350.    ? 0 
  351.    : ((*((pool)->ptr)++ = c), 1))
  352. struct XML_ParserStruct {
  353.   /* The first member must be userData so that the XML_GetUserData
  354.      macro works. */
  355.   void *m_userData;
  356.   void *m_handlerArg;
  357.   char *m_buffer;
  358.   const XML_Memory_Handling_Suite m_mem;
  359.   /* first character to be parsed */
  360.   const char *m_bufferPtr;
  361.   /* past last character to be parsed */
  362.   char *m_bufferEnd;
  363.   /* allocated end of buffer */
  364.   const char *m_bufferLim;
  365.   long m_parseEndByteIndex;
  366.   const char *m_parseEndPtr;
  367.   XML_Char *m_dataBuf;
  368.   XML_Char *m_dataBufEnd;
  369.   XML_StartElementHandler m_startElementHandler;
  370.   XML_EndElementHandler m_endElementHandler;
  371.   XML_CharacterDataHandler m_characterDataHandler;
  372.   XML_ProcessingInstructionHandler m_processingInstructionHandler;
  373.   XML_CommentHandler m_commentHandler;
  374.   XML_StartCdataSectionHandler m_startCdataSectionHandler;
  375.   XML_EndCdataSectionHandler m_endCdataSectionHandler;
  376.   XML_DefaultHandler m_defaultHandler;
  377.   XML_StartDoctypeDeclHandler m_startDoctypeDeclHandler;
  378.   XML_EndDoctypeDeclHandler m_endDoctypeDeclHandler;
  379.   XML_UnparsedEntityDeclHandler m_unparsedEntityDeclHandler;
  380.   XML_NotationDeclHandler m_notationDeclHandler;
  381.   XML_StartNamespaceDeclHandler m_startNamespaceDeclHandler;
  382.   XML_EndNamespaceDeclHandler m_endNamespaceDeclHandler;
  383.   XML_NotStandaloneHandler m_notStandaloneHandler;
  384.   XML_ExternalEntityRefHandler m_externalEntityRefHandler;
  385.   XML_Parser m_externalEntityRefHandlerArg;
  386.   XML_SkippedEntityHandler m_skippedEntityHandler;
  387.   XML_UnknownEncodingHandler m_unknownEncodingHandler;
  388.   XML_ElementDeclHandler m_elementDeclHandler;
  389.   XML_AttlistDeclHandler m_attlistDeclHandler;
  390.   XML_EntityDeclHandler m_entityDeclHandler;
  391.   XML_XmlDeclHandler m_xmlDeclHandler;
  392.   const ENCODING *m_encoding;
  393.   INIT_ENCODING m_initEncoding;
  394.   const ENCODING *m_internalEncoding;
  395.   const XML_Char *m_protocolEncodingName;
  396.   XML_Bool m_ns;
  397.   XML_Bool m_ns_triplets;
  398.   void *m_unknownEncodingMem;
  399.   void *m_unknownEncodingData;
  400.   void *m_unknownEncodingHandlerData;
  401.   void (*m_unknownEncodingRelease)(void *);
  402.   PROLOG_STATE m_prologState;
  403.   Processor *m_processor;
  404.   enum XML_Error m_errorCode;
  405.   const char *m_eventPtr;
  406.   const char *m_eventEndPtr;
  407.   const char *m_positionPtr;
  408.   OPEN_INTERNAL_ENTITY *m_openInternalEntities;
  409.   XML_Bool m_defaultExpandInternalEntities;
  410.   int m_tagLevel;
  411.   ENTITY *m_declEntity;
  412.   const XML_Char *m_doctypeName;
  413.   const XML_Char *m_doctypeSysid;
  414.   const XML_Char *m_doctypePubid;
  415.   const XML_Char *m_declAttributeType;
  416.   const XML_Char *m_declNotationName;
  417.   const XML_Char *m_declNotationPublicId;
  418.   ELEMENT_TYPE *m_declElementType;
  419.   ATTRIBUTE_ID *m_declAttributeId;
  420.   XML_Bool m_declAttributeIsCdata;
  421.   XML_Bool m_declAttributeIsId;
  422.   DTD *m_dtd;
  423.   const XML_Char *m_curBase;
  424.   TAG *m_tagStack;
  425.   TAG *m_freeTagList;
  426.   BINDING *m_inheritedBindings;
  427.   BINDING *m_freeBindingList;
  428.   int m_attsSize;
  429.   int m_nSpecifiedAtts;
  430.   int m_idAttIndex;
  431.   ATTRIBUTE *m_atts;
  432.   POSITION m_position;
  433.   STRING_POOL m_tempPool;
  434.   STRING_POOL m_temp2Pool;
  435.   char *m_groupConnector;
  436.   unsigned m_groupSize;
  437.   XML_Char m_namespaceSeparator;
  438.   XML_Parser m_parentParser;
  439. #ifdef XML_DTD
  440.   XML_Bool m_isParamEntity;
  441.   XML_Bool m_useForeignDTD;
  442.   enum XML_ParamEntityParsing m_paramEntityParsing;
  443. #endif
  444. };
  445. #define MALLOC(s) (parser->m_mem.malloc_fcn(parser->m_mem.priv,(s)))
  446. #define REALLOC(p,s) (parser->m_mem.realloc_fcn(parser->m_mem.priv,(p),(s)))
  447. #define FREE(p) (parser->m_mem.free_fcn(parser->m_mem.priv,(p)))
  448. #define userData (parser->m_userData)
  449. #define handlerArg (parser->m_handlerArg)
  450. #define startElementHandler (parser->m_startElementHandler)
  451. #define endElementHandler (parser->m_endElementHandler)
  452. #define characterDataHandler (parser->m_characterDataHandler)
  453. #define processingInstructionHandler 
  454.         (parser->m_processingInstructionHandler)
  455. #define commentHandler (parser->m_commentHandler)
  456. #define startCdataSectionHandler 
  457.         (parser->m_startCdataSectionHandler)
  458. #define endCdataSectionHandler (parser->m_endCdataSectionHandler)
  459. #define defaultHandler (parser->m_defaultHandler)
  460. #define startDoctypeDeclHandler (parser->m_startDoctypeDeclHandler)
  461. #define endDoctypeDeclHandler (parser->m_endDoctypeDeclHandler)
  462. #define unparsedEntityDeclHandler 
  463.         (parser->m_unparsedEntityDeclHandler)
  464. #define notationDeclHandler (parser->m_notationDeclHandler)
  465. #define startNamespaceDeclHandler 
  466.         (parser->m_startNamespaceDeclHandler)
  467. #define endNamespaceDeclHandler (parser->m_endNamespaceDeclHandler)
  468. #define notStandaloneHandler (parser->m_notStandaloneHandler)
  469. #define externalEntityRefHandler 
  470.         (parser->m_externalEntityRefHandler)
  471. #define externalEntityRefHandlerArg 
  472.         (parser->m_externalEntityRefHandlerArg)
  473. #define internalEntityRefHandler 
  474.         (parser->m_internalEntityRefHandler)
  475. #define skippedEntityHandler (parser->m_skippedEntityHandler)
  476. #define unknownEncodingHandler (parser->m_unknownEncodingHandler)
  477. #define elementDeclHandler (parser->m_elementDeclHandler)
  478. #define attlistDeclHandler (parser->m_attlistDeclHandler)
  479. #define entityDeclHandler (parser->m_entityDeclHandler)
  480. #define xmlDeclHandler (parser->m_xmlDeclHandler)
  481. #define encoding (parser->m_encoding)
  482. #define initEncoding (parser->m_initEncoding)
  483. #define internalEncoding (parser->m_internalEncoding)
  484. #define unknownEncodingMem (parser->m_unknownEncodingMem)
  485. #define unknownEncodingData (parser->m_unknownEncodingData)
  486. #define unknownEncodingHandlerData 
  487.   (parser->m_unknownEncodingHandlerData)
  488. #define unknownEncodingRelease (parser->m_unknownEncodingRelease)
  489. #define protocolEncodingName (parser->m_protocolEncodingName)
  490. #define ns (parser->m_ns)
  491. #define ns_triplets (parser->m_ns_triplets)
  492. #define prologState (parser->m_prologState)
  493. #define processor (parser->m_processor)
  494. #define errorCode (parser->m_errorCode)
  495. #define eventPtr (parser->m_eventPtr)
  496. #define eventEndPtr (parser->m_eventEndPtr)
  497. #define positionPtr (parser->m_positionPtr)
  498. #define position (parser->m_position)
  499. #define openInternalEntities (parser->m_openInternalEntities)
  500. #define defaultExpandInternalEntities 
  501.         (parser->m_defaultExpandInternalEntities)
  502. #define tagLevel (parser->m_tagLevel)
  503. #define buffer (parser->m_buffer)
  504. #define bufferPtr (parser->m_bufferPtr)
  505. #define bufferEnd (parser->m_bufferEnd)
  506. #define parseEndByteIndex (parser->m_parseEndByteIndex)
  507. #define parseEndPtr (parser->m_parseEndPtr)
  508. #define bufferLim (parser->m_bufferLim)
  509. #define dataBuf (parser->m_dataBuf)
  510. #define dataBufEnd (parser->m_dataBufEnd)
  511. #define _dtd (parser->m_dtd)
  512. #define curBase (parser->m_curBase)
  513. #define declEntity (parser->m_declEntity)
  514. #define doctypeName (parser->m_doctypeName)
  515. #define doctypeSysid (parser->m_doctypeSysid)
  516. #define doctypePubid (parser->m_doctypePubid)
  517. #define declAttributeType (parser->m_declAttributeType)
  518. #define declNotationName (parser->m_declNotationName)
  519. #define declNotationPublicId (parser->m_declNotationPublicId)
  520. #define declElementType (parser->m_declElementType)
  521. #define declAttributeId (parser->m_declAttributeId)
  522. #define declAttributeIsCdata (parser->m_declAttributeIsCdata)
  523. #define declAttributeIsId (parser->m_declAttributeIsId)
  524. #define freeTagList (parser->m_freeTagList)
  525. #define freeBindingList (parser->m_freeBindingList)
  526. #define inheritedBindings (parser->m_inheritedBindings)
  527. #define tagStack (parser->m_tagStack)
  528. #define atts (parser->m_atts)
  529. #define attsSize (parser->m_attsSize)
  530. #define nSpecifiedAtts (parser->m_nSpecifiedAtts)
  531. #define idAttIndex (parser->m_idAttIndex)
  532. #define tempPool (parser->m_tempPool)
  533. #define temp2Pool (parser->m_temp2Pool)
  534. #define groupConnector (parser->m_groupConnector)
  535. #define groupSize (parser->m_groupSize)
  536. #define namespaceSeparator (parser->m_namespaceSeparator)
  537. #define parentParser (parser->m_parentParser)
  538. #ifdef XML_DTD
  539. #define isParamEntity (parser->m_isParamEntity)
  540. #define useForeignDTD (parser->m_useForeignDTD)
  541. #define paramEntityParsing (parser->m_paramEntityParsing)
  542. #endif /* XML_DTD */
  543. #define parsing 
  544.   (parentParser 
  545.     ? 
  546.     (isParamEntity 
  547.       ? 
  548.       (processor != externalParEntInitProcessor) 
  549.       : 
  550.       (processor != externalEntityInitProcessor)) 
  551.     : 
  552.     (processor != prologInitProcessor))
  553. XML_Parser
  554. XML_ParserCreate(const XML_Char *encodingName)
  555. {
  556.   return XML_ParserCreate_MM(encodingName, NULL, NULL);
  557. }
  558. XML_Parser
  559. XML_ParserCreateNS(const XML_Char *encodingName, XML_Char nsSep)
  560. {
  561.   XML_Char tmp[2];
  562.   *tmp = nsSep;
  563.   return XML_ParserCreate_MM(encodingName, NULL, tmp);
  564. }
  565. static const XML_Char implicitContext[] = {
  566.   'x', 'm', 'l', '=', 'h', 't', 't', 'p', ':', '/', '/',
  567.   'w', 'w', 'w', '.', 'w', '3', '.', 'o', 'r', 'g', '/',
  568.   'X', 'M', 'L', '/', '1', '9', '9', '8', '/',
  569.   'n', 'a', 'm', 'e', 's', 'p', 'a', 'c', 'e', ''
  570. };
  571. XML_Parser
  572. XML_ParserCreate_MM(const XML_Char *encodingName,
  573.                     const XML_Memory_Handling_Suite *memsuite,
  574.                     const XML_Char *nameSep)
  575. {
  576.   XML_Parser parser = parserCreate(encodingName, memsuite, nameSep, NULL);
  577.   if (parser != NULL && ns) {
  578.     /* implicit context only set for root parser, since child
  579.        parsers (i.e. external entity parsers) will inherit it
  580.     */
  581.     if (!setContext(parser, implicitContext)) {
  582.       XML_ParserFree(parser);
  583.       return NULL;
  584.     }
  585.   }
  586.   return parser;
  587. }
  588. static XML_Parser
  589. parserCreate(const XML_Char *encodingName,
  590.              const XML_Memory_Handling_Suite *memsuite,
  591.              const XML_Char *nameSep,
  592.              DTD *dtd)
  593. {
  594.   XML_Parser parser=NULL;
  595.   if (memsuite) {
  596.     XML_Memory_Handling_Suite *mtemp;
  597.     parser = (XML_Parser)
  598.       memsuite->malloc_fcn(memsuite->priv,sizeof(struct XML_ParserStruct));
  599.     if (parser != NULL) {
  600.       mtemp = (XML_Memory_Handling_Suite *)&(parser->m_mem);
  601.       mtemp->malloc_fcn = memsuite->malloc_fcn;
  602.       mtemp->realloc_fcn = memsuite->realloc_fcn;
  603.       mtemp->free_fcn = memsuite->free_fcn;
  604.       mtemp->priv = memsuite->priv;
  605.     }
  606.   }
  607. #if 0
  608.   else {
  609.     XML_Memory_Handling_Suite *mtemp;
  610.     parser = (XML_Parser)malloc(sizeof(struct XML_ParserStruct));
  611.     if (parser != NULL) {
  612.       mtemp = (XML_Memory_Handling_Suite *)&(parser->m_mem);
  613.       mtemp->malloc_fcn = malloc;
  614.       mtemp->realloc_fcn = realloc;
  615.       mtemp->free_fcn = free;
  616.     }
  617.   }
  618. #endif
  619.   if (!parser)
  620.     return parser;
  621.   buffer = NULL;
  622.   bufferLim = NULL;
  623.   attsSize = INIT_ATTS_SIZE;
  624.   atts = (ATTRIBUTE *)MALLOC(attsSize * sizeof(ATTRIBUTE));
  625.   if (atts == NULL) {
  626.     FREE(parser);
  627.     return NULL;
  628.   }
  629.   dataBuf = (XML_Char *)MALLOC(INIT_DATA_BUF_SIZE * sizeof(XML_Char));
  630.   if (dataBuf == NULL) {
  631.     FREE(atts);
  632.     FREE(parser);
  633.     return NULL;
  634.   }
  635.   dataBufEnd = dataBuf + INIT_DATA_BUF_SIZE;
  636.   if (dtd)
  637.     _dtd = dtd;
  638.   else {
  639.     _dtd = dtdCreate(&parser->m_mem);
  640.     if (_dtd == NULL) {
  641.       FREE(dataBuf);
  642.       FREE(atts);
  643.       FREE(parser);
  644.       return NULL;
  645.     }
  646.   }
  647.   freeBindingList = NULL;
  648.   freeTagList = NULL;
  649.   groupSize = 0;
  650.   groupConnector = NULL;
  651.   unknownEncodingHandler = NULL;
  652.   unknownEncodingHandlerData = NULL;
  653.   namespaceSeparator = '!';
  654.   ns = XML_FALSE;
  655.   ns_triplets = XML_FALSE;
  656.   poolInit(&tempPool, &(parser->m_mem));
  657.   poolInit(&temp2Pool, &(parser->m_mem));
  658.   parserInit(parser, encodingName);
  659.   if (encodingName && !protocolEncodingName) {
  660.     XML_ParserFree(parser);
  661.     return NULL;
  662.   }
  663.   if (nameSep) {
  664.     ns = XML_TRUE;
  665.     internalEncoding = XmlGetInternalEncodingNS();
  666.     namespaceSeparator = *nameSep;
  667.   }
  668.   else {
  669.     internalEncoding = XmlGetInternalEncoding();
  670.   }
  671.   return parser;
  672. }
  673. static void
  674. parserInit(XML_Parser parser, const XML_Char *encodingName)
  675. {
  676.   processor = prologInitProcessor;
  677.   XmlPrologStateInit(&prologState);
  678.   protocolEncodingName = (encodingName != NULL
  679.                           ? poolCopyString(&tempPool, encodingName)
  680.                           : NULL);
  681.   curBase = NULL;
  682.   XmlInitEncoding(&initEncoding, &encoding, 0);
  683.   userData = NULL;
  684.   handlerArg = NULL;
  685.   startElementHandler = NULL;
  686.   endElementHandler = NULL;
  687.   characterDataHandler = NULL;
  688.   processingInstructionHandler = NULL;
  689.   commentHandler = NULL;
  690.   startCdataSectionHandler = NULL;
  691.   endCdataSectionHandler = NULL;
  692.   defaultHandler = NULL;
  693.   startDoctypeDeclHandler = NULL;
  694.   endDoctypeDeclHandler = NULL;
  695.   unparsedEntityDeclHandler = NULL;
  696.   notationDeclHandler = NULL;
  697.   startNamespaceDeclHandler = NULL;
  698.   endNamespaceDeclHandler = NULL;
  699.   notStandaloneHandler = NULL;
  700.   externalEntityRefHandler = NULL;
  701.   externalEntityRefHandlerArg = parser;
  702.   skippedEntityHandler = NULL;
  703.   elementDeclHandler = NULL;
  704.   attlistDeclHandler = NULL;
  705.   entityDeclHandler = NULL;
  706.   xmlDeclHandler = NULL;
  707.   bufferPtr = buffer;
  708.   bufferEnd = buffer;
  709.   parseEndByteIndex = 0;
  710.   parseEndPtr = NULL;
  711.   declElementType = NULL;
  712.   declAttributeId = NULL;
  713.   declEntity = NULL;
  714.   doctypeName = NULL;
  715.   doctypeSysid = NULL;
  716.   doctypePubid = NULL;
  717.   declAttributeType = NULL;
  718.   declNotationName = NULL;
  719.   declNotationPublicId = NULL;
  720.   declAttributeIsCdata = XML_FALSE;
  721.   declAttributeIsId = XML_FALSE;
  722.   memset(&position, 0, sizeof(POSITION));
  723.   errorCode = XML_ERROR_NONE;
  724.   eventPtr = NULL;
  725.   eventEndPtr = NULL;
  726.   positionPtr = NULL;
  727.   openInternalEntities = 0;
  728.   defaultExpandInternalEntities = XML_TRUE;
  729.   tagLevel = 0;
  730.   tagStack = NULL;
  731.   inheritedBindings = NULL;
  732.   nSpecifiedAtts = 0;
  733.   unknownEncodingMem = NULL;
  734.   unknownEncodingRelease = NULL;
  735.   unknownEncodingData = NULL;
  736.   parentParser = NULL;
  737. #ifdef XML_DTD
  738.   isParamEntity = XML_FALSE;
  739.   useForeignDTD = XML_FALSE;
  740.   paramEntityParsing = XML_PARAM_ENTITY_PARSING_NEVER;
  741. #endif
  742. }
  743. /* moves list of bindings to freeBindingList */
  744. static void FASTCALL
  745. moveToFreeBindingList(XML_Parser parser, BINDING *bindings)
  746. {
  747.   while (bindings) {
  748.     BINDING *b = bindings;
  749.     bindings = bindings->nextTagBinding;
  750.     b->nextTagBinding = freeBindingList;
  751.     freeBindingList = b;
  752.   }
  753. }
  754. XML_Bool
  755. XML_ParserReset(XML_Parser parser, const XML_Char *encodingName)
  756. {
  757.   TAG *tStk;
  758.   if (parentParser)
  759.     return XML_FALSE;
  760.   /* move tagStack to freeTagList */
  761.   tStk = tagStack;
  762.   while (tStk) {
  763.     TAG *tag = tStk;
  764.     tStk = tStk->parent;
  765.     tag->parent = freeTagList;
  766.     moveToFreeBindingList(parser, tag->bindings);
  767.     tag->bindings = NULL;
  768.     freeTagList = tag;
  769.   }
  770.   moveToFreeBindingList(parser, inheritedBindings);
  771.   if (unknownEncodingMem)
  772.     FREE(unknownEncodingMem);
  773.   if (unknownEncodingRelease)
  774.     unknownEncodingRelease(unknownEncodingData);
  775.   poolClear(&tempPool);
  776.   poolClear(&temp2Pool);
  777.   parserInit(parser, encodingName);
  778.   dtdReset(_dtd, &parser->m_mem);
  779.   return setContext(parser, implicitContext);
  780. }
  781. enum XML_Status
  782. XML_SetEncoding(XML_Parser parser, const XML_Char *encodingName)
  783. {
  784.   /* Block after XML_Parse()/XML_ParseBuffer() has been called.
  785.      XXX There's no way for the caller to determine which of the
  786.      XXX possible error cases caused the XML_STATUS_ERROR return.
  787.   */
  788.   if (parsing)
  789.     return XML_STATUS_ERROR;
  790.   if (encodingName == NULL)
  791.     protocolEncodingName = NULL;
  792.   else {
  793.     protocolEncodingName = poolCopyString(&tempPool, encodingName);
  794.     if (!protocolEncodingName)
  795.       return XML_STATUS_ERROR;
  796.   }
  797.   return XML_STATUS_OK;
  798. }
  799. XML_Parser
  800. XML_ExternalEntityParserCreate(XML_Parser oldParser,
  801.                                const XML_Char *context,
  802.                                const XML_Char *encodingName)
  803. {
  804.   XML_Parser parser = oldParser;
  805.   DTD *newDtd = NULL;
  806.   DTD *oldDtd = _dtd;
  807.   XML_StartElementHandler oldStartElementHandler = startElementHandler;
  808.   XML_EndElementHandler oldEndElementHandler = endElementHandler;
  809.   XML_CharacterDataHandler oldCharacterDataHandler = characterDataHandler;
  810.   XML_ProcessingInstructionHandler oldProcessingInstructionHandler
  811.       = processingInstructionHandler;
  812.   XML_CommentHandler oldCommentHandler = commentHandler;
  813.   XML_StartCdataSectionHandler oldStartCdataSectionHandler
  814.       = startCdataSectionHandler;
  815.   XML_EndCdataSectionHandler oldEndCdataSectionHandler
  816.       = endCdataSectionHandler;
  817.   XML_DefaultHandler oldDefaultHandler = defaultHandler;
  818.   XML_UnparsedEntityDeclHandler oldUnparsedEntityDeclHandler
  819.       = unparsedEntityDeclHandler;
  820.   XML_NotationDeclHandler oldNotationDeclHandler = notationDeclHandler;
  821.   XML_StartNamespaceDeclHandler oldStartNamespaceDeclHandler
  822.       = startNamespaceDeclHandler;
  823.   XML_EndNamespaceDeclHandler oldEndNamespaceDeclHandler
  824.       = endNamespaceDeclHandler;
  825.   XML_NotStandaloneHandler oldNotStandaloneHandler = notStandaloneHandler;
  826.   XML_ExternalEntityRefHandler oldExternalEntityRefHandler
  827.       = externalEntityRefHandler;
  828.   XML_SkippedEntityHandler oldSkippedEntityHandler = skippedEntityHandler;
  829.   XML_UnknownEncodingHandler oldUnknownEncodingHandler
  830.       = unknownEncodingHandler;
  831.   XML_ElementDeclHandler oldElementDeclHandler = elementDeclHandler;
  832.   XML_AttlistDeclHandler oldAttlistDeclHandler = attlistDeclHandler;
  833.   XML_EntityDeclHandler oldEntityDeclHandler = entityDeclHandler;
  834.   XML_XmlDeclHandler oldXmlDeclHandler = xmlDeclHandler;
  835.   ELEMENT_TYPE * oldDeclElementType = declElementType;
  836.   void *oldUserData = userData;
  837.   void *oldHandlerArg = handlerArg;
  838.   XML_Bool oldDefaultExpandInternalEntities = defaultExpandInternalEntities;
  839.   XML_Parser oldExternalEntityRefHandlerArg = externalEntityRefHandlerArg;
  840. #ifdef XML_DTD
  841.   enum XML_ParamEntityParsing oldParamEntityParsing = paramEntityParsing;
  842.   int oldInEntityValue = prologState.inEntityValue;
  843. #endif
  844.   XML_Bool oldns_triplets = ns_triplets;
  845. #ifdef XML_DTD
  846.   if (!context)
  847.     newDtd = oldDtd;
  848. #endif /* XML_DTD */
  849.   /* Note that the magical uses of the pre-processor to make field
  850.      access look more like C++ require that `parser' be overwritten
  851.      here.  This makes this function more painful to follow than it
  852.      would be otherwise.
  853.   */
  854.   if (ns) {
  855.     XML_Char tmp[2];
  856.     *tmp = namespaceSeparator;
  857.     parser = parserCreate(encodingName, &parser->m_mem, tmp, newDtd);
  858.   }
  859.   else {
  860.     parser = parserCreate(encodingName, &parser->m_mem, NULL, newDtd);
  861.   }
  862.   if (!parser)
  863.     return NULL;
  864.   startElementHandler = oldStartElementHandler;
  865.   endElementHandler = oldEndElementHandler;
  866.   characterDataHandler = oldCharacterDataHandler;
  867.   processingInstructionHandler = oldProcessingInstructionHandler;
  868.   commentHandler = oldCommentHandler;
  869.   startCdataSectionHandler = oldStartCdataSectionHandler;
  870.   endCdataSectionHandler = oldEndCdataSectionHandler;
  871.   defaultHandler = oldDefaultHandler;
  872.   unparsedEntityDeclHandler = oldUnparsedEntityDeclHandler;
  873.   notationDeclHandler = oldNotationDeclHandler;
  874.   startNamespaceDeclHandler = oldStartNamespaceDeclHandler;
  875.   endNamespaceDeclHandler = oldEndNamespaceDeclHandler;
  876.   notStandaloneHandler = oldNotStandaloneHandler;
  877.   externalEntityRefHandler = oldExternalEntityRefHandler;
  878.   skippedEntityHandler = oldSkippedEntityHandler;
  879.   unknownEncodingHandler = oldUnknownEncodingHandler;
  880.   elementDeclHandler = oldElementDeclHandler;
  881.   attlistDeclHandler = oldAttlistDeclHandler;
  882.   entityDeclHandler = oldEntityDeclHandler;
  883.   xmlDeclHandler = oldXmlDeclHandler;
  884.   declElementType = oldDeclElementType;
  885.   userData = oldUserData;
  886.   if (oldUserData == oldHandlerArg)
  887.     handlerArg = userData;
  888.   else
  889.     handlerArg = parser;
  890.   if (oldExternalEntityRefHandlerArg != oldParser)
  891.     externalEntityRefHandlerArg = oldExternalEntityRefHandlerArg;
  892.   defaultExpandInternalEntities = oldDefaultExpandInternalEntities;
  893.   ns_triplets = oldns_triplets;
  894.   parentParser = oldParser;
  895. #ifdef XML_DTD
  896.   paramEntityParsing = oldParamEntityParsing;
  897.   prologState.inEntityValue = oldInEntityValue;
  898.   if (context) {
  899. #endif /* XML_DTD */
  900.     if (!dtdCopy(_dtd, oldDtd, &parser->m_mem)
  901.       || !setContext(parser, context)) {
  902.       XML_ParserFree(parser);
  903.       return NULL;
  904.     }
  905.     processor = externalEntityInitProcessor;
  906. #ifdef XML_DTD
  907.   }
  908.   else {
  909.     /* The DTD instance referenced by _dtd is shared between the document's
  910.        root parser and external PE parsers, therefore one does not need to
  911.        call setContext. In addition, one also *must* not call setContext,
  912.        because this would overwrite existing prefix->binding pointers in
  913.        _dtd with ones that get destroyed with the external PE parser.
  914.        This would leave those prefixes with dangling pointers.
  915.     */
  916.     isParamEntity = XML_TRUE;
  917.     XmlPrologStateInitExternalEntity(&prologState);
  918.     processor = externalParEntInitProcessor;
  919.   }
  920. #endif /* XML_DTD */
  921.   return parser;
  922. }
  923. static void FASTCALL
  924. destroyBindings(BINDING *bindings, XML_Parser parser)
  925. {
  926.   for (;;) {
  927.     BINDING *b = bindings;
  928.     if (!b)
  929.       break;
  930.     bindings = b->nextTagBinding;
  931.     FREE(b->uri);
  932.     FREE(b);
  933.   }
  934. }
  935. void
  936. XML_ParserFree(XML_Parser parser)
  937. {
  938.   for (;;) {
  939.     TAG *p;
  940.     if (tagStack == NULL) {
  941.       if (freeTagList == NULL)
  942.         break;
  943.       tagStack = freeTagList;
  944.       freeTagList = NULL;
  945.     }
  946.     p = tagStack;
  947.     tagStack = tagStack->parent;
  948.     FREE(p->buf);
  949.     destroyBindings(p->bindings, parser);
  950.     FREE(p);
  951.   }
  952.   destroyBindings(freeBindingList, parser);
  953.   destroyBindings(inheritedBindings, parser);
  954.   poolDestroy(&tempPool);
  955.   poolDestroy(&temp2Pool);
  956. #ifdef XML_DTD
  957.   /* external parameter entity parsers share the DTD structure
  958.      parser->m_dtd with the root parser, so we must not destroy it
  959.   */
  960.   if (!isParamEntity && _dtd)
  961. #else
  962.   if (_dtd)
  963. #endif /* XML_DTD */
  964.     dtdDestroy(_dtd, (XML_Bool)!parentParser, &parser->m_mem);
  965.   FREE((void *)atts);
  966.   if (groupConnector)
  967.     FREE(groupConnector);
  968.   if (buffer)
  969.     FREE(buffer);
  970.   FREE(dataBuf);
  971.   if (unknownEncodingMem)
  972.     FREE(unknownEncodingMem);
  973.   if (unknownEncodingRelease)
  974.     unknownEncodingRelease(unknownEncodingData);
  975.   FREE(parser);
  976. }
  977. void
  978. XML_UseParserAsHandlerArg(XML_Parser parser)
  979. {
  980.   handlerArg = parser;
  981. }
  982. enum XML_Error
  983. XML_UseForeignDTD(XML_Parser parser, XML_Bool useDTD)
  984. {
  985. #ifdef XML_DTD
  986.   /* block after XML_Parse()/XML_ParseBuffer() has been called */
  987.   if (parsing)
  988.     return XML_ERROR_CANT_CHANGE_FEATURE_ONCE_PARSING;
  989.   useForeignDTD = useDTD;
  990.   return XML_ERROR_NONE;
  991. #else
  992.   return XML_ERROR_FEATURE_REQUIRES_XML_DTD;
  993. #endif
  994. }
  995. void
  996. XML_SetReturnNSTriplet(XML_Parser parser, int do_nst)
  997. {
  998.   /* block after XML_Parse()/XML_ParseBuffer() has been called */
  999.   if (parsing)
  1000.     return;
  1001.   ns_triplets = do_nst ? XML_TRUE : XML_FALSE;
  1002. }
  1003. void
  1004. XML_SetUserData(XML_Parser parser, void *p)
  1005. {
  1006.   if (handlerArg == userData)
  1007.     handlerArg = userData = p;
  1008.   else
  1009.     userData = p;
  1010. }
  1011. enum XML_Status
  1012. XML_SetBase(XML_Parser parser, const XML_Char *p)
  1013. {
  1014.   if (p) {
  1015.     p = poolCopyString(&_dtd->pool, p);
  1016.     if (!p)
  1017.       return XML_STATUS_ERROR;
  1018.     curBase = p;
  1019.   }
  1020.   else
  1021.     curBase = NULL;
  1022.   return XML_STATUS_OK;
  1023. }
  1024. const XML_Char *
  1025. XML_GetBase(XML_Parser parser)
  1026. {
  1027.   return curBase;
  1028. }
  1029. int
  1030. XML_GetSpecifiedAttributeCount(XML_Parser parser)
  1031. {
  1032.   return nSpecifiedAtts;
  1033. }
  1034. int
  1035. XML_GetIdAttributeIndex(XML_Parser parser)
  1036. {
  1037.   return idAttIndex;
  1038. }
  1039. void
  1040. XML_SetElementHandler(XML_Parser parser,
  1041.                       XML_StartElementHandler start,
  1042.                       XML_EndElementHandler end)
  1043. {
  1044.   startElementHandler = start;
  1045.   endElementHandler = end;
  1046. }
  1047. void
  1048. XML_SetStartElementHandler(XML_Parser parser,
  1049.                            XML_StartElementHandler start) {
  1050.   startElementHandler = start;
  1051. }
  1052. void
  1053. XML_SetEndElementHandler(XML_Parser parser,
  1054.                          XML_EndElementHandler end) {
  1055.   endElementHandler = end;
  1056. }
  1057. void
  1058. XML_SetCharacterDataHandler(XML_Parser parser,
  1059.                             XML_CharacterDataHandler handler)
  1060. {
  1061.   characterDataHandler = handler;
  1062. }
  1063. void
  1064. XML_SetProcessingInstructionHandler(XML_Parser parser,
  1065.                                     XML_ProcessingInstructionHandler handler)
  1066. {
  1067.   processingInstructionHandler = handler;
  1068. }
  1069. void
  1070. XML_SetCommentHandler(XML_Parser parser,
  1071.                       XML_CommentHandler handler)
  1072. {
  1073.   commentHandler = handler;
  1074. }
  1075. void
  1076. XML_SetCdataSectionHandler(XML_Parser parser,
  1077.                            XML_StartCdataSectionHandler start,
  1078.                            XML_EndCdataSectionHandler end)
  1079. {
  1080.   startCdataSectionHandler = start;
  1081.   endCdataSectionHandler = end;
  1082. }
  1083. void
  1084. XML_SetStartCdataSectionHandler(XML_Parser parser,
  1085.                                 XML_StartCdataSectionHandler start) {
  1086.   startCdataSectionHandler = start;
  1087. }
  1088. void
  1089. XML_SetEndCdataSectionHandler(XML_Parser parser,
  1090.                               XML_EndCdataSectionHandler end) {
  1091.   endCdataSectionHandler = end;
  1092. }
  1093. void
  1094. XML_SetDefaultHandler(XML_Parser parser,
  1095.                       XML_DefaultHandler handler)
  1096. {
  1097.   defaultHandler = handler;
  1098.   defaultExpandInternalEntities = XML_FALSE;
  1099. }
  1100. void
  1101. XML_SetDefaultHandlerExpand(XML_Parser parser,
  1102.                             XML_DefaultHandler handler)
  1103. {
  1104.   defaultHandler = handler;
  1105.   defaultExpandInternalEntities = XML_TRUE;
  1106. }
  1107. void
  1108. XML_SetDoctypeDeclHandler(XML_Parser parser,
  1109.                           XML_StartDoctypeDeclHandler start,
  1110.                           XML_EndDoctypeDeclHandler end)
  1111. {
  1112.   startDoctypeDeclHandler = start;
  1113.   endDoctypeDeclHandler = end;
  1114. }
  1115. void
  1116. XML_SetStartDoctypeDeclHandler(XML_Parser parser,
  1117.                                XML_StartDoctypeDeclHandler start) {
  1118.   startDoctypeDeclHandler = start;
  1119. }
  1120. void
  1121. XML_SetEndDoctypeDeclHandler(XML_Parser parser,
  1122.                              XML_EndDoctypeDeclHandler end) {
  1123.   endDoctypeDeclHandler = end;
  1124. }
  1125. void
  1126. XML_SetUnparsedEntityDeclHandler(XML_Parser parser,
  1127.                                  XML_UnparsedEntityDeclHandler handler)
  1128. {
  1129.   unparsedEntityDeclHandler = handler;
  1130. }
  1131. void
  1132. XML_SetNotationDeclHandler(XML_Parser parser,
  1133.                            XML_NotationDeclHandler handler)
  1134. {
  1135.   notationDeclHandler = handler;
  1136. }
  1137. void
  1138. XML_SetNamespaceDeclHandler(XML_Parser parser,
  1139.                             XML_StartNamespaceDeclHandler start,
  1140.                             XML_EndNamespaceDeclHandler end)
  1141. {
  1142.   startNamespaceDeclHandler = start;
  1143.   endNamespaceDeclHandler = end;
  1144. }
  1145. void
  1146. XML_SetStartNamespaceDeclHandler(XML_Parser parser,
  1147.                                  XML_StartNamespaceDeclHandler start) {
  1148.   startNamespaceDeclHandler = start;
  1149. }
  1150. void
  1151. XML_SetEndNamespaceDeclHandler(XML_Parser parser,
  1152.                                XML_EndNamespaceDeclHandler end) {
  1153.   endNamespaceDeclHandler = end;
  1154. }
  1155. void
  1156. XML_SetNotStandaloneHandler(XML_Parser parser,
  1157.                             XML_NotStandaloneHandler handler)
  1158. {
  1159.   notStandaloneHandler = handler;
  1160. }
  1161. void
  1162. XML_SetExternalEntityRefHandler(XML_Parser parser,
  1163.                                 XML_ExternalEntityRefHandler handler)
  1164. {
  1165.   externalEntityRefHandler = handler;
  1166. }
  1167. void
  1168. XML_SetExternalEntityRefHandlerArg(XML_Parser parser, void *arg)
  1169. {
  1170.   if (arg)
  1171.     externalEntityRefHandlerArg = (XML_Parser)arg;
  1172.   else
  1173.     externalEntityRefHandlerArg = parser;
  1174. }
  1175. void
  1176. XML_SetSkippedEntityHandler(XML_Parser parser,
  1177.                             XML_SkippedEntityHandler handler)
  1178. {
  1179.   skippedEntityHandler = handler;
  1180. }
  1181. void
  1182. XML_SetUnknownEncodingHandler(XML_Parser parser,
  1183.                               XML_UnknownEncodingHandler handler,
  1184.                               void *data)
  1185. {
  1186.   unknownEncodingHandler = handler;
  1187.   unknownEncodingHandlerData = data;
  1188. }
  1189. void
  1190. XML_SetElementDeclHandler(XML_Parser parser,
  1191.                           XML_ElementDeclHandler eldecl)
  1192. {
  1193.   elementDeclHandler = eldecl;
  1194. }
  1195. void
  1196. XML_SetAttlistDeclHandler(XML_Parser parser,
  1197.                           XML_AttlistDeclHandler attdecl)
  1198. {
  1199.   attlistDeclHandler = attdecl;
  1200. }
  1201. void
  1202. XML_SetEntityDeclHandler(XML_Parser parser,
  1203.                          XML_EntityDeclHandler handler)
  1204. {
  1205.   entityDeclHandler = handler;
  1206. }
  1207. void
  1208. XML_SetXmlDeclHandler(XML_Parser parser,
  1209.                       XML_XmlDeclHandler handler) {
  1210.   xmlDeclHandler = handler;
  1211. }
  1212. int
  1213. XML_SetParamEntityParsing(XML_Parser parser,
  1214.                           enum XML_ParamEntityParsing peParsing)
  1215. {
  1216.   /* block after XML_Parse()/XML_ParseBuffer() has been called */
  1217.   if (parsing)
  1218.     return 0;
  1219. #ifdef XML_DTD
  1220.   paramEntityParsing = peParsing;
  1221.   return 1;
  1222. #else
  1223.   return peParsing == XML_PARAM_ENTITY_PARSING_NEVER;
  1224. #endif
  1225. }
  1226. enum XML_Status
  1227. XML_Parse(XML_Parser parser, const char *s, int len, int isFinal)
  1228. {
  1229.   if (len == 0) {
  1230.     if (!isFinal)
  1231.       return XML_STATUS_OK;
  1232.     positionPtr = bufferPtr;
  1233.     errorCode = processor(parser, bufferPtr, parseEndPtr = bufferEnd, 0);
  1234.     if (errorCode == XML_ERROR_NONE)
  1235.       return XML_STATUS_OK;
  1236.     eventEndPtr = eventPtr;
  1237.     processor = errorProcessor;
  1238.     return XML_STATUS_ERROR;
  1239.   }
  1240. #ifndef XML_CONTEXT_BYTES
  1241.   else if (bufferPtr == bufferEnd) {
  1242.     const char *end;
  1243.     int nLeftOver;
  1244.     parseEndByteIndex += len;
  1245.     positionPtr = s;
  1246.     if (isFinal) {
  1247.       errorCode = processor(parser, s, parseEndPtr = s + len, 0);
  1248.       if (errorCode == XML_ERROR_NONE)
  1249.         return XML_STATUS_OK;
  1250.       eventEndPtr = eventPtr;
  1251.       processor = errorProcessor;
  1252.       return XML_STATUS_ERROR;
  1253.     }
  1254.     errorCode = processor(parser, s, parseEndPtr = s + len, &end);
  1255.     if (errorCode != XML_ERROR_NONE) {
  1256.       eventEndPtr = eventPtr;
  1257.       processor = errorProcessor;
  1258.       return XML_STATUS_ERROR;
  1259.     }
  1260.     XmlUpdatePosition(encoding, positionPtr, end, &position);
  1261.     positionPtr = end;
  1262.     nLeftOver = s + len - end;
  1263.     if (nLeftOver) {
  1264.       if (buffer == NULL || nLeftOver > bufferLim - buffer) {
  1265.         /* FIXME avoid integer overflow */
  1266.         char *temp;
  1267.         temp = (buffer == NULL
  1268.                 ? (char *)MALLOC(len * 2)
  1269.                 : (char *)REALLOC(buffer, len * 2));
  1270.         if (temp == NULL) {
  1271.           errorCode = XML_ERROR_NO_MEMORY;
  1272.           return XML_STATUS_ERROR;
  1273.         }
  1274.         buffer = temp;
  1275.         if (!buffer) {
  1276.           errorCode = XML_ERROR_NO_MEMORY;
  1277.           eventPtr = eventEndPtr = NULL;
  1278.           processor = errorProcessor;
  1279.           return XML_STATUS_ERROR;
  1280.         }
  1281.         bufferLim = buffer + len * 2;
  1282.       }
  1283.       memcpy(buffer, end, nLeftOver);
  1284.       bufferPtr = buffer;
  1285.       bufferEnd = buffer + nLeftOver;
  1286.     }
  1287.     return XML_STATUS_OK;
  1288.   }
  1289. #endif  /* not defined XML_CONTEXT_BYTES */
  1290.   else {
  1291.     void *buff = XML_GetBuffer(parser, len);
  1292.     if (buff == NULL)
  1293.       return XML_STATUS_ERROR;
  1294.     else {
  1295.       memcpy(buff, s, len);
  1296.       return XML_ParseBuffer(parser, len, isFinal);
  1297.     }
  1298.   }
  1299. }
  1300. enum XML_Status
  1301. XML_ParseBuffer(XML_Parser parser, int len, int isFinal)
  1302. {
  1303.   const char *start = bufferPtr;
  1304.   positionPtr = start;
  1305.   bufferEnd += len;
  1306.   parseEndByteIndex += len;
  1307.   errorCode = processor(parser, start, parseEndPtr = bufferEnd,
  1308.                         isFinal ? (const char **)NULL : &bufferPtr);
  1309.   if (errorCode == XML_ERROR_NONE) {
  1310.     if (!isFinal) {
  1311.       XmlUpdatePosition(encoding, positionPtr, bufferPtr, &position);
  1312.       positionPtr = bufferPtr;
  1313.     }
  1314.     return XML_STATUS_OK;
  1315.   }
  1316.   else {
  1317.     eventEndPtr = eventPtr;
  1318.     processor = errorProcessor;
  1319.     return XML_STATUS_ERROR;
  1320.   }
  1321. }
  1322. void *
  1323. XML_GetBuffer(XML_Parser parser, int len)
  1324. {
  1325.   if (len > bufferLim - bufferEnd) {
  1326.     /* FIXME avoid integer overflow */
  1327.     int neededSize = len + (bufferEnd - bufferPtr);
  1328. #ifdef XML_CONTEXT_BYTES
  1329.     int keep = bufferPtr - buffer;
  1330.     if (keep > XML_CONTEXT_BYTES)
  1331.       keep = XML_CONTEXT_BYTES;
  1332.     neededSize += keep;
  1333. #endif  /* defined XML_CONTEXT_BYTES */
  1334.     if (neededSize  <= bufferLim - buffer) {
  1335. #ifdef XML_CONTEXT_BYTES
  1336.       if (keep < bufferPtr - buffer) {
  1337.         int offset = (bufferPtr - buffer) - keep;
  1338.         memmove(buffer, &buffer[offset], bufferEnd - bufferPtr + keep);
  1339.         bufferEnd -= offset;
  1340.         bufferPtr -= offset;
  1341.       }
  1342. #else
  1343.       memmove(buffer, bufferPtr, bufferEnd - bufferPtr);
  1344.       bufferEnd = buffer + (bufferEnd - bufferPtr);
  1345.       bufferPtr = buffer;
  1346. #endif  /* not defined XML_CONTEXT_BYTES */
  1347.     }
  1348.     else {
  1349.       char *newBuf;
  1350.       int bufferSize = bufferLim - bufferPtr;
  1351.       if (bufferSize == 0)
  1352.         bufferSize = INIT_BUFFER_SIZE;
  1353.       do {
  1354.         bufferSize *= 2;
  1355.       } while (bufferSize < neededSize);
  1356.       newBuf = (char *)MALLOC(bufferSize);
  1357.       if (newBuf == 0) {
  1358.         errorCode = XML_ERROR_NO_MEMORY;
  1359.         return NULL;
  1360.       }
  1361.       bufferLim = newBuf + bufferSize;
  1362. #ifdef XML_CONTEXT_BYTES
  1363.       if (bufferPtr) {
  1364.         int keep = bufferPtr - buffer;
  1365.         if (keep > XML_CONTEXT_BYTES)
  1366.           keep = XML_CONTEXT_BYTES;
  1367.         memcpy(newBuf, &bufferPtr[-keep], bufferEnd - bufferPtr + keep);
  1368.         FREE(buffer);
  1369.         buffer = newBuf;
  1370.         bufferEnd = buffer + (bufferEnd - bufferPtr) + keep;
  1371.         bufferPtr = buffer + keep;
  1372.       }
  1373.       else {
  1374.         bufferEnd = newBuf + (bufferEnd - bufferPtr);
  1375.         bufferPtr = buffer = newBuf;
  1376.       }
  1377. #else
  1378.       if (bufferPtr) {
  1379.         memcpy(newBuf, bufferPtr, bufferEnd - bufferPtr);
  1380.         FREE(buffer);
  1381.       }
  1382.       bufferEnd = newBuf + (bufferEnd - bufferPtr);
  1383.       bufferPtr = buffer = newBuf;
  1384. #endif  /* not defined XML_CONTEXT_BYTES */
  1385.     }
  1386.   }
  1387.   return bufferEnd;
  1388. }
  1389. enum XML_Error
  1390. XML_GetErrorCode(XML_Parser parser)
  1391. {
  1392.   return errorCode;
  1393. }
  1394. long
  1395. XML_GetCurrentByteIndex(XML_Parser parser)
  1396. {
  1397.   if (eventPtr)
  1398.     return parseEndByteIndex - (parseEndPtr - eventPtr);
  1399.   return -1;
  1400. }
  1401. int
  1402. XML_GetCurrentByteCount(XML_Parser parser)
  1403. {
  1404.   if (eventEndPtr && eventPtr)
  1405.     return eventEndPtr - eventPtr;
  1406.   return 0;
  1407. }
  1408. const char *
  1409. XML_GetInputContext(XML_Parser parser, int *offset, int *size)
  1410. {
  1411. #ifdef XML_CONTEXT_BYTES
  1412.   if (eventPtr && buffer) {
  1413.     *offset = eventPtr - buffer;
  1414.     *size   = bufferEnd - buffer;
  1415.     return buffer;
  1416.   }
  1417. #endif /* defined XML_CONTEXT_BYTES */
  1418.   return (char *) 0;
  1419. }
  1420. int
  1421. XML_GetCurrentLineNumber(XML_Parser parser)
  1422. {
  1423.   if (eventPtr) {
  1424.     XmlUpdatePosition(encoding, positionPtr, eventPtr, &position);
  1425.     positionPtr = eventPtr;
  1426.   }
  1427.   return position.lineNumber + 1;
  1428. }
  1429. int
  1430. XML_GetCurrentColumnNumber(XML_Parser parser)
  1431. {
  1432.   if (eventPtr) {
  1433.     XmlUpdatePosition(encoding, positionPtr, eventPtr, &position);
  1434.     positionPtr = eventPtr;
  1435.   }
  1436.   return position.columnNumber;
  1437. }
  1438. void
  1439. XML_FreeContentModel(XML_Parser parser, XML_Content *model)
  1440. {
  1441.   FREE(model);
  1442. }
  1443. void *
  1444. XML_MemMalloc(XML_Parser parser, size_t size)
  1445. {
  1446.   return MALLOC(size);
  1447. }
  1448. void *
  1449. XML_MemRealloc(XML_Parser parser, void *ptr, size_t size)
  1450. {
  1451.   return REALLOC(ptr, size);
  1452. }
  1453. void
  1454. XML_MemFree(XML_Parser parser, void *ptr)
  1455. {
  1456.   FREE(ptr);
  1457. }
  1458. void
  1459. XML_DefaultCurrent(XML_Parser parser)
  1460. {
  1461.   if (defaultHandler) {
  1462.     if (openInternalEntities)
  1463.       reportDefault(parser,
  1464.                     internalEncoding,
  1465.                     openInternalEntities->internalEventPtr,
  1466.                     openInternalEntities->internalEventEndPtr);
  1467.     else
  1468.       reportDefault(parser, encoding, eventPtr, eventEndPtr);
  1469.   }
  1470. }
  1471. const XML_LChar *
  1472. XML_ErrorString(enum XML_Error code)
  1473. {
  1474.   static const XML_LChar *message[] = {
  1475.     0,
  1476.     XML_L("out of memory"),
  1477.     XML_L("syntax error"),
  1478.     XML_L("no element found"),
  1479.     XML_L("not well-formed (invalid token)"),
  1480.     XML_L("unclosed token"),
  1481.     XML_L("partial character"),
  1482.     XML_L("mismatched tag"),
  1483.     XML_L("duplicate attribute"),
  1484.     XML_L("junk after document element"),
  1485.     XML_L("illegal parameter entity reference"),
  1486.     XML_L("undefined entity"),
  1487.     XML_L("recursive entity reference"),
  1488.     XML_L("asynchronous entity"),
  1489.     XML_L("reference to invalid character number"),
  1490.     XML_L("reference to binary entity"),
  1491.     XML_L("reference to external entity in attribute"),
  1492.     XML_L("xml declaration not at start of external entity"),
  1493.     XML_L("unknown encoding"),
  1494.     XML_L("encoding specified in XML declaration is incorrect"),
  1495.     XML_L("unclosed CDATA section"),
  1496.     XML_L("error in processing external entity reference"),
  1497.     XML_L("document is not standalone"),
  1498.     XML_L("unexpected parser state - please send a bug report"),
  1499.     XML_L("entity declared in parameter entity"),
  1500.     XML_L("requested feature requires XML_DTD support in Expat"),
  1501.     XML_L("cannot change setting once parsing has begun")
  1502.   };
  1503.   if (code > 0 && code < sizeof(message)/sizeof(message[0]))
  1504.     return message[code];
  1505.   return NULL;
  1506. }
  1507. const XML_LChar *
  1508. XML_ExpatVersion(void) {
  1509.   /* V1 is used to string-ize the version number. However, it would
  1510.      string-ize the actual version macro *names* unless we get them
  1511.      substituted before being passed to V1. CPP is defined to expand
  1512.      a macro, then rescan for more expansions. Thus, we use V2 to expand
  1513.      the version macros, then CPP will expand the resulting V1() macro
  1514.      with the correct numerals. */
  1515.   /* ### I'm assuming cpp is portable in this respect... */
  1516. #define V1(a,b,c) XML_L(#a)XML_L(".")XML_L(#b)XML_L(".")XML_L(#c)
  1517. #define V2(a,b,c) XML_L("expat_")V1(a,b,c)
  1518.   return V2(XML_MAJOR_VERSION, XML_MINOR_VERSION, XML_MICRO_VERSION);
  1519. #undef V1
  1520. #undef V2
  1521. }
  1522. XML_Expat_Version
  1523. XML_ExpatVersionInfo(void)
  1524. {
  1525.   XML_Expat_Version version;
  1526.   version.major = XML_MAJOR_VERSION;
  1527.   version.minor = XML_MINOR_VERSION;
  1528.   version.micro = XML_MICRO_VERSION;
  1529.   return version;
  1530. }
  1531. const XML_Feature *
  1532. XML_GetFeatureList(void)
  1533. {
  1534.   static XML_Feature features[] = {
  1535.     {XML_FEATURE_SIZEOF_XML_CHAR,  XML_L("sizeof(XML_Char)")},
  1536.     {XML_FEATURE_SIZEOF_XML_LCHAR, XML_L("sizeof(XML_LChar)")},
  1537. #ifdef XML_UNICODE
  1538.     {XML_FEATURE_UNICODE,          XML_L("XML_UNICODE")},
  1539. #endif
  1540. #ifdef XML_UNICODE_WCHAR_T
  1541.     {XML_FEATURE_UNICODE_WCHAR_T,  XML_L("XML_UNICODE_WCHAR_T")},
  1542. #endif
  1543. #ifdef XML_DTD
  1544.     {XML_FEATURE_DTD,              XML_L("XML_DTD")},
  1545. #endif
  1546. #ifdef XML_CONTEXT_BYTES
  1547.     {XML_FEATURE_CONTEXT_BYTES,    XML_L("XML_CONTEXT_BYTES"),
  1548.      XML_CONTEXT_BYTES},
  1549. #endif
  1550. #ifdef XML_MIN_SIZE
  1551.     {XML_FEATURE_MIN_SIZE,         XML_L("XML_MIN_SIZE")},
  1552. #endif
  1553.     {XML_FEATURE_END,              NULL}
  1554.   };
  1555.   features[0].value = sizeof(XML_Char);
  1556.   features[1].value = sizeof(XML_LChar);
  1557.   return features;
  1558. }
  1559. /* Initially tag->rawName always points into the parse buffer;
  1560.    for those TAG instances opened while the current parse buffer was
  1561.    processed, and not yet closed, we need to store tag->rawName in a more
  1562.    permanent location, since the parse buffer is about to be discarded.
  1563. */
  1564. static XML_Bool
  1565. storeRawNames(XML_Parser parser)
  1566. {
  1567.   TAG *tag = tagStack;
  1568.   while (tag) {
  1569.     int bufSize;
  1570.     int nameLen = sizeof(XML_Char) * (tag->name.strLen + 1);
  1571.     char *rawNameBuf = tag->buf + nameLen;
  1572.     /* Stop if already stored.  Since tagStack is a stack, we can stop
  1573.        at the first entry that has already been copied; everything
  1574.        below it in the stack is already been accounted for in a
  1575.        previous call to this function.
  1576.     */
  1577.     if (tag->rawName == rawNameBuf)
  1578.       break;
  1579.     /* For re-use purposes we need to ensure that the
  1580.        size of tag->buf is a multiple of sizeof(XML_Char).
  1581.     */
  1582.     bufSize = nameLen + ROUND_UP(tag->rawNameLength, sizeof(XML_Char));
  1583.     if (bufSize > tag->bufEnd - tag->buf) {
  1584.       char *temp = (char *)REALLOC(tag->buf, bufSize);
  1585.       if (temp == NULL)
  1586.         return XML_FALSE;
  1587.       /* if tag->name.str points to tag->buf (only when namespace
  1588.          processing is off) then we have to update it
  1589.       */
  1590.       if (tag->name.str == (XML_Char *)tag->buf)
  1591.         tag->name.str = (XML_Char *)temp;
  1592.       /* if tag->name.localPart is set (when namespace processing is on)
  1593.          then update it as well, since it will always point into tag->buf
  1594.       */
  1595.       if (tag->name.localPart)
  1596.         tag->name.localPart = (XML_Char *)temp + (tag->name.localPart -
  1597.                                                   (XML_Char *)tag->buf);
  1598.       tag->buf = temp;
  1599.       tag->bufEnd = temp + bufSize;
  1600.       rawNameBuf = temp + nameLen;
  1601.     }
  1602.     memcpy(rawNameBuf, tag->rawName, tag->rawNameLength);
  1603.     tag->rawName = rawNameBuf;
  1604.     tag = tag->parent;
  1605.   }
  1606.   return XML_TRUE;
  1607. }
  1608. static enum XML_Error PTRCALL
  1609. contentProcessor(XML_Parser parser,
  1610.                  const char *start,
  1611.                  const char *end,
  1612.                  const char **endPtr)
  1613. {
  1614.   enum XML_Error result =
  1615.     doContent(parser, 0, encoding, start, end, endPtr);
  1616.   if (result != XML_ERROR_NONE)
  1617.     return result;
  1618.   if (!storeRawNames(parser))
  1619.     return XML_ERROR_NO_MEMORY;
  1620.   return result;
  1621. }
  1622. static enum XML_Error PTRCALL
  1623. externalEntityInitProcessor(XML_Parser parser,
  1624.                             const char *start,
  1625.                             const char *end,
  1626.                             const char **endPtr)
  1627. {
  1628.   enum XML_Error result = initializeEncoding(parser);
  1629.   if (result != XML_ERROR_NONE)
  1630.     return result;
  1631.   processor = externalEntityInitProcessor2;
  1632.   return externalEntityInitProcessor2(parser, start, end, endPtr);
  1633. }
  1634. static enum XML_Error PTRCALL
  1635. externalEntityInitProcessor2(XML_Parser parser,
  1636.                              const char *start,
  1637.                              const char *end,
  1638.                              const char **endPtr)
  1639. {
  1640.   const char *next = start; /* XmlContentTok doesn't always set the last arg */
  1641.   int tok = XmlContentTok(encoding, start, end, &next);
  1642.   switch (tok) {
  1643.   case XML_TOK_BOM:
  1644.     /* If we are at the end of the buffer, this would cause the next stage,
  1645.        i.e. externalEntityInitProcessor3, to pass control directly to
  1646.        doContent (by detecting XML_TOK_NONE) without processing any xml text
  1647.        declaration - causing the error XML_ERROR_MISPLACED_XML_PI in doContent.
  1648.     */
  1649.     if (next == end && endPtr) {
  1650.       *endPtr = next;
  1651.       return XML_ERROR_NONE;
  1652.     }
  1653.     start = next;
  1654.     break;
  1655.   case XML_TOK_PARTIAL:
  1656.     if (endPtr) {
  1657.       *endPtr = start;
  1658.       return XML_ERROR_NONE;
  1659.     }
  1660.     eventPtr = start;
  1661.     return XML_ERROR_UNCLOSED_TOKEN;
  1662.   case XML_TOK_PARTIAL_CHAR:
  1663.     if (endPtr) {
  1664.       *endPtr = start;
  1665.       return XML_ERROR_NONE;
  1666.     }
  1667.     eventPtr = start;
  1668.     return XML_ERROR_PARTIAL_CHAR;
  1669.   }
  1670.   processor = externalEntityInitProcessor3;
  1671.   return externalEntityInitProcessor3(parser, start, end, endPtr);
  1672. }
  1673. static enum XML_Error PTRCALL
  1674. externalEntityInitProcessor3(XML_Parser parser,
  1675.                              const char *start,
  1676.                              const char *end,
  1677.                              const char **endPtr)
  1678. {
  1679.   const char *next = start; /* XmlContentTok doesn't always set the last arg */
  1680.   int tok = XmlContentTok(encoding, start, end, &next);
  1681.   switch (tok) {
  1682.   case XML_TOK_XML_DECL:
  1683.     {
  1684.       enum XML_Error result = processXmlDecl(parser, 1, start, next);
  1685.       if (result != XML_ERROR_NONE)
  1686.         return result;
  1687.       start = next;
  1688.     }
  1689.     break;
  1690.   case XML_TOK_PARTIAL:
  1691.     if (endPtr) {
  1692.       *endPtr = start;
  1693.       return XML_ERROR_NONE;
  1694.     }
  1695.     eventPtr = start;
  1696.     return XML_ERROR_UNCLOSED_TOKEN;
  1697.   case XML_TOK_PARTIAL_CHAR:
  1698.     if (endPtr) {
  1699.       *endPtr = start;
  1700.       return XML_ERROR_NONE;
  1701.     }
  1702.     eventPtr = start;
  1703.     return XML_ERROR_PARTIAL_CHAR;
  1704.   }
  1705.   processor = externalEntityContentProcessor;
  1706.   tagLevel = 1;
  1707.   return externalEntityContentProcessor(parser, start, end, endPtr);
  1708. }
  1709. static enum XML_Error PTRCALL
  1710. externalEntityContentProcessor(XML_Parser parser,
  1711.                                const char *start,
  1712.                                const char *end,
  1713.                                const char **endPtr)
  1714. {
  1715.   enum XML_Error result =
  1716.     doContent(parser, 1, encoding, start, end, endPtr);
  1717.   if (result != XML_ERROR_NONE)
  1718.     return result;
  1719.   if (!storeRawNames(parser))
  1720.     return XML_ERROR_NO_MEMORY;
  1721.   return result;
  1722. }
  1723. static enum XML_Error
  1724. doContent(XML_Parser parser,
  1725.           int startTagLevel,
  1726.           const ENCODING *enc,
  1727.           const char *s,
  1728.           const char *end,
  1729.           const char **nextPtr)
  1730. {
  1731.   DTD * const dtd = _dtd;  /* save one level of indirection */
  1732.   const char **eventPP;
  1733.   const char **eventEndPP;
  1734.   if (enc == encoding) {
  1735.     eventPP = &eventPtr;
  1736.     eventEndPP = &eventEndPtr;
  1737.   }
  1738.   else {
  1739.     eventPP = &(openInternalEntities->internalEventPtr);
  1740.     eventEndPP = &(openInternalEntities->internalEventEndPtr);
  1741.   }
  1742.   *eventPP = s;
  1743.   for (;;) {
  1744.     const char *next = s; /* XmlContentTok doesn't always set the last arg */
  1745.     int tok = XmlContentTok(enc, s, end, &next);
  1746.     *eventEndPP = next;
  1747.     switch (tok) {
  1748.     case XML_TOK_TRAILING_CR:
  1749.       if (nextPtr) {
  1750.         *nextPtr = s;
  1751.         return XML_ERROR_NONE;
  1752.       }
  1753.       *eventEndPP = end;
  1754.       if (characterDataHandler) {
  1755.         XML_Char c = 0xA;
  1756.         characterDataHandler(handlerArg, &c, 1);
  1757.       }
  1758.       else if (defaultHandler)
  1759.         reportDefault(parser, enc, s, end);
  1760.       if (startTagLevel == 0)
  1761.         return XML_ERROR_NO_ELEMENTS;
  1762.       if (tagLevel != startTagLevel)
  1763.         return XML_ERROR_ASYNC_ENTITY;
  1764.       return XML_ERROR_NONE;
  1765.     case XML_TOK_NONE:
  1766.       if (nextPtr) {
  1767.         *nextPtr = s;
  1768.         return XML_ERROR_NONE;
  1769.       }
  1770.       if (startTagLevel > 0) {
  1771.         if (tagLevel != startTagLevel)
  1772.           return XML_ERROR_ASYNC_ENTITY;
  1773.         return XML_ERROR_NONE;
  1774.       }
  1775.       return XML_ERROR_NO_ELEMENTS;
  1776.     case XML_TOK_INVALID:
  1777.       *eventPP = next;
  1778.       return XML_ERROR_INVALID_TOKEN;
  1779.     case XML_TOK_PARTIAL:
  1780.       if (nextPtr) {
  1781.         *nextPtr = s;
  1782.         return XML_ERROR_NONE;
  1783.       }
  1784.       return XML_ERROR_UNCLOSED_TOKEN;
  1785.     case XML_TOK_PARTIAL_CHAR:
  1786.       if (nextPtr) {
  1787.         *nextPtr = s;
  1788.         return XML_ERROR_NONE;
  1789.       }
  1790.       return XML_ERROR_PARTIAL_CHAR;
  1791.     case XML_TOK_ENTITY_REF:
  1792.       {
  1793.         const XML_Char *name;
  1794.         ENTITY *entity;
  1795.         XML_Char ch = (XML_Char) XmlPredefinedEntityName(enc,
  1796.                                               s + enc->minBytesPerChar,
  1797.                                               next - enc->minBytesPerChar);
  1798.         if (ch) {
  1799.           if (characterDataHandler)
  1800.             characterDataHandler(handlerArg, &ch, 1);
  1801.           else if (defaultHandler)
  1802.             reportDefault(parser, enc, s, next);
  1803.           break;
  1804.         }
  1805.         name = poolStoreString(&dtd->pool, enc,
  1806.                                 s + enc->minBytesPerChar,
  1807.                                 next - enc->minBytesPerChar);
  1808.         if (!name)
  1809.           return XML_ERROR_NO_MEMORY;
  1810.         entity = (ENTITY *)lookup(&dtd->generalEntities, name, 0);
  1811.         poolDiscard(&dtd->pool);
  1812.         /* First, determine if a check for an existing declaration is needed;
  1813.            if yes, check that the entity exists, and that it is internal,
  1814.            otherwise call the skipped entity or default handler.
  1815.         */
  1816.         if (!dtd->hasParamEntityRefs || dtd->standalone) {
  1817.           if (!entity)
  1818.             return XML_ERROR_UNDEFINED_ENTITY;
  1819.           else if (!entity->is_internal)
  1820.             return XML_ERROR_ENTITY_DECLARED_IN_PE;
  1821.         }
  1822.         else if (!entity) {
  1823.           if (skippedEntityHandler)
  1824.             skippedEntityHandler(handlerArg, name, 0);
  1825.           else if (defaultHandler)
  1826.             reportDefault(parser, enc, s, next);
  1827.           break;
  1828.         }
  1829.         if (entity->open)
  1830.           return XML_ERROR_RECURSIVE_ENTITY_REF;
  1831.         if (entity->notation)
  1832.           return XML_ERROR_BINARY_ENTITY_REF;
  1833.         if (entity->textPtr) {
  1834.           enum XML_Error result;
  1835.           OPEN_INTERNAL_ENTITY openEntity;
  1836.           if (!defaultExpandInternalEntities) {
  1837.             if (skippedEntityHandler)
  1838.               skippedEntityHandler(handlerArg, entity->name, 0);
  1839.             else if (defaultHandler)
  1840.               reportDefault(parser, enc, s, next);
  1841.             break;
  1842.           }
  1843.           entity->open = XML_TRUE;
  1844.           openEntity.next = openInternalEntities;
  1845.           openInternalEntities = &openEntity;
  1846.           openEntity.entity = entity;
  1847.           openEntity.internalEventPtr = NULL;
  1848.           openEntity.internalEventEndPtr = NULL;
  1849.           result = doContent(parser,
  1850.                              tagLevel,
  1851.                              internalEncoding,
  1852.                              (char *)entity->textPtr,
  1853.                              (char *)(entity->textPtr + entity->textLen),
  1854.                              0);
  1855.           entity->open = XML_FALSE;
  1856.           openInternalEntities = openEntity.next;
  1857.           if (result)
  1858.             return result;
  1859.         }
  1860.         else if (externalEntityRefHandler) {
  1861.           const XML_Char *context;
  1862.           entity->open = XML_TRUE;
  1863.           context = getContext(parser);
  1864.           entity->open = XML_FALSE;
  1865.           if (!context)
  1866.             return XML_ERROR_NO_MEMORY;
  1867.           if (!externalEntityRefHandler((XML_Parser)externalEntityRefHandlerArg,
  1868.                                         context,
  1869.                                         entity->base,
  1870.                                         entity->systemId,
  1871.                                         entity->publicId))
  1872.             return XML_ERROR_EXTERNAL_ENTITY_HANDLING;
  1873.           poolDiscard(&tempPool);
  1874.         }
  1875.         else if (defaultHandler)
  1876.           reportDefault(parser, enc, s, next);
  1877.         break;
  1878.       }
  1879.     case XML_TOK_START_TAG_WITH_ATTS:
  1880.       if (!startElementHandler) {
  1881.         enum XML_Error result = storeAtts(parser, enc, s, 0, 0);
  1882.         if (result)
  1883.           return result;
  1884.       }
  1885.       /* fall through */
  1886.     case XML_TOK_START_TAG_NO_ATTS:
  1887.       {
  1888.         TAG *tag;
  1889.         enum XML_Error result;
  1890.         XML_Char *toPtr;
  1891.         if (freeTagList) {
  1892.           tag = freeTagList;
  1893.           freeTagList = freeTagList->parent;
  1894.         }
  1895.         else {
  1896.           tag = (TAG *)MALLOC(sizeof(TAG));
  1897.           if (!tag)
  1898.             return XML_ERROR_NO_MEMORY;
  1899.           tag->buf = (char *)MALLOC(INIT_TAG_BUF_SIZE);
  1900.           if (!tag->buf) {
  1901.             FREE(tag);
  1902.             return XML_ERROR_NO_MEMORY;
  1903.           }
  1904.           tag->bufEnd = tag->buf + INIT_TAG_BUF_SIZE;
  1905.         }
  1906.         tag->bindings = NULL;
  1907.         tag->parent = tagStack;
  1908.         tagStack = tag;
  1909.         tag->name.localPart = NULL;
  1910.         tag->name.prefix = NULL;
  1911.         tag->rawName = s + enc->minBytesPerChar;
  1912.         tag->rawNameLength = XmlNameLength(enc, tag->rawName);
  1913.         ++tagLevel;
  1914.         {
  1915.           const char *rawNameEnd = tag->rawName + tag->rawNameLength;
  1916.           const char *fromPtr = tag->rawName;
  1917.           toPtr = (XML_Char *)tag->buf;
  1918.           for (;;) {
  1919.             int bufSize;
  1920.             int convLen;
  1921.             XmlConvert(enc,
  1922.                        &fromPtr, rawNameEnd,
  1923.                        (ICHAR **)&toPtr, (ICHAR *)tag->bufEnd - 1);
  1924.             convLen = toPtr - (XML_Char *)tag->buf;
  1925.             if (fromPtr == rawNameEnd) {
  1926.               tag->name.strLen = convLen;
  1927.               break;
  1928.             }
  1929.             bufSize = (tag->bufEnd - tag->buf) << 1;
  1930.             {
  1931.               char *temp = (char *)REALLOC(tag->buf, bufSize);
  1932.               if (temp == NULL)
  1933.                 return XML_ERROR_NO_MEMORY;
  1934.               tag->buf = temp;
  1935.               tag->bufEnd = temp + bufSize;
  1936.               toPtr = (XML_Char *)temp + convLen;
  1937.             }
  1938.           }
  1939.         }
  1940.         tag->name.str = (XML_Char *)tag->buf;
  1941.         *toPtr = XML_T('');
  1942.         if (startElementHandler) {
  1943.           result = storeAtts(parser, enc, s, &(tag->name), &(tag->bindings));
  1944.           if (result)
  1945.             return result;
  1946.           if (startElementHandler)
  1947.             startElementHandler(handlerArg, tag->name.str,
  1948.                                 (const XML_Char **)atts);
  1949.         }
  1950.         else if (defaultHandler)
  1951.           reportDefault(parser, enc, s, next);
  1952.         poolClear(&tempPool);
  1953.         break;
  1954.       }
  1955.     case XML_TOK_EMPTY_ELEMENT_WITH_ATTS:
  1956.       if (!startElementHandler) {
  1957.         enum XML_Error result = storeAtts(parser, enc, s, 0, 0);
  1958.         if (result)
  1959.           return result;
  1960.       }
  1961.       /* fall through */
  1962.     case XML_TOK_EMPTY_ELEMENT_NO_ATTS:
  1963.       if (startElementHandler || endElementHandler) {
  1964.         const char *rawName = s + enc->minBytesPerChar;
  1965.         enum XML_Error result;
  1966.         BINDING *bindings = NULL;
  1967.         TAG_NAME name;
  1968.         name.str = poolStoreString(&tempPool, enc, rawName,
  1969.                                    rawName + XmlNameLength(enc, rawName));
  1970.         if (!name.str)
  1971.           return XML_ERROR_NO_MEMORY;
  1972.         poolFinish(&tempPool);
  1973.         result = storeAtts(parser, enc, s, &name, &bindings);
  1974.         if (result)
  1975.           return result;
  1976.         poolFinish(&tempPool);
  1977.         if (startElementHandler)
  1978.           startElementHandler(handlerArg, name.str, (const XML_Char **)atts);
  1979.         if (endElementHandler) {
  1980.           if (startElementHandler)
  1981.             *eventPP = *eventEndPP;
  1982.           endElementHandler(handlerArg, name.str);
  1983.         }
  1984.         poolClear(&tempPool);
  1985.         while (bindings) {
  1986.           BINDING *b = bindings;
  1987.           if (endNamespaceDeclHandler)
  1988.             endNamespaceDeclHandler(handlerArg, b->prefix->name);
  1989.           bindings = bindings->nextTagBinding;
  1990.           b->nextTagBinding = freeBindingList;
  1991.           freeBindingList = b;
  1992.           b->prefix->binding = b->prevPrefixBinding;
  1993.         }
  1994.       }
  1995.       else if (defaultHandler)
  1996.         reportDefault(parser, enc, s, next);
  1997.       if (tagLevel == 0)
  1998.         return epilogProcessor(parser, next, end, nextPtr);
  1999.       break;
  2000.     case XML_TOK_END_TAG:
  2001.       if (tagLevel == startTagLevel)
  2002.         return XML_ERROR_ASYNC_ENTITY;
  2003.       else {
  2004.         int len;
  2005.         const char *rawName;
  2006.         TAG *tag = tagStack;
  2007.         tagStack = tag->parent;
  2008.         tag->parent = freeTagList;
  2009.         freeTagList = tag;
  2010.         rawName = s + enc->minBytesPerChar*2;
  2011.         len = XmlNameLength(enc, rawName);
  2012.         if (len != tag->rawNameLength
  2013.             || memcmp(tag->rawName, rawName, len) != 0) {
  2014.           *eventPP = rawName;
  2015.           return XML_ERROR_TAG_MISMATCH;
  2016.         }
  2017.         --tagLevel;
  2018.         if (endElementHandler) {
  2019.           const XML_Char *localPart;
  2020.           const XML_Char *prefix;
  2021.           XML_Char *uri;
  2022.           localPart = tag->name.localPart;
  2023.           if (ns && localPart) {
  2024.             /* localPart and prefix may have been overwritten in
  2025.                tag->name.str, since this points to the binding->uri
  2026.                buffer which gets re-used; so we have to add them again
  2027.             */
  2028.             uri = (XML_Char *)tag->name.str + tag->name.uriLen;
  2029.             /* don't need to check for space - already done in storeAtts() */
  2030.             while (*localPart) *uri++ = *localPart++;
  2031.             prefix = (XML_Char *)tag->name.prefix;
  2032.             if (ns_triplets && prefix) {
  2033.               *uri++ = namespaceSeparator;
  2034.               while (*prefix) *uri++ = *prefix++;
  2035.              }
  2036.             *uri = XML_T('');
  2037.           }
  2038.           endElementHandler(handlerArg, tag->name.str);
  2039.         }
  2040.         else if (defaultHandler)
  2041.           reportDefault(parser, enc, s, next);
  2042.         while (tag->bindings) {
  2043.           BINDING *b = tag->bindings;
  2044.           if (endNamespaceDeclHandler)
  2045.             endNamespaceDeclHandler(handlerArg, b->prefix->name);
  2046.           tag->bindings = tag->bindings->nextTagBinding;
  2047.           b->nextTagBinding = freeBindingList;
  2048.           freeBindingList = b;
  2049.           b->prefix->binding = b->prevPrefixBinding;
  2050.         }
  2051.         if (tagLevel == 0)
  2052.           return epilogProcessor(parser, next, end, nextPtr);
  2053.       }
  2054.       break;
  2055.     case XML_TOK_CHAR_REF:
  2056.       {
  2057.         int n = XmlCharRefNumber(enc, s);
  2058.         if (n < 0)
  2059.           return XML_ERROR_BAD_CHAR_REF;
  2060.         if (characterDataHandler) {
  2061.           XML_Char buf[XML_ENCODE_MAX];
  2062.           characterDataHandler(handlerArg, buf, XmlEncode(n, (ICHAR *)buf));
  2063.         }
  2064.         else if (defaultHandler)
  2065.           reportDefault(parser, enc, s, next);
  2066.       }
  2067.       break;
  2068.     case XML_TOK_XML_DECL:
  2069.       return XML_ERROR_MISPLACED_XML_PI;
  2070.     case XML_TOK_DATA_NEWLINE:
  2071.       if (characterDataHandler) {
  2072.         XML_Char c = 0xA;
  2073.         characterDataHandler(handlerArg, &c, 1);
  2074.       }
  2075.       else if (defaultHandler)
  2076.         reportDefault(parser, enc, s, next);
  2077.       break;
  2078.     case XML_TOK_CDATA_SECT_OPEN:
  2079.       {
  2080.         enum XML_Error result;
  2081.         if (startCdataSectionHandler)
  2082.           startCdataSectionHandler(handlerArg);
  2083. #if 0
  2084.         /* Suppose you doing a transformation on a document that involves
  2085.            changing only the character data.  You set up a defaultHandler
  2086.            and a characterDataHandler.  The defaultHandler simply copies
  2087.            characters through.  The characterDataHandler does the
  2088.            transformation and writes the characters out escaping them as
  2089.            necessary.  This case will fail to work if we leave out the
  2090.            following two lines (because & and < inside CDATA sections will
  2091.            be incorrectly escaped).
  2092.            However, now we have a start/endCdataSectionHandler, so it seems
  2093.            easier to let the user deal with this.
  2094.         */
  2095.         else if (characterDataHandler)
  2096.           characterDataHandler(handlerArg, dataBuf, 0);
  2097. #endif
  2098.         else if (defaultHandler)
  2099.           reportDefault(parser, enc, s, next);
  2100.         result = doCdataSection(parser, enc, &next, end, nextPtr);
  2101.         if (!next) {
  2102.           processor = cdataSectionProcessor;
  2103.           return result;
  2104.         }
  2105.       }
  2106.       break;
  2107.     case XML_TOK_TRAILING_RSQB:
  2108.       if (nextPtr) {
  2109.         *nextPtr = s;
  2110.         return XML_ERROR_NONE;
  2111.       }
  2112.       if (characterDataHandler) {
  2113.         if (MUST_CONVERT(enc, s)) {
  2114.           ICHAR *dataPtr = (ICHAR *)dataBuf;
  2115.           XmlConvert(enc, &s, end, &dataPtr, (ICHAR *)dataBufEnd);
  2116.           characterDataHandler(handlerArg, dataBuf,
  2117.                                dataPtr - (ICHAR *)dataBuf);
  2118.         }
  2119.         else
  2120.           characterDataHandler(handlerArg,
  2121.                                (XML_Char *)s,
  2122.                                (XML_Char *)end - (XML_Char *)s);
  2123.       }
  2124.       else if (defaultHandler)
  2125.         reportDefault(parser, enc, s, end);
  2126.       if (startTagLevel == 0) {
  2127.         *eventPP = end;
  2128.         return XML_ERROR_NO_ELEMENTS;
  2129.       }
  2130.       if (tagLevel != startTagLevel) {
  2131.         *eventPP = end;
  2132.         return XML_ERROR_ASYNC_ENTITY;
  2133.       }
  2134.       return XML_ERROR_NONE;
  2135.     case XML_TOK_DATA_CHARS:
  2136.       if (characterDataHandler) {
  2137.         if (MUST_CONVERT(enc, s)) {
  2138.           for (;;) {
  2139.             ICHAR *dataPtr = (ICHAR *)dataBuf;
  2140.             XmlConvert(enc, &s, next, &dataPtr, (ICHAR *)dataBufEnd);
  2141.             *eventEndPP = s;
  2142.             characterDataHandler(handlerArg, dataBuf,
  2143.                                  dataPtr - (ICHAR *)dataBuf);
  2144.             if (s == next)
  2145.               break;
  2146.             *eventPP = s;
  2147.           }
  2148.         }
  2149.         else
  2150.           characterDataHandler(handlerArg,
  2151.                                (XML_Char *)s,
  2152.                                (XML_Char *)next - (XML_Char *)s);
  2153.       }
  2154.       else if (defaultHandler)
  2155.         reportDefault(parser, enc, s, next);
  2156.       break;
  2157.     case XML_TOK_PI:
  2158.       if (!reportProcessingInstruction(parser, enc, s, next))
  2159.         return XML_ERROR_NO_MEMORY;
  2160.       break;
  2161.     case XML_TOK_COMMENT:
  2162.       if (!reportComment(parser, enc, s, next))
  2163.         return XML_ERROR_NO_MEMORY;
  2164.       break;
  2165.     default:
  2166.       if (defaultHandler)
  2167.         reportDefault(parser, enc, s, next);
  2168.       break;
  2169.     }
  2170.     *eventPP = s = next;
  2171.   }
  2172.   /* not reached */
  2173. }
  2174. /* If tagNamePtr is non-null, build a real list of attributes,
  2175.    otherwise just check the attributes for well-formedness.
  2176. */
  2177. static enum XML_Error
  2178. storeAtts(XML_Parser parser, const ENCODING *enc,
  2179.           const char *attStr, TAG_NAME *tagNamePtr,
  2180.           BINDING **bindingsPtr)
  2181. {
  2182.   DTD * const dtd = _dtd;  /* save one level of indirection */
  2183.   ELEMENT_TYPE *elementType = NULL;
  2184.   int nDefaultAtts = 0;
  2185.   const XML_Char **appAtts;   /* the attribute list for the application */
  2186.   int attIndex = 0;
  2187.   int prefixLen;
  2188.   int i;
  2189.   int n;
  2190.   XML_Char *uri;
  2191.   int nPrefixes = 0;
  2192.   BINDING *binding;
  2193.   const XML_Char *localPart;
  2194.   /* lookup the element type name */
  2195.   if (tagNamePtr) {
  2196.     elementType = (ELEMENT_TYPE *)lookup(&dtd->elementTypes, tagNamePtr->str,0);
  2197.     if (!elementType) {
  2198.       const XML_Char *name = poolCopyString(&dtd->pool, tagNamePtr->str);
  2199.       if (!name)
  2200.         return XML_ERROR_NO_MEMORY;
  2201.       elementType = (ELEMENT_TYPE *)lookup(&dtd->elementTypes, name,
  2202.                                            sizeof(ELEMENT_TYPE));
  2203.       if (!elementType)
  2204.         return XML_ERROR_NO_MEMORY;
  2205.       if (ns && !setElementTypePrefix(parser, elementType))
  2206.         return XML_ERROR_NO_MEMORY;
  2207.     }
  2208.     nDefaultAtts = elementType->nDefaultAtts;
  2209.   }
  2210.   /* get the attributes from the tokenizer */
  2211.   n = XmlGetAttributes(enc, attStr, attsSize, atts);
  2212.   if (n + nDefaultAtts > attsSize) {
  2213.     int oldAttsSize = attsSize;
  2214.     ATTRIBUTE *temp;
  2215.     attsSize = n + nDefaultAtts + INIT_ATTS_SIZE;
  2216.     temp = (ATTRIBUTE *)REALLOC((void *)atts, attsSize * sizeof(ATTRIBUTE));
  2217.     if (temp == NULL)
  2218.       return XML_ERROR_NO_MEMORY;
  2219.     atts = temp;
  2220.     if (n > oldAttsSize)
  2221.       XmlGetAttributes(enc, attStr, n, atts);
  2222.   }
  2223.   appAtts = (const XML_Char **)atts;
  2224.   for (i = 0; i < n; i++) {
  2225.     /* add the name and value to the attribute list */
  2226.     ATTRIBUTE_ID *attId = getAttributeId(parser, enc, atts[i].name,
  2227.                                          atts[i].name
  2228.                                          + XmlNameLength(enc, atts[i].name));
  2229.     if (!attId)
  2230.       return XML_ERROR_NO_MEMORY;
  2231.     /* detect duplicate attributes */
  2232.     if ((attId->name)[-1]) {
  2233.       if (enc == encoding)
  2234.         eventPtr = atts[i].name;
  2235.       return XML_ERROR_DUPLICATE_ATTRIBUTE;
  2236.     }
  2237.     (attId->name)[-1] = 1;
  2238.     appAtts[attIndex++] = attId->name;
  2239.     if (!atts[i].normalized) {
  2240.       enum XML_Error result;
  2241.       XML_Bool isCdata = XML_TRUE;
  2242.       /* figure out whether declared as other than CDATA */
  2243.       if (attId->maybeTokenized) {
  2244.         int j;
  2245.         for (j = 0; j < nDefaultAtts; j++) {
  2246.           if (attId == elementType->defaultAtts[j].id) {
  2247.             isCdata = elementType->defaultAtts[j].isCdata;
  2248.             break;
  2249.           }
  2250.         }
  2251.       }
  2252.       /* normalize the attribute value */
  2253.       result = storeAttributeValue(parser, enc, isCdata,
  2254.                                    atts[i].valuePtr, atts[i].valueEnd,
  2255.                                    &tempPool);
  2256.       if (result)
  2257.         return result;
  2258.       if (tagNamePtr) {
  2259.         appAtts[attIndex] = poolStart(&tempPool);
  2260.         poolFinish(&tempPool);
  2261.       }
  2262.       else
  2263.         poolDiscard(&tempPool);
  2264.     }
  2265.     else if (tagNamePtr) {
  2266.       /* the value did not need normalizing */
  2267.       appAtts[attIndex] = poolStoreString(&tempPool, enc, atts[i].valuePtr,
  2268.                                           atts[i].valueEnd);
  2269.       if (appAtts[attIndex] == 0)
  2270.         return XML_ERROR_NO_MEMORY;
  2271.       poolFinish(&tempPool);
  2272.     }
  2273.     /* handle prefixed attribute names */
  2274.     if (attId->prefix && tagNamePtr) {
  2275.       if (attId->xmlns) {
  2276.         /* deal with namespace declarations here */
  2277.         if (!addBinding(parser, attId->prefix, attId, appAtts[attIndex],
  2278.                         bindingsPtr))
  2279.           return XML_ERROR_NO_MEMORY;
  2280.         --attIndex;
  2281.       }
  2282.       else {
  2283.         /* deal with other prefixed names later */
  2284.         attIndex++;
  2285.         nPrefixes++;
  2286.         (attId->name)[-1] = 2;
  2287.       }
  2288.     }
  2289.     else
  2290.       attIndex++;
  2291.   }
  2292.   if (tagNamePtr) {
  2293.     int j;
  2294.     nSpecifiedAtts = attIndex;
  2295.     if (elementType->idAtt && (elementType->idAtt->name)[-1]) {
  2296.       for (i = 0; i < attIndex; i += 2)
  2297.         if (appAtts[i] == elementType->idAtt->name) {
  2298.           idAttIndex = i;
  2299.           break;
  2300.         }
  2301.     }
  2302.     else
  2303.       idAttIndex = -1;
  2304.     /* do attribute defaulting */
  2305.     for (j = 0; j < nDefaultAtts; j++) {
  2306.       const DEFAULT_ATTRIBUTE *da = elementType->defaultAtts + j;
  2307.       if (!(da->id->name)[-1] && da->value) {
  2308.         if (da->id->prefix) {
  2309.           if (da->id->xmlns) {
  2310.             if (!addBinding(parser, da->id->prefix, da->id, da->value,
  2311.                             bindingsPtr))
  2312.               return XML_ERROR_NO_MEMORY;
  2313.           }
  2314.           else {
  2315.             (da->id->name)[-1] = 2;
  2316.             nPrefixes++;
  2317.             appAtts[attIndex++] = da->id->name;
  2318.             appAtts[attIndex++] = da->value;
  2319.           }
  2320.         }
  2321.         else {
  2322.           (da->id->name)[-1] = 1;
  2323.           appAtts[attIndex++] = da->id->name;
  2324.           appAtts[attIndex++] = da->value;
  2325.         }
  2326.       }
  2327.     }
  2328.     appAtts[attIndex] = 0;
  2329.   }
  2330.   i = 0;
  2331.   if (nPrefixes) {
  2332.     /* expand prefixed attribute names */
  2333.     for (; i < attIndex; i += 2) {
  2334.       if (appAtts[i][-1] == 2) {
  2335.         ATTRIBUTE_ID *id;
  2336.         ((XML_Char *)(appAtts[i]))[-1] = 0;
  2337.         id = (ATTRIBUTE_ID *)lookup(&dtd->attributeIds, appAtts[i], 0);
  2338.         if (id->prefix->binding) {
  2339.           int j;
  2340.           const BINDING *b = id->prefix->binding;
  2341.           const XML_Char *s = appAtts[i];
  2342.           for (j = 0; j < b->uriLen; j++) {
  2343.             if (!poolAppendChar(&tempPool, b->uri[j]))
  2344.               return XML_ERROR_NO_MEMORY;
  2345.           }
  2346.           while (*s++ != XML_T(':'))
  2347.             ;
  2348.           do {
  2349.             if (!poolAppendChar(&tempPool, *s))
  2350.               return XML_ERROR_NO_MEMORY;
  2351.           } while (*s++);
  2352.           if (ns_triplets) {
  2353.             tempPool.ptr[-1] = namespaceSeparator;
  2354.             s = b->prefix->name;
  2355.             do {
  2356.               if (!poolAppendChar(&tempPool, *s))
  2357.                 return XML_ERROR_NO_MEMORY;
  2358.             } while (*s++);
  2359.           }
  2360.           appAtts[i] = poolStart(&tempPool);
  2361.           poolFinish(&tempPool);
  2362.         }
  2363.         if (!--nPrefixes)
  2364.           break;
  2365.       }
  2366.       else
  2367.         ((XML_Char *)(appAtts[i]))[-1] = 0;
  2368.     }
  2369.   }
  2370.   /* clear the flags that say whether attributes were specified */
  2371.   for (; i < attIndex; i += 2)
  2372.     ((XML_Char *)(appAtts[i]))[-1] = 0;
  2373.   if (!tagNamePtr)
  2374.     return XML_ERROR_NONE;
  2375.   for (binding = *bindingsPtr; binding; binding = binding->nextTagBinding)
  2376.     binding->attId->name[-1] = 0;
  2377.   /* expand the element type name */
  2378.   if (elementType->prefix) {
  2379.     binding = elementType->prefix->binding;
  2380.     if (!binding)
  2381.       return XML_ERROR_NONE;
  2382.     localPart = tagNamePtr->str;
  2383.     while (*localPart++ != XML_T(':'))
  2384.       ;
  2385.   }
  2386.   else if (dtd->defaultPrefix.binding) {
  2387.     binding = dtd->defaultPrefix.binding;
  2388.     localPart = tagNamePtr->str;
  2389.   }
  2390.   else
  2391.     return XML_ERROR_NONE;
  2392.   prefixLen = 0;
  2393.   if (ns && ns_triplets && binding->prefix->name) {
  2394.     for (; binding->prefix->name[prefixLen++];)
  2395.       ;
  2396.   }
  2397.   tagNamePtr->localPart = localPart;
  2398.   tagNamePtr->uriLen = binding->uriLen;
  2399.   tagNamePtr->prefix = binding->prefix->name;
  2400.   tagNamePtr->prefixLen = prefixLen;
  2401.   for (i = 0; localPart[i++];)
  2402.     ;
  2403.   n = i + binding->uriLen + prefixLen;
  2404.   if (n > binding->uriAlloc) {
  2405.     TAG *p;
  2406.     uri = (XML_Char *)MALLOC((n + EXPAND_SPARE) * sizeof(XML_Char));
  2407.     if (!uri)
  2408.       return XML_ERROR_NO_MEMORY;
  2409.     binding->uriAlloc = n + EXPAND_SPARE;
  2410.     memcpy(uri, binding->uri, binding->uriLen * sizeof(XML_Char));
  2411.     for (p = tagStack; p; p = p->parent)
  2412.       if (p->name.str == binding->uri)
  2413.         p->name.str = uri;
  2414.     FREE(binding->uri);
  2415.     binding->uri = uri;
  2416.   }
  2417.   uri = binding->uri + binding->uriLen;
  2418.   memcpy(uri, localPart, i * sizeof(XML_Char));
  2419.   if (prefixLen) {
  2420.         uri = uri + (i - 1);
  2421.     if (namespaceSeparator) { *(uri) = namespaceSeparator; }
  2422.     memcpy(uri + 1, binding->prefix->name, prefixLen * sizeof(XML_Char));
  2423.   }
  2424.   tagNamePtr->str = binding->uri;
  2425.   return XML_ERROR_NONE;
  2426. }
  2427. /* addBinding() overwrites the value of prefix->binding without checking.
  2428.    Therefore one must keep track of the old value outside of addBinding().
  2429. */
  2430. static int
  2431. addBinding(XML_Parser parser, PREFIX *prefix, const ATTRIBUTE_ID *attId,
  2432.            const XML_Char *uri, BINDING **bindingsPtr)
  2433. {
  2434.   BINDING *b;
  2435.   int len;
  2436.   for (len = 0; uri[len]; len++)
  2437.     ;
  2438.   if (namespaceSeparator)
  2439.     len++;
  2440.   if (freeBindingList) {
  2441.     b = freeBindingList;
  2442.     if (len > b->uriAlloc) {
  2443.       XML_Char *temp = (XML_Char *)REALLOC(b->uri,
  2444.                           sizeof(XML_Char) * (len + EXPAND_SPARE));
  2445.       if (temp == NULL)
  2446.         return 0;
  2447.       b->uri = temp;
  2448.       b->uriAlloc = len + EXPAND_SPARE;
  2449.     }
  2450.     freeBindingList = b->nextTagBinding;
  2451.   }
  2452.   else {
  2453.     b = (BINDING *)MALLOC(sizeof(BINDING));
  2454.     if (!b)
  2455.       return 0;
  2456.     b->uri = (XML_Char *)MALLOC(sizeof(XML_Char) * (len + EXPAND_SPARE));
  2457.     if (!b->uri) {
  2458.       FREE(b);
  2459.       return 0;
  2460.     }
  2461.     b->uriAlloc = len + EXPAND_SPARE;
  2462.   }
  2463.   b->uriLen = len;
  2464.   memcpy(b->uri, uri, len * sizeof(XML_Char));
  2465.   if (namespaceSeparator)
  2466.     b->uri[len - 1] = namespaceSeparator;
  2467.   b->prefix = prefix;
  2468.   b->attId = attId;
  2469.   b->prevPrefixBinding = prefix->binding;
  2470.   if (*uri == XML_T('') && prefix == &_dtd->defaultPrefix)
  2471.     prefix->binding = NULL;
  2472.   else
  2473.     prefix->binding = b;
  2474.   b->nextTagBinding = *bindingsPtr;
  2475.   *bindingsPtr = b;
  2476.   if (startNamespaceDeclHandler)
  2477.     startNamespaceDeclHandler(handlerArg, prefix->name,
  2478.                               prefix->binding ? uri : 0);
  2479.   return 1;
  2480. }
  2481. /* The idea here is to avoid using stack for each CDATA section when
  2482.    the whole file is parsed with one call.
  2483. */
  2484. static enum XML_Error PTRCALL
  2485. cdataSectionProcessor(XML_Parser parser,
  2486.                       const char *start,
  2487.                       const char *end,
  2488.                       const char **endPtr)
  2489. {
  2490.   enum XML_Error result = doCdataSection(parser, encoding, &start,
  2491.                                          end, endPtr);
  2492.   if (start) {
  2493.     if (parentParser) {  /* we are parsing an external entity */
  2494.       processor = externalEntityContentProcessor;
  2495.       return externalEntityContentProcessor(parser, start, end, endPtr);
  2496.     }
  2497.     else {
  2498.       processor = contentProcessor;
  2499.       return contentProcessor(parser, start, end, endPtr);
  2500.     }
  2501.   }
  2502.   return result;
  2503. }
  2504. /* startPtr gets set to non-null is the section is closed, and to null if
  2505.    the section is not yet closed.
  2506. */
  2507. static enum XML_Error
  2508. doCdataSection(XML_Parser parser,
  2509.                const ENCODING *enc,
  2510.                const char **startPtr,
  2511.                const char *end,
  2512.                const char **nextPtr)
  2513. {
  2514.   const char *s = *startPtr;
  2515.   const char **eventPP;
  2516.   const char **eventEndPP;
  2517.   if (enc == encoding) {
  2518.     eventPP = &eventPtr;
  2519.     *eventPP = s;
  2520.     eventEndPP = &eventEndPtr;
  2521.   }
  2522.   else {
  2523.     eventPP = &(openInternalEntities->internalEventPtr);
  2524.     eventEndPP = &(openInternalEntities->internalEventEndPtr);
  2525.   }
  2526.   *eventPP = s;
  2527.   *startPtr = NULL;
  2528.   for (;;) {
  2529.     const char *next;
  2530.     int tok = XmlCdataSectionTok(enc, s, end, &next);
  2531.     *eventEndPP = next;
  2532.     switch (tok) {
  2533.     case XML_TOK_CDATA_SECT_CLOSE:
  2534.       if (endCdataSectionHandler)
  2535.         endCdataSectionHandler(handlerArg);
  2536. #if 0
  2537.       /* see comment under XML_TOK_CDATA_SECT_OPEN */
  2538.       else if (characterDataHandler)
  2539.         characterDataHandler(handlerArg, dataBuf, 0);
  2540. #endif
  2541.       else if (defaultHandler)
  2542.         reportDefault(parser, enc, s, next);
  2543.       *startPtr = next;
  2544.       return XML_ERROR_NONE;
  2545.     case XML_TOK_DATA_NEWLINE:
  2546.       if (characterDataHandler) {
  2547.         XML_Char c = 0xA;
  2548.         characterDataHandler(handlerArg, &c, 1);
  2549.       }
  2550.       else if (defaultHandler)
  2551.         reportDefault(parser, enc, s, next);
  2552.       break;
  2553.     case XML_TOK_DATA_CHARS:
  2554.       if (characterDataHandler) {
  2555.         if (MUST_CONVERT(enc, s)) {
  2556.           for (;;) {
  2557.             ICHAR *dataPtr = (ICHAR *)dataBuf;
  2558.             XmlConvert(enc, &s, next, &dataPtr, (ICHAR *)dataBufEnd);
  2559.             *eventEndPP = next;
  2560.             characterDataHandler(handlerArg, dataBuf,
  2561.                                  dataPtr - (ICHAR *)dataBuf);
  2562.             if (s == next)
  2563.               break;
  2564.             *eventPP = s;
  2565.           }
  2566.         }
  2567.         else
  2568.           characterDataHandler(handlerArg,
  2569.                                (XML_Char *)s,
  2570.                                (XML_Char *)next - (XML_Char *)s);
  2571.       }
  2572.       else if (defaultHandler)
  2573.         reportDefault(parser, enc, s, next);
  2574.       break;
  2575.     case XML_TOK_INVALID:
  2576.       *eventPP = next;
  2577.       return XML_ERROR_INVALID_TOKEN;
  2578.     case XML_TOK_PARTIAL_CHAR:
  2579.       if (nextPtr) {
  2580.         *nextPtr = s;
  2581.         return XML_ERROR_NONE;
  2582.       }
  2583.       return XML_ERROR_PARTIAL_CHAR;
  2584.     case XML_TOK_PARTIAL:
  2585.     case XML_TOK_NONE:
  2586.       if (nextPtr) {
  2587.         *nextPtr = s;
  2588.         return XML_ERROR_NONE;
  2589.       }
  2590.       return XML_ERROR_UNCLOSED_CDATA_SECTION;
  2591.     default:
  2592.       *eventPP = next;
  2593.       return XML_ERROR_UNEXPECTED_STATE;
  2594.     }
  2595.     *eventPP = s = next;
  2596.   }
  2597.   /* not reached */
  2598. }
  2599. #ifdef XML_DTD
  2600. /* The idea here is to avoid using stack for each IGNORE section when
  2601.    the whole file is parsed with one call.
  2602. */
  2603. static enum XML_Error PTRCALL
  2604. ignoreSectionProcessor(XML_Parser parser,
  2605.                        const char *start,
  2606.                        const char *end,
  2607.                        const char **endPtr)
  2608. {
  2609.   enum XML_Error result = doIgnoreSection(parser, encoding, &start,
  2610.                                           end, endPtr);
  2611.   if (start) {
  2612.     processor = prologProcessor;
  2613.     return prologProcessor(parser, start, end, endPtr);
  2614.   }
  2615.   return result;
  2616. }
  2617. /* startPtr gets set to non-null is the section is closed, and to null
  2618.    if the section is not yet closed.
  2619. */
  2620. static enum XML_Error
  2621. doIgnoreSection(XML_Parser parser,
  2622.                 const ENCODING *enc,
  2623.                 const char **startPtr,
  2624.                 const char *end,
  2625.                 const char **nextPtr)
  2626. {
  2627.   const char *next;
  2628.   int tok;
  2629.   const char *s = *startPtr;
  2630.   const char **eventPP;
  2631.   const char **eventEndPP;
  2632.   if (enc == encoding) {
  2633.     eventPP = &eventPtr;
  2634.     *eventPP = s;
  2635.     eventEndPP = &eventEndPtr;
  2636.   }
  2637.   else {
  2638.     eventPP = &(openInternalEntities->internalEventPtr);
  2639.     eventEndPP = &(openInternalEntities->internalEventEndPtr);
  2640.   }
  2641.   *eventPP = s;
  2642.   *startPtr = NULL;
  2643.   tok = XmlIgnoreSectionTok(enc, s, end, &next);
  2644.   *eventEndPP = next;
  2645.   switch (tok) {
  2646.   case XML_TOK_IGNORE_SECT:
  2647.     if (defaultHandler)
  2648.       reportDefault(parser, enc, s, next);
  2649.     *startPtr = next;
  2650.     return XML_ERROR_NONE;
  2651.   case XML_TOK_INVALID:
  2652.     *eventPP = next;
  2653.     return XML_ERROR_INVALID_TOKEN;
  2654.   case XML_TOK_PARTIAL_CHAR:
  2655.     if (nextPtr) {
  2656.       *nextPtr = s;
  2657.       return XML_ERROR_NONE;
  2658.     }
  2659.     return XML_ERROR_PARTIAL_CHAR;
  2660.   case XML_TOK_PARTIAL:
  2661.   case XML_TOK_NONE:
  2662.     if (nextPtr) {
  2663.       *nextPtr = s;
  2664.       return XML_ERROR_NONE;
  2665.     }
  2666.     return XML_ERROR_SYNTAX; /* XML_ERROR_UNCLOSED_IGNORE_SECTION */
  2667.   default:
  2668.     *eventPP = next;
  2669.     return XML_ERROR_UNEXPECTED_STATE;
  2670.   }
  2671.   /* not reached */
  2672. }
  2673. #endif /* XML_DTD */
  2674. static enum XML_Error
  2675. initializeEncoding(XML_Parser parser)
  2676. {
  2677.   const char *s;
  2678. #ifdef XML_UNICODE
  2679.   char encodingBuf[128];
  2680.   if (!protocolEncodingName)
  2681.     s = NULL;
  2682.   else {
  2683.     int i;
  2684.     for (i = 0; protocolEncodingName[i]; i++) {
  2685.       if (i == sizeof(encodingBuf) - 1
  2686.           || (protocolEncodingName[i] & ~0x7f) != 0) {
  2687.         encodingBuf[0] = '';
  2688.         break;
  2689.       }
  2690.       encodingBuf[i] = (char)protocolEncodingName[i];
  2691.     }
  2692.     encodingBuf[i] = '';
  2693.     s = encodingBuf;
  2694.   }
  2695. #else
  2696.   s = protocolEncodingName;
  2697. #endif
  2698.   if ((ns ? XmlInitEncodingNS : XmlInitEncoding)(&initEncoding, &encoding, s))
  2699.     return XML_ERROR_NONE;
  2700.   return handleUnknownEncoding(parser, protocolEncodingName);
  2701. }
  2702. static enum XML_Error
  2703. processXmlDecl(XML_Parser parser, int isGeneralTextEntity,
  2704.                const char *s, const char *next)
  2705. {
  2706.   const char *encodingName = NULL;
  2707.   const XML_Char *storedEncName = NULL;
  2708.   const ENCODING *newEncoding = NULL;
  2709.   const char *version = NULL;
  2710.   const char *versionend;
  2711.   const XML_Char *storedversion = NULL;
  2712.   int standalone = -1;
  2713.   if (!(ns
  2714.         ? XmlParseXmlDeclNS
  2715.         : XmlParseXmlDecl)(isGeneralTextEntity,
  2716.                            encoding,
  2717.                            s,
  2718.                            next,
  2719.                            &eventPtr,
  2720.                            &version,
  2721.                            &versionend,