Newer
Older
monitord / xmlParser / .svn / text-base / Readme.txt.svn-base
@root root on 23 Jan 2012 11 KB Migration from SVN revision 455
  1. XMLParser v2.23
  2. ===============
  3.  
  4. The library is composed by two files: "xmlParser.cpp" and "xmlParser.h".
  5. These are the only 2 files that you need when using the library inside your own projects.
  6. All the functions of the library are documented inside the comments of the file "xmlParser.h".
  7.  
  8. To use the unicode version of the library, you need to define the "_UNICODE" preprocessor
  9. definition variable (inside your project definition file).
  10.  
  11. Some small test examples are also given: see the files "xmlTest.cpp" and "xmlTestUnicode.cpp".
  12. The examples are described inside the html file "xmlParser.html".
  13.  
  14. To build the examples:
  15. - linux/unix: type "make"
  16. - solaris: type "make -f makefile.solaris"
  17. - windows: Visual Studio: double-click on xmlParser.dsw
  18. (under Visual Studio .NET, the .dsp and .dsw files will be automatically converted to .vcproj and .sln files)
  19.  
  20. In order to build the examples you need some project files:
  21. - linux/unix: makefile
  22. - solaris: makefile.solaris
  23. - windows: Visual Studio: *.dsp, xmlParser.dsw
  24.  
  25. WINDOWS:
  26. Inside Visual C++, the "debug versions" of the memory allocation functions are
  27. very slow: Do not forget to compile in "release mode" to get maximum speed.
  28. When I have to debug a software that is using the XMLParser Library, it's usually
  29. a nightmare because the library is sooOOOoooo slow in debug mode. To solve this
  30. problem, during all the debugging session, I use a very fast DLL version of the
  31. XMLParser Library (the DLL is compiled in release mode). Using the DLL version of
  32. the XMLParser Library allows me to have lightening XML parsing speed even in debug!
  33. Other than that, the DLL version is useless: In the release version of my tool,
  34. I always use the normal, ".cpp"-based, XMLParser Library.
  35. LINUX:
  36. The speed of the debug version of the XMLParser library is tolerable.
  37.  
  38. Change Log
  39. ----------
  40.  
  41. * V1.00: February 20, 2002: initial version.
  42. * V1.01: February 13, 2005: first bug-free release.
  43. * V1.02: March 6, 2005: 2 minor changes:
  44. o "parseString" function declaration changed to allow easy parsing from memory buffer
  45. o Minor changes to allow easy compilation under old GCC under QNX
  46. * V1.03: April 2,2005: 3 minors changes:
  47. o When parsing from a user-supplied memory buffer, the library was previously modifying the content of the memory buffer. This is not the case anymore
  48. o Non-unicode Windows version: You can now work with unicode XML files: They are converted to ANSI charset before being processed
  49. o Added Visual Studio 6.0 project files
  50. * V1.04: May 16, 2005: 3 minors changes, 1 bug fix:
  51. o FIX: When creating an xml string with no formatting, the formatting did not work always (due to an un-initialized variable)
  52. o Improved parsing speed (try increasing the constant "memoryIncrease" if you need more speed)
  53. o Minor changes to allow easy compilation under MSYS/MINGW under Windows
  54. o Added more character entities
  55. * V1.05: May 31, 2005: 2 minors changes:
  56. o Changed some "char *" to "const char *"
  57. o Improved robustness against badly formed xml strings
  58. * V1.06: July 11, 2005: 1 change, 1 bug fix:
  59. o FIX: Some character entities were not previously correctly processed.
  60. o Major speed improvement. The library is now at least 10 times faster. (Try increasing the constant "memoryIncrease" if you need more speed)
  61. o moved the log file out of the HTML file
  62. * V1.07: July 25, 2005: 1 change
  63. o Added a pre-compiler directive named "APPROXIMATE_PARSING". See header of xmlParser.cpp for more info.
  64. * V1.08: September 8,2005: 1 bug fix:
  65. o FIX: on special cases, non-matching quotes were causing malfunction
  66. * V1.09: November 22, 2005: 1 addition
  67. o Added some new functions to be able to easily create a XML structure in memory
  68. * V1.10: December 29, 2005: 2 minor change.
  69. o Changed some formatting when rendering a XML tree to a string
  70. o added the STRICT_PARSING option
  71. * V1.11: December 31, 2005: 1 bug fix:
  72. o FIX: reduced memory consumption.
  73. * V1.12: January 4, 2006: 1 addition.
  74. o added the function "removeNodeContent" to delete a subtree
  75. * V1.13: February 25, 2006: 1 addition.
  76. o added a primitive UNICODE support under linux (thanks to Sunny Bains)
  77. * V1.14: April 24, 2006: 1 bug fix:
  78. o FIX: memory allocation errors when the XML tree is created from scratch using "addChild" method.
  79. * V1.15: April 28, 2006: 2 additions
  80. o added some methods to delete attributes,clearTags and textFields from an XMLNode tree.
  81. o added the "addChild(XMLNode x)" method
  82. * V1.16: May 17, 2006: 1 bug fix:
  83. o FIX: memory allocation errors under linux
  84. * V1.17: May 28, 2006: 1 bug fix, 2 additions:
  85. o FIX: character entities not always processed inside text block
  86. o position of the eXMLErrorMissingEndTag error is computed
  87. o added the eXMLErrorUnknownEscapeSequence
  88. * V1.18: June 8, 2006: 1 bug fix, minors changes
  89. o FIX: the 'eXMLErrorFirstTagNotFound' error was not reported.
  90. o changed license to BSD - added some examples of usage.
  91. * V1.19: July 4, 2006: 3 addition.
  92. o added automatic convertion from/to UNICODE/ANSI in linux (this was already done in windows)
  93. o added getChildNodeWithAttribute()
  94. o added support for SOLARIS unicode (Thanks to Joseph Vijay!).
  95. o added support for 32 bit unicode (so that the library works on Redhat Enterprise v4 EMT64).
  96. * V1.20: July 22, 2006: 13 additions.
  97. o added 9 "update" functions (like updateAttribute(LPCTSTR lpszNewValue, LPCTSTR lpszNewName=NULL,LPCTSTR lpszOldName);)
  98. o added 4 functions that allows you to include any binary data (images, sounds,...) into an XML file or string using "Base64 encoding".
  99. * V2.01: July 24, 2006: 1 major change, 2 minor change, 3 additions
  100. o added extended support for strict UTF-8 character encoding (The characters in UTF-8 have different lengths (from 1 byte to 4 bytes)).
  101. Chinese, cyrilic and other extended characters are now processed successfully.
  102. o new character entities: This is now equivalent: 'A' or 'A' or 'A'
  103. (The ascci code of 'A' is 65 in decimal and 0x41 in hexadecimal).
  104. o added a function that try to guess if the encoding is UTF-8.
  105. o the code has been modified in order to allow easy inclusion of new entities and new clearTags (minor change).
  106. o the "updateAttribute" function is now adding a new attribute if the one to update is missing.
  107. (same behavior for "updateText" and "updateClear").
  108. o no more "stringDup" required for functions like "addText", "addAttribute",...
  109. The old behavior is still accessible through functions like "addText_WOSD", "addAttribute_WOSD",...
  110. ("_WSOD" stands for "WithOut StringDup").
  111. This change greatly simplifies the user's code (major update).
  112. Unfortunately, old user's code must be updated to work with the new version.
  113. Fortunately, all the user's code used to READ the content of an XML file is left unchanged:
  114. Only the "creation of XML" and the "update of XML" user's code require a little updating work.
  115. * V2.02: July 25, 2006: 1 minor change
  116. o changed the function "createXMLTopNode()" to "createXMLTopNode(LPCTSTR lpszName, int isDeclaration=FALSE);".
  117. * V2.03: July 28, 2006: 1 minor change
  118. o changed LPTSTR to XMLSTR to avoid name-clash with the definitions in <winnt.h>
  119. * V2.04: August 6, 2006: 1 addition
  120. o added one heuristic inside the function "guessUTF8ParsingParameterValue".
  121. * V2.05: August 15, 2006: 1 addition
  122. o now displays the error message inside the method "openFileHelper" in a MessageBox window (WIN32 only).
  123. * V2.06: August 16, 2006: 2 additions
  124. o added the method XMLNode::writeToFile to make it easier to write the content of an XMLNode to a file.
  125. o added support for Byte-order marks (or BOM).
  126. * V2.07: August 22, 2006: 1 additions
  127. o added _XMLUNICODE preprocessor variable to make it easy to force the library into either utf16-mode or utf8-mode.
  128. * V2.08: August 22, 2006: 1 bug fix
  129. o inside the tag content, the ">" and "/>" strings are not reported as errors anymore.
  130. * V2.09: August 31, 2006: 1 bug fix
  131. o the character entities of type &#x04B; were not working properly (thanks to José Carlos Medeiros for notifying me!).
  132. * V2.10: September 21, 2006: 1 bug fix
  133. o two consecutive calls to the deleteNodeContent() function on the same node has now no effect (as it should be).
  134. (Thanks to Hartmut Lemmel for notifying me!)
  135. o improved compatibility to Borland C++
  136. * V2.11: October 24, 2006: 3 additions, 1 bug fix.
  137. o added the function getParentNode(). Thanks to Jakub Siudzinski for notifying me a good way to do it easily.
  138. o added one parameter to the deleteNodeContent() function to force the deletion of the underlying XMLNode tree.
  139. This will release all the memory occupied by the XMLNode tree even if there still exist references to some part
  140. of the tree.
  141. o changed the usage of the base64Encode() function to reduce the number of malloc's (speed increase).
  142. o FIX: when parsing an XML string, if the TOP tag has no closing tag, the library now correctly
  143. reports "eXMLErrorMissingEndTag".
  144. * V2.12: October 25, 2006: 2 additions
  145. o refactoring of the Base64 functions to make things easier to use
  146. o added the _XMLPARSER_NO_MESSAGEBOX_ preprocessor variable (see header of xmlParser.cpp for explanation)
  147. * V2.13: October 31, 2006: 1 minor change, 1 bug fix
  148. o changed the signature of _strnicmp to allow easy compilation under linux .
  149. o FIX: size of buffer for the convertion from ascii/utf8 to utf-16 was incorrect.
  150. * V2.14: November 13, 2006: 1 minor change, 1 bug fix
  151. o changed the parseFile,openFileHelper,writeToFile functions so that the filename parameter is widechar when UNICODE=1
  152. o fixed a bug in openFileHelper when sizeof(wchar_t)=4
  153. * V2.15: December 22, 2006: 2 additions
  154. o added the parameter 'pos' to the addChild,addText,addClear methods to allow insertion of new components anywhere in an already existing XMLNode structure
  155. o added 'postionOf*' methods.
  156. * V2.16: December 27, 2006: 1 minor change
  157. o removed the un-necessary method "firstPosition()" & some code re-structuration.
  158. * V2.17: January 9, 2007: 1 addition, 1 minor change
  159. o added the preprocessor variable "XML_NO_WIDE_CHAR" to allow easy compilation on exotic compilers
  160. o added the "const" method qualifier to some methods.
  161. * V2.18: January 15, 2007: 1 bug fix
  162. o FIX: addChild(XMLNode x,int pos) was sometime inserting at the wrong position when pos!=-1
  163. * V2.19: January 30, 2007: 1 bug fix, 3 additions.
  164. o FIX: Unknown Character Entities are now always reported correctly. Thanks to Vincent Vanhoucke.
  165. o The XML specification indicates that no white spaces should be lost when parsing the file. This is now possible setting the
  166. new global parameter "dropWhiteSpaces" to false.
  167. o The library now works under Windows CE 4.2, Windows Mobile (PPC) 2003(5) (xscale) and Mac OS X Tiger. Thanks to Zdenek Nemec.
  168. o The "<!DOCTYPE" tag is now always handled properly. Thanks to Zdenek Nemec.
  169. * V2.20: February 17, 2007: 1 addition
  170. o added a Visual Studio projet file to build a DLL version of the library.
  171. Under Windows, when I have to debug a software that is using the XMLParser Library,
  172. it's usually a nightmare because the library is sooOOOoooo slow in debug mode. To
  173. solve this problem, during all the debugging session, I use a very fast DLL version
  174. of the XMLParser Library (the DLL is compiled in release mode). Using the DLL version
  175. of the XMLParser Library allows me to have lightening XML parsing speed, even in
  176. debug mode! Other than that, the DLL version is useless: In the release version
  177. of my tool, I always use the normal, ".cpp"-based, XMLParser Library.
  178. * V2.21: Mars 1, 2007: 1 minor change, 1 bug fix
  179. o changed to a better algorithm to handle the "<!DOCTYPE" tag.
  180. o FIX: under SPARC processor, the heuristic that is used to check if the xml file is wchar_t* was generating a BUS error.
  181. * V2.22: Mars 6, 2007: 1 bug fix
  182. o FIX: the 'tag' parameter was not always working properly in parseString
  183. * V2.23: Mars 13, 2007: 1 bug fix
  184. o FIX: the library is now thread-safe.