Sophie

Sophie

distrib > Mandriva > 2010.1 > i586 > by-pkgid > 59e136c5713357bec32fa00e9f43af8f > files > 792

xerces-c-doc-3.1.0-2mdv2010.1.i586.rpm

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html><head><meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
<title>Xerces-C++: XMLPlatformUtils Class Reference</title>
<link href="doxygen.css" rel="stylesheet" type="text/css">
<link href="tabs.css" rel="stylesheet" type="text/css">
</head><body>
<!-- Generated by Doxygen 1.5.6 -->
<div class="navigation" id="top">
  <div class="tabs">
    <ul>
      <li><a href="index.html"><span>Main&nbsp;Page</span></a></li>
      <li><a href="pages.html"><span>Related&nbsp;Pages</span></a></li>
      <li class="current"><a href="classes.html"><span>Classes</span></a></li>
      <li><a href="files.html"><span>Files</span></a></li>
    </ul>
  </div>
  <div class="tabs">
    <ul>
      <li><a href="classes.html"><span>Alphabetical&nbsp;List</span></a></li>
      <li><a href="annotated.html"><span>Class&nbsp;List</span></a></li>
      <li><a href="hierarchy.html"><span>Class&nbsp;Hierarchy</span></a></li>
      <li><a href="functions.html"><span>Class&nbsp;Members</span></a></li>
    </ul>
  </div>
</div>
<div class="contents">
<h1>XMLPlatformUtils Class Reference</h1><!-- doxytag: class="XMLPlatformUtils" -->Utilities that must be implemented in a platform-specific way.  
<a href="#_details">More...</a>
<p>

<p>
<a href="classXMLPlatformUtils-members.html">List of all members.</a><table border="0" cellpadding="0" cellspacing="0">
<tr><td></td></tr>
<tr><td colspan="2"><br><h2>Static Public Member Functions</h2></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#c0f7e36996cd03eb43bcee10321f77cd">XMLSize_t</a>&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#560fd9eecc8651995a4d6af70d71f23a">alignPointerForNewBlockAllocation</a> (<a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#c0f7e36996cd03eb43bcee10321f77cd">XMLSize_t</a> ptrSize)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Aligns the specified pointer per platform block allocation requirements.  <a href="#560fd9eecc8651995a4d6af70d71f23a"></a><br></td></tr>
<tr><td colspan="2"><div class="groupHeader">Initialization and Panic methods</div></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#aa98f8d1346b8b531ee8886d9ce36173">Initialize</a> (const char *const locale=<a class="el" href="classXMLUni.html#65fb61efef197f1387836a339477ab5e">XMLUni::fgXercescDefaultLocale</a>, const char *const nlsHome=0, <a class="el" href="classPanicHandler.html">PanicHandler</a> *const panicHandler=0, <a class="el" href="classMemoryManager.html">MemoryManager</a> *const memoryManager=0)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Perform per-process parser initialization.  <a href="#aa98f8d1346b8b531ee8886d9ce36173"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#369d3584567fc54c582b2074aed43f18">Initialize</a> (<a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#c0f7e36996cd03eb43bcee10321f77cd">XMLSize_t</a> initialDOMHeapAllocSize, <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#c0f7e36996cd03eb43bcee10321f77cd">XMLSize_t</a> maxDOMHeapAllocSize, <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#c0f7e36996cd03eb43bcee10321f77cd">XMLSize_t</a> maxDOMSubAllocationSize, const char *const locale=<a class="el" href="classXMLUni.html#65fb61efef197f1387836a339477ab5e">XMLUni::fgXercescDefaultLocale</a>, const char *const nlsHome=0, <a class="el" href="classPanicHandler.html">PanicHandler</a> *const panicHandler=0, <a class="el" href="classMemoryManager.html">MemoryManager</a> *const memoryManager=0)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Perform per-process parser initialization.  <a href="#369d3584567fc54c582b2074aed43f18"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#dc0dcc57907126e06a2f5e376b392794">Terminate</a> ()</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Perform per-process parser termination.  <a href="#dc0dcc57907126e06a2f5e376b392794"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#b07bdc9abed13b76519c88b166cd6442">panic</a> (const <a class="el" href="classPanicHandler.html#ace4c4f408d68f168e1c2537e0ba5be2">PanicHandler::PanicReasons</a> reason)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">The panic mechanism.  <a href="#b07bdc9abed13b76519c88b166cd6442"></a><br></td></tr>
<tr><td colspan="2"><div class="groupHeader">File Methods</div></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static <a class="el" href="classXMLFileMgr.html">XMLFileMgr</a> *&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#001e511067dc6ac8941e34732b8fa7cb">makeFileMgr</a> (<a class="el" href="classMemoryManager.html">MemoryManager</a> *const manager)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Make a new file object appropriate for the platform.  <a href="#001e511067dc6ac8941e34732b8fa7cb"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#7647261a546ac47bda863a51d24ad898">XMLFilePos</a>&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#2acb4b2eec3a5ddb579c6d410c7873e9">curFilePos</a> (<a class="el" href="XMLFileMgr_8hpp.html#6738b6a1cc86fbf4c231eac94e357446">FileHandle</a> theFile, <a class="el" href="classMemoryManager.html">MemoryManager</a> *const manager=<a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a>)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Get the current file position.  <a href="#2acb4b2eec3a5ddb579c6d410c7873e9"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#a0398de86ccca867efb18f73ec8a82f4">closeFile</a> (<a class="el" href="XMLFileMgr_8hpp.html#6738b6a1cc86fbf4c231eac94e357446">FileHandle</a> theFile, <a class="el" href="classMemoryManager.html">MemoryManager</a> *const manager=<a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a>)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Closes the file handle.  <a href="#a0398de86ccca867efb18f73ec8a82f4"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#7647261a546ac47bda863a51d24ad898">XMLFilePos</a>&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#788a3664405357f0004a1d55c4dc02df">fileSize</a> (<a class="el" href="XMLFileMgr_8hpp.html#6738b6a1cc86fbf4c231eac94e357446">FileHandle</a> theFile, <a class="el" href="classMemoryManager.html">MemoryManager</a> *const manager=<a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a>)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Returns the file size.  <a href="#788a3664405357f0004a1d55c4dc02df"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static <a class="el" href="XMLFileMgr_8hpp.html#6738b6a1cc86fbf4c231eac94e357446">FileHandle</a>&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#98eadae95169c66853c8264438505907">openFile</a> (const char *const fileName, <a class="el" href="classMemoryManager.html">MemoryManager</a> *const manager=<a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a>)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Opens the file.  <a href="#98eadae95169c66853c8264438505907"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static <a class="el" href="XMLFileMgr_8hpp.html#6738b6a1cc86fbf4c231eac94e357446">FileHandle</a>&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#5632167e9027b6def671ed4571ccf0bf">openFile</a> (const <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#fae8f92d83170d97f757f704eca7f52a">XMLCh</a> *const fileName, <a class="el" href="classMemoryManager.html">MemoryManager</a> *const manager=<a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a>)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Opens a named file.  <a href="#5632167e9027b6def671ed4571ccf0bf"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static <a class="el" href="XMLFileMgr_8hpp.html#6738b6a1cc86fbf4c231eac94e357446">FileHandle</a>&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#5939d893ef7399d9d770be562bea6cfb">openFileToWrite</a> (const char *const fileName, <a class="el" href="classMemoryManager.html">MemoryManager</a> *const manager=<a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a>)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Open a named file to write.  <a href="#5939d893ef7399d9d770be562bea6cfb"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static <a class="el" href="XMLFileMgr_8hpp.html#6738b6a1cc86fbf4c231eac94e357446">FileHandle</a>&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#6e96c30edcbe8b1fa570fe2de0d5c31b">openFileToWrite</a> (const <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#fae8f92d83170d97f757f704eca7f52a">XMLCh</a> *const fileName, <a class="el" href="classMemoryManager.html">MemoryManager</a> *const manager=<a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a>)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Open a named file to write.  <a href="#6e96c30edcbe8b1fa570fe2de0d5c31b"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static <a class="el" href="XMLFileMgr_8hpp.html#6738b6a1cc86fbf4c231eac94e357446">FileHandle</a>&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#627be718689157e44f73da8fd23ee004">openStdInHandle</a> (<a class="el" href="classMemoryManager.html">MemoryManager</a> *const manager=<a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a>)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Opens the standard input as a file.  <a href="#627be718689157e44f73da8fd23ee004"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#c0f7e36996cd03eb43bcee10321f77cd">XMLSize_t</a>&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#1f24a6b4b6c097ab66617f48349527dd">readFileBuffer</a> (<a class="el" href="XMLFileMgr_8hpp.html#6738b6a1cc86fbf4c231eac94e357446">FileHandle</a> theFile, const <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#c0f7e36996cd03eb43bcee10321f77cd">XMLSize_t</a> toRead, <a class="el" href="XercesDefs_8hpp.html#7470c7a32c59355685ebcd878a33f126">XMLByte</a> *const toFill, <a class="el" href="classMemoryManager.html">MemoryManager</a> *const manager=<a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a>)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Reads the file buffer.  <a href="#1f24a6b4b6c097ab66617f48349527dd"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#6c77c874c1c3c04773c5d7c16056f874">writeBufferToFile</a> (<a class="el" href="XMLFileMgr_8hpp.html#6738b6a1cc86fbf4c231eac94e357446">FileHandle</a> const theFile, <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#c0f7e36996cd03eb43bcee10321f77cd">XMLSize_t</a> toWrite, const <a class="el" href="XercesDefs_8hpp.html#7470c7a32c59355685ebcd878a33f126">XMLByte</a> *const toFlush, <a class="el" href="classMemoryManager.html">MemoryManager</a> *const manager=<a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a>)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Writes the buffer to the file.  <a href="#6c77c874c1c3c04773c5d7c16056f874"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#3e64b2526936ae010a69cb42ba44c5c8">resetFile</a> (<a class="el" href="XMLFileMgr_8hpp.html#6738b6a1cc86fbf4c231eac94e357446">FileHandle</a> theFile, <a class="el" href="classMemoryManager.html">MemoryManager</a> *const manager=<a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a>)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Resets the file handle.  <a href="#3e64b2526936ae010a69cb42ba44c5c8"></a><br></td></tr>
<tr><td colspan="2"><div class="groupHeader">File System Methods</div></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#fae8f92d83170d97f757f704eca7f52a">XMLCh</a> *&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#41d767f41350edd2bd8853714b9124d8">getFullPath</a> (const <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#fae8f92d83170d97f757f704eca7f52a">XMLCh</a> *const srcPath, <a class="el" href="classMemoryManager.html">MemoryManager</a> *const manager=<a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a>)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Gets the full path from a relative path.  <a href="#41d767f41350edd2bd8853714b9124d8"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#fae8f92d83170d97f757f704eca7f52a">XMLCh</a> *&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#8385708fc8ef23f163a09f19d378231c">getCurrentDirectory</a> (<a class="el" href="classMemoryManager.html">MemoryManager</a> *const manager=<a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a>)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Gets the current working directory.  <a href="#8385708fc8ef23f163a09f19d378231c"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static bool&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#381a005feb529e59f65a4cbd5fe39c11">isAnySlash</a> (<a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#fae8f92d83170d97f757f704eca7f52a">XMLCh</a> c)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Check if a charater is a slash.  <a href="#381a005feb529e59f65a4cbd5fe39c11"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#ff1af43494b60e1783124747f291b6a0">removeDotSlash</a> (<a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#fae8f92d83170d97f757f704eca7f52a">XMLCh</a> *const srcPath, <a class="el" href="classMemoryManager.html">MemoryManager</a> *const manager=<a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a>)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Remove occurences of the pair of dot slash.  <a href="#ff1af43494b60e1783124747f291b6a0"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#1b90b8d2129bdcdfa4bf615db8dd85a7">removeDotDotSlash</a> (<a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#fae8f92d83170d97f757f704eca7f52a">XMLCh</a> *const srcPath, <a class="el" href="classMemoryManager.html">MemoryManager</a> *const manager=<a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a>)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Remove occurences of the dot dot slash.  <a href="#1b90b8d2129bdcdfa4bf615db8dd85a7"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static bool&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#8c865f3209cf6e05712c0d1ba7d3e589">isRelative</a> (const <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#fae8f92d83170d97f757f704eca7f52a">XMLCh</a> *const toCheck, <a class="el" href="classMemoryManager.html">MemoryManager</a> *const manager=<a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a>)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Determines if a path is relative or absolute.  <a href="#8c865f3209cf6e05712c0d1ba7d3e589"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#fae8f92d83170d97f757f704eca7f52a">XMLCh</a> *&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#e5773fab0f689e5befc627d515818d46">weavePaths</a> (const <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#fae8f92d83170d97f757f704eca7f52a">XMLCh</a> *const basePath, const <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#fae8f92d83170d97f757f704eca7f52a">XMLCh</a> *const relativePath, <a class="el" href="classMemoryManager.html">MemoryManager</a> *const manager=<a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a>)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Utility to join two paths.  <a href="#e5773fab0f689e5befc627d515818d46"></a><br></td></tr>
<tr><td colspan="2"><div class="groupHeader">Timing Methods</div></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static unsigned long&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#4d315cfa7b9ec38b47b458fde5f2f443">getCurrentMillis</a> ()</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Gets the system time in milliseconds.  <a href="#4d315cfa7b9ec38b47b458fde5f2f443"></a><br></td></tr>
<tr><td colspan="2"><div class="groupHeader">Mutex Methods</div></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static <a class="el" href="classXMLMutexMgr.html">XMLMutexMgr</a> *&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#d41fe916bbe6e7594bdc103ebe24c2fd">makeMutexMgr</a> (<a class="el" href="classMemoryManager.html">MemoryManager</a> *const manager)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Factory method for creating MutexMgr object.  <a href="#d41fe916bbe6e7594bdc103ebe24c2fd"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#411987d4230f48888c23aa3d293c3fa5">closeMutex</a> (void *const mtxHandle, <a class="el" href="classMemoryManager.html">MemoryManager</a> *const manager=<a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a>)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Closes a mutex handle.  <a href="#411987d4230f48888c23aa3d293c3fa5"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#15fd7d673d0c6ce193b5c068d0c4b872">lockMutex</a> (void *const mtxHandle)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Locks a mutex handle.  <a href="#15fd7d673d0c6ce193b5c068d0c4b872"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static void *&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#dd15292f2ae75911a2d64781f1787629">makeMutex</a> (<a class="el" href="classMemoryManager.html">MemoryManager</a> *const manager=<a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a>)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Make a new mutex.  <a href="#dd15292f2ae75911a2d64781f1787629"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#e0213591d1ba763a82bd25197e22a89b">unlockMutex</a> (void *const mtxHandle)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Unlocks a mutex.  <a href="#e0213591d1ba763a82bd25197e22a89b"></a><br></td></tr>
<tr><td colspan="2"><div class="groupHeader">External Message Support</div></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static XMLMsgLoader *&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#f1981b8cfbf3b2d13e2debfd1eac634e">loadMsgSet</a> (const <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#fae8f92d83170d97f757f704eca7f52a">XMLCh</a> *const msgDomain)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Loads the message set from among the available domains.  <a href="#f1981b8cfbf3b2d13e2debfd1eac634e"></a><br></td></tr>
<tr><td colspan="2"><div class="groupHeader">NEL Character Handling</div></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#92246fafe4d841516c48b88f10d62a4a">recognizeNEL</a> (bool state, <a class="el" href="classMemoryManager.html">MemoryManager</a> *const manager=<a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a>)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">This function enables the recognition of NEL(0x85) char and LSEP (0x2028) as newline chars which is disabled by default.  <a href="#92246fafe4d841516c48b88f10d62a4a"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static bool&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#4367daf991397024b918fb0ab1a0389d">isNELRecognized</a> ()</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Return the value of fgNEL flag.  <a href="#4367daf991397024b918fb0ab1a0389d"></a><br></td></tr>
<tr><td colspan="2"><div class="groupHeader">Strict IANA Encoding Checking</div></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#467744b197025769630c61e940336434">strictIANAEncoding</a> (const bool state)</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">This function enables/disables strict IANA encoding names checking.  <a href="#467744b197025769630c61e940336434"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static bool&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#996f16ad1aad195eb2e7e618b5f89f94">isStrictIANAEncoding</a> ()</td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Returns whether a strict IANA encoding name check is enabled or disabled.  <a href="#996f16ad1aad195eb2e7e618b5f89f94"></a><br></td></tr>
<tr><td colspan="2"><br><h2>Static Public Attributes</h2></td></tr>
<tr><td colspan="2"><div class="groupHeader">Public Static Data</div></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static <a class="el" href="classXMLNetAccessor.html">XMLNetAccessor</a> *&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#6bbba118a3327b2e7c1952bf04de2787">fgNetAccessor</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">The network accessor.  <a href="#6bbba118a3327b2e7c1952bf04de2787"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static <a class="el" href="classXMLTransService.html">XMLTransService</a> *&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#bb0ad83db922cbf891a70319b2e6702b">fgTransService</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">The transcoding service.  <a href="#bb0ad83db922cbf891a70319b2e6702b"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static <a class="el" href="classPanicHandler.html">PanicHandler</a> *&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#ac6484e7073d5fb515ea791ee873b5bd">fgUserPanicHandler</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">The Panic Handler.  <a href="#ac6484e7073d5fb515ea791ee873b5bd"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static <a class="el" href="classPanicHandler.html">PanicHandler</a> *&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#db96471b53887380718f80e54934925f">fgDefaultPanicHandler</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">The Panic Handler.  <a href="#db96471b53887380718f80e54934925f"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static <a class="el" href="classMemoryManager.html">MemoryManager</a> *&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">fgMemoryManager</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">The configurable memory manager.  <a href="#97eff0d9fff3567bea3acd3ca4d95252"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static <a class="el" href="classXMLFileMgr.html">XMLFileMgr</a> *&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#14ce4194a811184a9e1e17ca2adeee9d">fgFileMgr</a></td></tr>

<tr><td class="memItemLeft" nowrap align="right" valign="top">static <a class="el" href="classXMLMutexMgr.html">XMLMutexMgr</a> *&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#28f0c7e21b0ccf29bb38c90a544ebc8f">fgMutexMgr</a></td></tr>

<tr><td class="memItemLeft" nowrap align="right" valign="top">static XMLMutex *&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#aa3859ca77bec01d7c5c4da4632ab761">fgAtomicMutex</a></td></tr>

<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Global mutex for fast or infrequent operations.  <a href="#aa3859ca77bec01d7c5c4da4632ab761"></a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static bool&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#5d963ab2acfd08abcfcaab3a7e5819d2">fgXMLChBigEndian</a></td></tr>

<tr><td class="memItemLeft" nowrap align="right" valign="top">static bool&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classXMLPlatformUtils.html#41b2fc50c55ad21172a8e649d441aec0">fgSSE2ok</a></td></tr>

</table>
<hr><a name="_details"></a><h2>Detailed Description</h2>
Utilities that must be implemented in a platform-specific way. 
<p>
This class contains methods that must be implemented in a platform specific manner. The actual implementations of these methods are available in the per-platform files indide <code>src/util/Platforms </code>. <hr><h2>Member Function Documentation</h2>
<a class="anchor" name="aa98f8d1346b8b531ee8886d9ce36173"></a><!-- doxytag: member="XMLPlatformUtils::Initialize" ref="aa98f8d1346b8b531ee8886d9ce36173" args="(const char *const locale=XMLUni::fgXercescDefaultLocale, const char *const nlsHome=0, PanicHandler *const panicHandler=0, MemoryManager *const memoryManager=0)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static void XMLPlatformUtils::Initialize           </td>
          <td>(</td>
          <td class="paramtype">const char *const &nbsp;</td>
          <td class="paramname"> <em>locale</em> = <code><a class="el" href="classXMLUni.html#65fb61efef197f1387836a339477ab5e">XMLUni::fgXercescDefaultLocale</a></code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const char *const &nbsp;</td>
          <td class="paramname"> <em>nlsHome</em> = <code>0</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="classPanicHandler.html">PanicHandler</a> *const &nbsp;</td>
          <td class="paramname"> <em>panicHandler</em> = <code>0</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="classMemoryManager.html">MemoryManager</a> *const &nbsp;</td>
          <td class="paramname"> <em>memoryManager</em> = <code>0</code></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Perform per-process parser initialization. 
<p>
Initialization <b>must</b> be called first in any client code.<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>locale</em>&nbsp;</td><td>The locale to use for messages.</td></tr>
  </table>
</dl>
The locale is set iff the <a class="el" href="classXMLPlatformUtils.html#aa98f8d1346b8b531ee8886d9ce36173" title="Perform per-process parser initialization.">Initialize()</a> is invoked for the very first time, to ensure that each and every message loader, in the process space, share the same locale.<p>
All subsequent invocations of <a class="el" href="classXMLPlatformUtils.html#aa98f8d1346b8b531ee8886d9ce36173" title="Perform per-process parser initialization.">Initialize()</a>, with a different locale, have no effect on the message loaders, either instantiated, or to be instantiated.<p>
To set to a different locale, client application needs to <a class="el" href="classXMLPlatformUtils.html#dc0dcc57907126e06a2f5e376b392794" title="Perform per-process parser termination.">Terminate()</a> (or multiple <a class="el" href="classXMLPlatformUtils.html#dc0dcc57907126e06a2f5e376b392794" title="Perform per-process parser termination.">Terminate()</a> in the case where multiple <a class="el" href="classXMLPlatformUtils.html#aa98f8d1346b8b531ee8886d9ce36173" title="Perform per-process parser initialization.">Initialize()</a> have been invoked before), followed by Initialize(new_locale).<p>
The default locale is "en_US".<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>nlsHome</em>&nbsp;</td><td>User specified location where MsgLoader retrieves error message files. the discussion above with regard to locale, applies to nlsHome as well.</td></tr>
    <tr><td valign="top"></td><td valign="top"><em>panicHandler</em>&nbsp;</td><td>Application's panic handler, application owns this handler. Application shall make sure that the plugged panic handler persists through the call to <a class="el" href="classXMLPlatformUtils.html#dc0dcc57907126e06a2f5e376b392794" title="Perform per-process parser termination.">XMLPlatformUtils::Terminate()</a>.</td></tr>
    <tr><td valign="top"></td><td valign="top"><em>memoryManager</em>&nbsp;</td><td>Plugged-in memory manager which is owned by the application. Applications must make sure that the plugged-in memory manager persist through the call to <a class="el" href="classXMLPlatformUtils.html#dc0dcc57907126e06a2f5e376b392794" title="Perform per-process parser termination.">XMLPlatformUtils::Terminate()</a> </td></tr>
  </table>
</dl>

</div>
</div><p>
<a class="anchor" name="369d3584567fc54c582b2074aed43f18"></a><!-- doxytag: member="XMLPlatformUtils::Initialize" ref="369d3584567fc54c582b2074aed43f18" args="(XMLSize_t initialDOMHeapAllocSize, XMLSize_t maxDOMHeapAllocSize, XMLSize_t maxDOMSubAllocationSize, const char *const locale=XMLUni::fgXercescDefaultLocale, const char *const nlsHome=0, PanicHandler *const panicHandler=0, MemoryManager *const memoryManager=0)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static void XMLPlatformUtils::Initialize           </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#c0f7e36996cd03eb43bcee10321f77cd">XMLSize_t</a>&nbsp;</td>
          <td class="paramname"> <em>initialDOMHeapAllocSize</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#c0f7e36996cd03eb43bcee10321f77cd">XMLSize_t</a>&nbsp;</td>
          <td class="paramname"> <em>maxDOMHeapAllocSize</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#c0f7e36996cd03eb43bcee10321f77cd">XMLSize_t</a>&nbsp;</td>
          <td class="paramname"> <em>maxDOMSubAllocationSize</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const char *const &nbsp;</td>
          <td class="paramname"> <em>locale</em> = <code><a class="el" href="classXMLUni.html#65fb61efef197f1387836a339477ab5e">XMLUni::fgXercescDefaultLocale</a></code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const char *const &nbsp;</td>
          <td class="paramname"> <em>nlsHome</em> = <code>0</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="classPanicHandler.html">PanicHandler</a> *const &nbsp;</td>
          <td class="paramname"> <em>panicHandler</em> = <code>0</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="classMemoryManager.html">MemoryManager</a> *const &nbsp;</td>
          <td class="paramname"> <em>memoryManager</em> = <code>0</code></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Perform per-process parser initialization. 
<p>
Initialization <b>must</b> be called first in any client code.<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>initialDOMHeapAllocSize</em>&nbsp;</td><td>The size of the first memory block allocated by the <a class="el" href="classDOMDocument.html" title="The DOMDocument interface represents the entire XML document.">DOMDocument</a> heap. Note that changing this parameter may result in poor performance and/or excessive memory usage. For the default value refer to dom/impl/DOMDocumentImpl.cpp.</td></tr>
    <tr><td valign="top"></td><td valign="top"><em>maxDOMHeapAllocSize</em>&nbsp;</td><td>The maximum size of the memory block allocated by the <a class="el" href="classDOMDocument.html" title="The DOMDocument interface represents the entire XML document.">DOMDocument</a> heap. As the document grows, the allocated by the heap memory blocks grow from initialDOMHeapAllocSize to maxDOMHeapAllocSize. Note that changing this parameter may result in poor performance and/or excessive memory usage. For the default value refer to dom/impl/DOMDocumentImpl.cpp.</td></tr>
    <tr><td valign="top"></td><td valign="top"><em>maxDOMSubAllocationSize</em>&nbsp;</td><td>The maximum size of the memory block requested that is handled by the <a class="el" href="classDOMDocument.html" title="The DOMDocument interface represents the entire XML document.">DOMDocument</a> heap. A request for a larger block is handled directly by the memory manager. Note that changing this parameter may result in poor performance and/or excessive memory usage. For the default value refer to dom/impl/DOMDocumentImpl.cpp.</td></tr>
    <tr><td valign="top"></td><td valign="top"><em>locale</em>&nbsp;</td><td>The locale to use for messages.</td></tr>
  </table>
</dl>
The locale is set iff the <a class="el" href="classXMLPlatformUtils.html#aa98f8d1346b8b531ee8886d9ce36173" title="Perform per-process parser initialization.">Initialize()</a> is invoked for the very first time, to ensure that each and every message loader, in the process space, share the same locale.<p>
All subsequent invocations of <a class="el" href="classXMLPlatformUtils.html#aa98f8d1346b8b531ee8886d9ce36173" title="Perform per-process parser initialization.">Initialize()</a>, with a different locale, have no effect on the message loaders, either instantiated, or to be instantiated.<p>
To set to a different locale, client application needs to <a class="el" href="classXMLPlatformUtils.html#dc0dcc57907126e06a2f5e376b392794" title="Perform per-process parser termination.">Terminate()</a> (or multiple <a class="el" href="classXMLPlatformUtils.html#dc0dcc57907126e06a2f5e376b392794" title="Perform per-process parser termination.">Terminate()</a> in the case where multiple <a class="el" href="classXMLPlatformUtils.html#aa98f8d1346b8b531ee8886d9ce36173" title="Perform per-process parser initialization.">Initialize()</a> have been invoked before), followed by Initialize(new_locale).<p>
The default locale is "en_US".<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>nlsHome</em>&nbsp;</td><td>User specified location where MsgLoader retrieves error message files. the discussion above with regard to locale, applies to nlsHome as well.</td></tr>
    <tr><td valign="top"></td><td valign="top"><em>panicHandler</em>&nbsp;</td><td>Application's panic handler, application owns this handler. Application shall make sure that the plugged panic handler persists through the call to <a class="el" href="classXMLPlatformUtils.html#dc0dcc57907126e06a2f5e376b392794" title="Perform per-process parser termination.">XMLPlatformUtils::Terminate()</a>.</td></tr>
    <tr><td valign="top"></td><td valign="top"><em>memoryManager</em>&nbsp;</td><td>Plugged-in memory manager which is owned by the application. Applications must make sure that the plugged-in memory manager persist through the call to <a class="el" href="classXMLPlatformUtils.html#dc0dcc57907126e06a2f5e376b392794" title="Perform per-process parser termination.">XMLPlatformUtils::Terminate()</a> </td></tr>
  </table>
</dl>

</div>
</div><p>
<a class="anchor" name="dc0dcc57907126e06a2f5e376b392794"></a><!-- doxytag: member="XMLPlatformUtils::Terminate" ref="dc0dcc57907126e06a2f5e376b392794" args="()" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static void XMLPlatformUtils::Terminate           </td>
          <td>(</td>
          <td class="paramname">          </td>
          <td>&nbsp;)&nbsp;</td>
          <td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Perform per-process parser termination. 
<p>
The termination call is currently optional, to aid those dynamically loading the parser to clean up before exit, or to avoid spurious reports from leak detectors. 
</div>
</div><p>
<a class="anchor" name="b07bdc9abed13b76519c88b166cd6442"></a><!-- doxytag: member="XMLPlatformUtils::panic" ref="b07bdc9abed13b76519c88b166cd6442" args="(const PanicHandler::PanicReasons reason)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static void XMLPlatformUtils::panic           </td>
          <td>(</td>
          <td class="paramtype">const <a class="el" href="classPanicHandler.html#ace4c4f408d68f168e1c2537e0ba5be2">PanicHandler::PanicReasons</a>&nbsp;</td>
          <td class="paramname"> <em>reason</em>          </td>
          <td>&nbsp;)&nbsp;</td>
          <td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
The panic mechanism. 
<p>
If, during initialization, we cannot even get far enough along to get transcoding up or get message loading working, we call this method.<p>
Each platform can implement it however they want. This method will delegate the panic handling to a user specified panic handler or in the absence of it, the default panic handler.<p>
In case the default panic handler does not support a particular platform, the platform specific panic hanlding shall be implemented here .<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>reason</em>&nbsp;</td><td>The enumeration that defines the cause of the failure </td></tr>
  </table>
</dl>

</div>
</div><p>
<a class="anchor" name="001e511067dc6ac8941e34732b8fa7cb"></a><!-- doxytag: member="XMLPlatformUtils::makeFileMgr" ref="001e511067dc6ac8941e34732b8fa7cb" args="(MemoryManager *const manager)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static <a class="el" href="classXMLFileMgr.html">XMLFileMgr</a>* XMLPlatformUtils::makeFileMgr           </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="classMemoryManager.html">MemoryManager</a> *const &nbsp;</td>
          <td class="paramname"> <em>manager</em>          </td>
          <td>&nbsp;)&nbsp;</td>
          <td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Make a new file object appropriate for the platform. 
<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>manager</em>&nbsp;</td><td>The <a class="el" href="classMemoryManager.html" title="Configurable memory manager.">MemoryManager</a> to use to allocate objects </td></tr>
  </table>
</dl>

</div>
</div><p>
<a class="anchor" name="2acb4b2eec3a5ddb579c6d410c7873e9"></a><!-- doxytag: member="XMLPlatformUtils::curFilePos" ref="2acb4b2eec3a5ddb579c6d410c7873e9" args="(FileHandle theFile, MemoryManager *const manager=XMLPlatformUtils::fgMemoryManager)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#7647261a546ac47bda863a51d24ad898">XMLFilePos</a> XMLPlatformUtils::curFilePos           </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="XMLFileMgr_8hpp.html#6738b6a1cc86fbf4c231eac94e357446">FileHandle</a>&nbsp;</td>
          <td class="paramname"> <em>theFile</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="classMemoryManager.html">MemoryManager</a> *const &nbsp;</td>
          <td class="paramname"> <em>manager</em> = <code><a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a></code></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Get the current file position. 
<p>
This must be implemented by the per-platform driver, which should use local file services to deterine the current position within the passed file.<p>
Since the file API provided here only reads, if the host platform supports separate read/write positions, only the read position is of any interest, and hence should be the one returned.<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>theFile</em>&nbsp;</td><td>The file handle </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>manager</em>&nbsp;</td><td>The <a class="el" href="classMemoryManager.html" title="Configurable memory manager.">MemoryManager</a> to use to allocate objects </td></tr>
  </table>
</dl>

</div>
</div><p>
<a class="anchor" name="a0398de86ccca867efb18f73ec8a82f4"></a><!-- doxytag: member="XMLPlatformUtils::closeFile" ref="a0398de86ccca867efb18f73ec8a82f4" args="(FileHandle theFile, MemoryManager *const manager=XMLPlatformUtils::fgMemoryManager)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static void XMLPlatformUtils::closeFile           </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="XMLFileMgr_8hpp.html#6738b6a1cc86fbf4c231eac94e357446">FileHandle</a>&nbsp;</td>
          <td class="paramname"> <em>theFile</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="classMemoryManager.html">MemoryManager</a> *const &nbsp;</td>
          <td class="paramname"> <em>manager</em> = <code><a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a></code></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Closes the file handle. 
<p>
This must be implemented by the per-platform driver, which should use local file services to close the passed file handle, and to destroy the passed file handle and any allocated data or system resources it contains.<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>theFile</em>&nbsp;</td><td>The file handle to close </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>manager</em>&nbsp;</td><td>The <a class="el" href="classMemoryManager.html" title="Configurable memory manager.">MemoryManager</a> to use to allocate objects </td></tr>
  </table>
</dl>

</div>
</div><p>
<a class="anchor" name="788a3664405357f0004a1d55c4dc02df"></a><!-- doxytag: member="XMLPlatformUtils::fileSize" ref="788a3664405357f0004a1d55c4dc02df" args="(FileHandle theFile, MemoryManager *const manager=XMLPlatformUtils::fgMemoryManager)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#7647261a546ac47bda863a51d24ad898">XMLFilePos</a> XMLPlatformUtils::fileSize           </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="XMLFileMgr_8hpp.html#6738b6a1cc86fbf4c231eac94e357446">FileHandle</a>&nbsp;</td>
          <td class="paramname"> <em>theFile</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="classMemoryManager.html">MemoryManager</a> *const &nbsp;</td>
          <td class="paramname"> <em>manager</em> = <code><a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a></code></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Returns the file size. 
<p>
This must be implemented by the per-platform driver, which should use local file services to determine the current size of the file represented by the passed handle.<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>theFile</em>&nbsp;</td><td>The file handle whose size you want </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>manager</em>&nbsp;</td><td>The <a class="el" href="classMemoryManager.html" title="Configurable memory manager.">MemoryManager</a> to use to allocate objects </td></tr>
  </table>
</dl>
<dl class="return" compact><dt><b>Returns:</b></dt><dd>Returns the size of the file in bytes </dd></dl>

</div>
</div><p>
<a class="anchor" name="98eadae95169c66853c8264438505907"></a><!-- doxytag: member="XMLPlatformUtils::openFile" ref="98eadae95169c66853c8264438505907" args="(const char *const fileName, MemoryManager *const manager=XMLPlatformUtils::fgMemoryManager)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static <a class="el" href="XMLFileMgr_8hpp.html#6738b6a1cc86fbf4c231eac94e357446">FileHandle</a> XMLPlatformUtils::openFile           </td>
          <td>(</td>
          <td class="paramtype">const char *const &nbsp;</td>
          <td class="paramname"> <em>fileName</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="classMemoryManager.html">MemoryManager</a> *const &nbsp;</td>
          <td class="paramname"> <em>manager</em> = <code><a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a></code></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Opens the file. 
<p>
This must be implemented by the per-platform driver, which should use local file services to open passed file. If it fails, a null handle pointer should be returned.<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>fileName</em>&nbsp;</td><td>The string containing the name of the file </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>manager</em>&nbsp;</td><td>The <a class="el" href="classMemoryManager.html" title="Configurable memory manager.">MemoryManager</a> to use to allocate objects </td></tr>
  </table>
</dl>
<dl class="return" compact><dt><b>Returns:</b></dt><dd>The file handle of the opened file </dd></dl>

</div>
</div><p>
<a class="anchor" name="5632167e9027b6def671ed4571ccf0bf"></a><!-- doxytag: member="XMLPlatformUtils::openFile" ref="5632167e9027b6def671ed4571ccf0bf" args="(const XMLCh *const fileName, MemoryManager *const manager=XMLPlatformUtils::fgMemoryManager)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static <a class="el" href="XMLFileMgr_8hpp.html#6738b6a1cc86fbf4c231eac94e357446">FileHandle</a> XMLPlatformUtils::openFile           </td>
          <td>(</td>
          <td class="paramtype">const <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#fae8f92d83170d97f757f704eca7f52a">XMLCh</a> *const &nbsp;</td>
          <td class="paramname"> <em>fileName</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="classMemoryManager.html">MemoryManager</a> *const &nbsp;</td>
          <td class="paramname"> <em>manager</em> = <code><a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a></code></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Opens a named file. 
<p>
This must be implemented by the per-platform driver, which should use local file services to open the passed file. If it fails, a null handle pointer should be returned.<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>fileName</em>&nbsp;</td><td>The string containing the name of the file </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>manager</em>&nbsp;</td><td>The <a class="el" href="classMemoryManager.html" title="Configurable memory manager.">MemoryManager</a> to use to allocate objects </td></tr>
  </table>
</dl>
<dl class="return" compact><dt><b>Returns:</b></dt><dd>The file handle of the opened file </dd></dl>

</div>
</div><p>
<a class="anchor" name="5939d893ef7399d9d770be562bea6cfb"></a><!-- doxytag: member="XMLPlatformUtils::openFileToWrite" ref="5939d893ef7399d9d770be562bea6cfb" args="(const char *const fileName, MemoryManager *const manager=XMLPlatformUtils::fgMemoryManager)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static <a class="el" href="XMLFileMgr_8hpp.html#6738b6a1cc86fbf4c231eac94e357446">FileHandle</a> XMLPlatformUtils::openFileToWrite           </td>
          <td>(</td>
          <td class="paramtype">const char *const &nbsp;</td>
          <td class="paramname"> <em>fileName</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="classMemoryManager.html">MemoryManager</a> *const &nbsp;</td>
          <td class="paramname"> <em>manager</em> = <code><a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a></code></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Open a named file to write. 
<p>
This must be implemented by the per-platform driver, which should use local file services to open passed file. If it fails, a null handle pointer should be returned.<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>fileName</em>&nbsp;</td><td>The string containing the name of the file </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>manager</em>&nbsp;</td><td>The <a class="el" href="classMemoryManager.html" title="Configurable memory manager.">MemoryManager</a> to use to allocate objects </td></tr>
  </table>
</dl>
<dl class="return" compact><dt><b>Returns:</b></dt><dd>The file handle of the opened file </dd></dl>

</div>
</div><p>
<a class="anchor" name="6e96c30edcbe8b1fa570fe2de0d5c31b"></a><!-- doxytag: member="XMLPlatformUtils::openFileToWrite" ref="6e96c30edcbe8b1fa570fe2de0d5c31b" args="(const XMLCh *const fileName, MemoryManager *const manager=XMLPlatformUtils::fgMemoryManager)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static <a class="el" href="XMLFileMgr_8hpp.html#6738b6a1cc86fbf4c231eac94e357446">FileHandle</a> XMLPlatformUtils::openFileToWrite           </td>
          <td>(</td>
          <td class="paramtype">const <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#fae8f92d83170d97f757f704eca7f52a">XMLCh</a> *const &nbsp;</td>
          <td class="paramname"> <em>fileName</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="classMemoryManager.html">MemoryManager</a> *const &nbsp;</td>
          <td class="paramname"> <em>manager</em> = <code><a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a></code></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Open a named file to write. 
<p>
This must be implemented by the per-platform driver, which should use local file services to open the passed file. If it fails, a null handle pointer should be returned.<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>fileName</em>&nbsp;</td><td>The string containing the name of the file </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>manager</em>&nbsp;</td><td>The <a class="el" href="classMemoryManager.html" title="Configurable memory manager.">MemoryManager</a> to use to allocate objects </td></tr>
  </table>
</dl>
<dl class="return" compact><dt><b>Returns:</b></dt><dd>The file handle of the opened file </dd></dl>

</div>
</div><p>
<a class="anchor" name="627be718689157e44f73da8fd23ee004"></a><!-- doxytag: member="XMLPlatformUtils::openStdInHandle" ref="627be718689157e44f73da8fd23ee004" args="(MemoryManager *const manager=XMLPlatformUtils::fgMemoryManager)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static <a class="el" href="XMLFileMgr_8hpp.html#6738b6a1cc86fbf4c231eac94e357446">FileHandle</a> XMLPlatformUtils::openStdInHandle           </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="classMemoryManager.html">MemoryManager</a> *const &nbsp;</td>
          <td class="paramname"> <em>manager</em> = <code><a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a></code>          </td>
          <td>&nbsp;)&nbsp;</td>
          <td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Opens the standard input as a file. 
<p>
This must be implemented by the per-platform driver, which should use local file services to open a handle to the standard input. It should be a copy of the standard input handle, since it will be closed later!<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>manager</em>&nbsp;</td><td>The <a class="el" href="classMemoryManager.html" title="Configurable memory manager.">MemoryManager</a> to use to allocate objects </td></tr>
  </table>
</dl>
<dl class="return" compact><dt><b>Returns:</b></dt><dd>The file handle of the standard input stream </dd></dl>

</div>
</div><p>
<a class="anchor" name="1f24a6b4b6c097ab66617f48349527dd"></a><!-- doxytag: member="XMLPlatformUtils::readFileBuffer" ref="1f24a6b4b6c097ab66617f48349527dd" args="(FileHandle theFile, const XMLSize_t toRead, XMLByte *const toFill, MemoryManager *const manager=XMLPlatformUtils::fgMemoryManager)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#c0f7e36996cd03eb43bcee10321f77cd">XMLSize_t</a> XMLPlatformUtils::readFileBuffer           </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="XMLFileMgr_8hpp.html#6738b6a1cc86fbf4c231eac94e357446">FileHandle</a>&nbsp;</td>
          <td class="paramname"> <em>theFile</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#c0f7e36996cd03eb43bcee10321f77cd">XMLSize_t</a>&nbsp;</td>
          <td class="paramname"> <em>toRead</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="XercesDefs_8hpp.html#7470c7a32c59355685ebcd878a33f126">XMLByte</a> *const &nbsp;</td>
          <td class="paramname"> <em>toFill</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="classMemoryManager.html">MemoryManager</a> *const &nbsp;</td>
          <td class="paramname"> <em>manager</em> = <code><a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a></code></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Reads the file buffer. 
<p>
This must be implemented by the per-platform driver, which should use local file services to read up to 'toRead' bytes of data from the passed file, and return those bytes in the 'toFill' buffer. It is not an error not to read the requested number of bytes. When the end of file is reached, zero should be returned.<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>theFile</em>&nbsp;</td><td>The file handle to be read from. </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>toRead</em>&nbsp;</td><td>The maximum number of byte to read from the current position </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>toFill</em>&nbsp;</td><td>The byte buffer to fill </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>manager</em>&nbsp;</td><td>The <a class="el" href="classMemoryManager.html" title="Configurable memory manager.">MemoryManager</a> to use to allocate objects</td></tr>
  </table>
</dl>
<dl class="return" compact><dt><b>Returns:</b></dt><dd>Returns the number of bytes read from the stream or file </dd></dl>

</div>
</div><p>
<a class="anchor" name="6c77c874c1c3c04773c5d7c16056f874"></a><!-- doxytag: member="XMLPlatformUtils::writeBufferToFile" ref="6c77c874c1c3c04773c5d7c16056f874" args="(FileHandle const theFile, XMLSize_t toWrite, const XMLByte *const toFlush, MemoryManager *const manager=XMLPlatformUtils::fgMemoryManager)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static void XMLPlatformUtils::writeBufferToFile           </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="XMLFileMgr_8hpp.html#6738b6a1cc86fbf4c231eac94e357446">FileHandle</a> const &nbsp;</td>
          <td class="paramname"> <em>theFile</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#c0f7e36996cd03eb43bcee10321f77cd">XMLSize_t</a>&nbsp;</td>
          <td class="paramname"> <em>toWrite</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const <a class="el" href="XercesDefs_8hpp.html#7470c7a32c59355685ebcd878a33f126">XMLByte</a> *const &nbsp;</td>
          <td class="paramname"> <em>toFlush</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="classMemoryManager.html">MemoryManager</a> *const &nbsp;</td>
          <td class="paramname"> <em>manager</em> = <code><a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a></code></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Writes the buffer to the file. 
<p>
This must be implemented by the per-platform driver, which should use local file services to write up to 'toWrite' bytes of data to the passed file. Unless exception raised by local file services, 'toWrite' bytes of data is to be written to the passed file.<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>theFile</em>&nbsp;</td><td>The file handle to be written to. </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>toWrite</em>&nbsp;</td><td>The maximum number of byte to write from the current position </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>toFlush</em>&nbsp;</td><td>The byte buffer to flush </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>manager</em>&nbsp;</td><td>The <a class="el" href="classMemoryManager.html" title="Configurable memory manager.">MemoryManager</a> to use to allocate objects </td></tr>
  </table>
</dl>
<dl class="return" compact><dt><b>Returns:</b></dt><dd>void </dd></dl>

</div>
</div><p>
<a class="anchor" name="3e64b2526936ae010a69cb42ba44c5c8"></a><!-- doxytag: member="XMLPlatformUtils::resetFile" ref="3e64b2526936ae010a69cb42ba44c5c8" args="(FileHandle theFile, MemoryManager *const manager=XMLPlatformUtils::fgMemoryManager)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static void XMLPlatformUtils::resetFile           </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="XMLFileMgr_8hpp.html#6738b6a1cc86fbf4c231eac94e357446">FileHandle</a>&nbsp;</td>
          <td class="paramname"> <em>theFile</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="classMemoryManager.html">MemoryManager</a> *const &nbsp;</td>
          <td class="paramname"> <em>manager</em> = <code><a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a></code></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Resets the file handle. 
<p>
This must be implemented by the per-platform driver which will use local file services to reset the file position to the start of the the file.<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>theFile</em>&nbsp;</td><td>The file handle that you want to reset </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>manager</em>&nbsp;</td><td>The <a class="el" href="classMemoryManager.html" title="Configurable memory manager.">MemoryManager</a> to use to allocate objects </td></tr>
  </table>
</dl>

</div>
</div><p>
<a class="anchor" name="41d767f41350edd2bd8853714b9124d8"></a><!-- doxytag: member="XMLPlatformUtils::getFullPath" ref="41d767f41350edd2bd8853714b9124d8" args="(const XMLCh *const srcPath, MemoryManager *const manager=XMLPlatformUtils::fgMemoryManager)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#fae8f92d83170d97f757f704eca7f52a">XMLCh</a>* XMLPlatformUtils::getFullPath           </td>
          <td>(</td>
          <td class="paramtype">const <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#fae8f92d83170d97f757f704eca7f52a">XMLCh</a> *const &nbsp;</td>
          <td class="paramname"> <em>srcPath</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="classMemoryManager.html">MemoryManager</a> *const &nbsp;</td>
          <td class="paramname"> <em>manager</em> = <code><a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a></code></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Gets the full path from a relative path. 
<p>
This must be implemented by the per-platform driver. It should complete a relative path using the 'current directory', or whatever the local equivalent of a current directory is. If the passed source path is actually fully qualified, then a straight copy of it will be returned.<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>srcPath</em>&nbsp;</td><td>The path of the file for which you want the full path</td></tr>
    <tr><td valign="top"></td><td valign="top"><em>manager</em>&nbsp;</td><td>Pointer to the memory manager to be used to allocate objects.</td></tr>
  </table>
</dl>
<dl class="return" compact><dt><b>Returns:</b></dt><dd>Returns the fully qualified path of the file name including the file name. This is dyanmically allocated and must be deleted by the caller when its no longer needed! The memory returned will beallocated using the static memory manager, if user do not supply a memory manager. Users then need to make sure to use either the default or user specific memory manager to deallocate the memory. </dd></dl>

</div>
</div><p>
<a class="anchor" name="8385708fc8ef23f163a09f19d378231c"></a><!-- doxytag: member="XMLPlatformUtils::getCurrentDirectory" ref="8385708fc8ef23f163a09f19d378231c" args="(MemoryManager *const manager=XMLPlatformUtils::fgMemoryManager)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#fae8f92d83170d97f757f704eca7f52a">XMLCh</a>* XMLPlatformUtils::getCurrentDirectory           </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="classMemoryManager.html">MemoryManager</a> *const &nbsp;</td>
          <td class="paramname"> <em>manager</em> = <code><a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a></code>          </td>
          <td>&nbsp;)&nbsp;</td>
          <td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Gets the current working directory. 
<p>
This must be implemented by the per-platform driver. It returns the current working directory is. <dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>manager</em>&nbsp;</td><td>The <a class="el" href="classMemoryManager.html" title="Configurable memory manager.">MemoryManager</a> to use to allocate objects </td></tr>
  </table>
</dl>
<dl class="return" compact><dt><b>Returns:</b></dt><dd>Returns the current working directory. This is dyanmically allocated and must be deleted by the caller when its no longer needed! The memory returned will be allocated using the static memory manager, if users do not supply a memory manager. Users then need to make sure to use either the default or user specific memory manager to deallocate the memory. </dd></dl>

</div>
</div><p>
<a class="anchor" name="381a005feb529e59f65a4cbd5fe39c11"></a><!-- doxytag: member="XMLPlatformUtils::isAnySlash" ref="381a005feb529e59f65a4cbd5fe39c11" args="(XMLCh c)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static bool XMLPlatformUtils::isAnySlash           </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#fae8f92d83170d97f757f704eca7f52a">XMLCh</a>&nbsp;</td>
          <td class="paramname"> <em>c</em>          </td>
          <td>&nbsp;)&nbsp;</td>
          <td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Check if a charater is a slash. 
<p>
This must be implemented by the per-platform driver.<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>c</em>&nbsp;</td><td>the character to be examined</td></tr>
  </table>
</dl>
<dl class="return" compact><dt><b>Returns:</b></dt><dd>true if the character examined is a slash false otherwise </dd></dl>

</div>
</div><p>
<a class="anchor" name="ff1af43494b60e1783124747f291b6a0"></a><!-- doxytag: member="XMLPlatformUtils::removeDotSlash" ref="ff1af43494b60e1783124747f291b6a0" args="(XMLCh *const srcPath, MemoryManager *const manager=XMLPlatformUtils::fgMemoryManager)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static void XMLPlatformUtils::removeDotSlash           </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#fae8f92d83170d97f757f704eca7f52a">XMLCh</a> *const &nbsp;</td>
          <td class="paramname"> <em>srcPath</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="classMemoryManager.html">MemoryManager</a> *const &nbsp;</td>
          <td class="paramname"> <em>manager</em> = <code><a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a></code></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Remove occurences of the pair of dot slash. 
<p>
To remove the sequence, dot slash if it is part of the sequence, slash dot slash.<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>srcPath</em>&nbsp;</td><td>The path for which you want to remove the dot slash sequence. </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>manager</em>&nbsp;</td><td>The <a class="el" href="classMemoryManager.html" title="Configurable memory manager.">MemoryManager</a> to use to allocate objects </td></tr>
  </table>
</dl>
<dl class="return" compact><dt><b>Returns:</b></dt><dd></dd></dl>

</div>
</div><p>
<a class="anchor" name="1b90b8d2129bdcdfa4bf615db8dd85a7"></a><!-- doxytag: member="XMLPlatformUtils::removeDotDotSlash" ref="1b90b8d2129bdcdfa4bf615db8dd85a7" args="(XMLCh *const srcPath, MemoryManager *const manager=XMLPlatformUtils::fgMemoryManager)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static void XMLPlatformUtils::removeDotDotSlash           </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#fae8f92d83170d97f757f704eca7f52a">XMLCh</a> *const &nbsp;</td>
          <td class="paramname"> <em>srcPath</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="classMemoryManager.html">MemoryManager</a> *const &nbsp;</td>
          <td class="paramname"> <em>manager</em> = <code><a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a></code></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Remove occurences of the dot dot slash. 
<p>
To remove the sequence, slash dot dot slash and its preceding path segment if and only if the preceding path segment is not slash dot dot slash.<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>srcPath</em>&nbsp;</td><td>The path for which you want to remove the slash dot dot slash sequence and its preceding path segment. </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>manager</em>&nbsp;</td><td>The <a class="el" href="classMemoryManager.html" title="Configurable memory manager.">MemoryManager</a> to use to allocate objects </td></tr>
  </table>
</dl>
<dl class="return" compact><dt><b>Returns:</b></dt><dd></dd></dl>

</div>
</div><p>
<a class="anchor" name="8c865f3209cf6e05712c0d1ba7d3e589"></a><!-- doxytag: member="XMLPlatformUtils::isRelative" ref="8c865f3209cf6e05712c0d1ba7d3e589" args="(const XMLCh *const toCheck, MemoryManager *const manager=XMLPlatformUtils::fgMemoryManager)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static bool XMLPlatformUtils::isRelative           </td>
          <td>(</td>
          <td class="paramtype">const <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#fae8f92d83170d97f757f704eca7f52a">XMLCh</a> *const &nbsp;</td>
          <td class="paramname"> <em>toCheck</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="classMemoryManager.html">MemoryManager</a> *const &nbsp;</td>
          <td class="paramname"> <em>manager</em> = <code><a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a></code></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Determines if a path is relative or absolute. 
<p>
This must be implemented by the per-platform driver, which should determine whether the passed path is relative or not. The concept of relative and absolute might be... well relative on different platforms. But, as long as the determination is made consistently and in coordination with the <a class="el" href="classXMLPlatformUtils.html#e5773fab0f689e5befc627d515818d46" title="Utility to join two paths.">weavePaths()</a> method, it should work for any platform.<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>toCheck</em>&nbsp;</td><td>The file name which you want to check </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>manager</em>&nbsp;</td><td>The <a class="el" href="classMemoryManager.html" title="Configurable memory manager.">MemoryManager</a> to use to allocate objects </td></tr>
  </table>
</dl>
<dl class="return" compact><dt><b>Returns:</b></dt><dd>Returns true if the filename appears to be relative </dd></dl>

</div>
</div><p>
<a class="anchor" name="e5773fab0f689e5befc627d515818d46"></a><!-- doxytag: member="XMLPlatformUtils::weavePaths" ref="e5773fab0f689e5befc627d515818d46" args="(const XMLCh *const basePath, const XMLCh *const relativePath, MemoryManager *const manager=XMLPlatformUtils::fgMemoryManager)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#fae8f92d83170d97f757f704eca7f52a">XMLCh</a>* XMLPlatformUtils::weavePaths           </td>
          <td>(</td>
          <td class="paramtype">const <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#fae8f92d83170d97f757f704eca7f52a">XMLCh</a> *const &nbsp;</td>
          <td class="paramname"> <em>basePath</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#fae8f92d83170d97f757f704eca7f52a">XMLCh</a> *const &nbsp;</td>
          <td class="paramname"> <em>relativePath</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="classMemoryManager.html">MemoryManager</a> *const &nbsp;</td>
          <td class="paramname"> <em>manager</em> = <code><a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a></code></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Utility to join two paths. 
<p>
This must be implemented by the per-platform driver, and should weave the relative path part together with the base part and return a new path that represents this combination.<p>
If the relative part turns out to be fully qualified, it will be returned as is. If it is not, then it will be woven onto the passed base path, by removing one path component for each leading "../" (or whatever is the equivalent in the local system) in the relative path.<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>basePath</em>&nbsp;</td><td>The string containing the base path </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>relativePath</em>&nbsp;</td><td>The string containing the relative path </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>manager</em>&nbsp;</td><td>The <a class="el" href="classMemoryManager.html" title="Configurable memory manager.">MemoryManager</a> to use to allocate objects </td></tr>
  </table>
</dl>
<dl class="return" compact><dt><b>Returns:</b></dt><dd>Returns a string containing the 'woven' path. It should be dynamically allocated and becomes the responsibility of the caller to delete. </dd></dl>

</div>
</div><p>
<a class="anchor" name="4d315cfa7b9ec38b47b458fde5f2f443"></a><!-- doxytag: member="XMLPlatformUtils::getCurrentMillis" ref="4d315cfa7b9ec38b47b458fde5f2f443" args="()" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static unsigned long XMLPlatformUtils::getCurrentMillis           </td>
          <td>(</td>
          <td class="paramname">          </td>
          <td>&nbsp;)&nbsp;</td>
          <td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Gets the system time in milliseconds. 
<p>
This must be implemented by the per-platform driver, which should use local services to return the current value of a running millisecond timer. Note that the value returned is only as accurate as the millisecond time of the underyling host system.<p>
<dl class="return" compact><dt><b>Returns:</b></dt><dd>Returns the system time as an unsigned long </dd></dl>

</div>
</div><p>
<a class="anchor" name="d41fe916bbe6e7594bdc103ebe24c2fd"></a><!-- doxytag: member="XMLPlatformUtils::makeMutexMgr" ref="d41fe916bbe6e7594bdc103ebe24c2fd" args="(MemoryManager *const manager)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static <a class="el" href="classXMLMutexMgr.html">XMLMutexMgr</a>* XMLPlatformUtils::makeMutexMgr           </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="classMemoryManager.html">MemoryManager</a> *const &nbsp;</td>
          <td class="paramname"> <em>manager</em>          </td>
          <td>&nbsp;)&nbsp;</td>
          <td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Factory method for creating MutexMgr object. 
<p>
This factory method creates a mutexmgr that will be used on the particular platform.<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>manager</em>&nbsp;</td><td>The <a class="el" href="classMemoryManager.html" title="Configurable memory manager.">MemoryManager</a> to use to allocate objects </td></tr>
  </table>
</dl>

</div>
</div><p>
<a class="anchor" name="411987d4230f48888c23aa3d293c3fa5"></a><!-- doxytag: member="XMLPlatformUtils::closeMutex" ref="411987d4230f48888c23aa3d293c3fa5" args="(void *const mtxHandle, MemoryManager *const manager=XMLPlatformUtils::fgMemoryManager)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static void XMLPlatformUtils::closeMutex           </td>
          <td>(</td>
          <td class="paramtype">void *const &nbsp;</td>
          <td class="paramname"> <em>mtxHandle</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="classMemoryManager.html">MemoryManager</a> *const &nbsp;</td>
          <td class="paramname"> <em>manager</em> = <code><a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a></code></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Closes a mutex handle. 
<p>
Each per-platform driver must implement this. Only it knows what the actual content of the passed mutex handle is.<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>mtxHandle</em>&nbsp;</td><td>The mutex handle that you want to close </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>manager</em>&nbsp;</td><td>The <a class="el" href="classMemoryManager.html" title="Configurable memory manager.">MemoryManager</a> used to allocate the object </td></tr>
  </table>
</dl>

</div>
</div><p>
<a class="anchor" name="15fd7d673d0c6ce193b5c068d0c4b872"></a><!-- doxytag: member="XMLPlatformUtils::lockMutex" ref="15fd7d673d0c6ce193b5c068d0c4b872" args="(void *const mtxHandle)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static void XMLPlatformUtils::lockMutex           </td>
          <td>(</td>
          <td class="paramtype">void *const &nbsp;</td>
          <td class="paramname"> <em>mtxHandle</em>          </td>
          <td>&nbsp;)&nbsp;</td>
          <td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Locks a mutex handle. 
<p>
Each per-platform driver must implement this. Only it knows what the actual content of the passed mutex handle is.<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>mtxHandle</em>&nbsp;</td><td>The mutex handle that you want to lock </td></tr>
  </table>
</dl>

</div>
</div><p>
<a class="anchor" name="dd15292f2ae75911a2d64781f1787629"></a><!-- doxytag: member="XMLPlatformUtils::makeMutex" ref="dd15292f2ae75911a2d64781f1787629" args="(MemoryManager *const manager=XMLPlatformUtils::fgMemoryManager)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static void* XMLPlatformUtils::makeMutex           </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="classMemoryManager.html">MemoryManager</a> *const &nbsp;</td>
          <td class="paramname"> <em>manager</em> = <code><a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a></code>          </td>
          <td>&nbsp;)&nbsp;</td>
          <td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Make a new mutex. 
<p>
Each per-platform driver must implement this. Only it knows what the actual content of the passed mutex handle is. The returned handle pointer will be eventually passed to <a class="el" href="classXMLPlatformUtils.html#411987d4230f48888c23aa3d293c3fa5" title="Closes a mutex handle.">closeMutex()</a> which is also implemented by the platform driver.<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>manager</em>&nbsp;</td><td>The <a class="el" href="classMemoryManager.html" title="Configurable memory manager.">MemoryManager</a> to use to allocate objects </td></tr>
  </table>
</dl>

</div>
</div><p>
<a class="anchor" name="e0213591d1ba763a82bd25197e22a89b"></a><!-- doxytag: member="XMLPlatformUtils::unlockMutex" ref="e0213591d1ba763a82bd25197e22a89b" args="(void *const mtxHandle)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static void XMLPlatformUtils::unlockMutex           </td>
          <td>(</td>
          <td class="paramtype">void *const &nbsp;</td>
          <td class="paramname"> <em>mtxHandle</em>          </td>
          <td>&nbsp;)&nbsp;</td>
          <td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Unlocks a mutex. 
<p>
Each per-platform driver must implement this. Only it knows what the actual content of the passed mutex handle is.<p>
Note that, since the underlying system synchronization services are used, Xerces cannot guarantee that lock/unlock operations are correctly enforced on a per-thread basis or that incorrect nesting of lock/unlock operations will be caught.<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>mtxHandle</em>&nbsp;</td><td>The mutex handle that you want to unlock </td></tr>
  </table>
</dl>

</div>
</div><p>
<a class="anchor" name="f1981b8cfbf3b2d13e2debfd1eac634e"></a><!-- doxytag: member="XMLPlatformUtils::loadMsgSet" ref="f1981b8cfbf3b2d13e2debfd1eac634e" args="(const XMLCh *const msgDomain)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static XMLMsgLoader* XMLPlatformUtils::loadMsgSet           </td>
          <td>(</td>
          <td class="paramtype">const <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#fae8f92d83170d97f757f704eca7f52a">XMLCh</a> *const &nbsp;</td>
          <td class="paramname"> <em>msgDomain</em>          </td>
          <td>&nbsp;)&nbsp;</td>
          <td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Loads the message set from among the available domains. 
<p>
The returned object must be dynamically allocated and the caller becomes responsible for cleaning it up.<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>msgDomain</em>&nbsp;</td><td>The message domain which you want to load </td></tr>
  </table>
</dl>

</div>
</div><p>
<a class="anchor" name="92246fafe4d841516c48b88f10d62a4a"></a><!-- doxytag: member="XMLPlatformUtils::recognizeNEL" ref="92246fafe4d841516c48b88f10d62a4a" args="(bool state, MemoryManager *const manager=XMLPlatformUtils::fgMemoryManager)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static void XMLPlatformUtils::recognizeNEL           </td>
          <td>(</td>
          <td class="paramtype">bool&nbsp;</td>
          <td class="paramname"> <em>state</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="classMemoryManager.html">MemoryManager</a> *const &nbsp;</td>
          <td class="paramname"> <em>manager</em> = <code><a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a></code></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
This function enables the recognition of NEL(0x85) char and LSEP (0x2028) as newline chars which is disabled by default. 
<p>
It is only called once per process. Once it is set, any subsequent calls will result in exception being thrown.<p>
Note: 1. Turning this option on will make the parser non compliant to XML 1.0. 2. This option has no effect to document conforming to XML 1.1 compliant, which always recognize these two chars (0x85 and 0x2028) as newline characters. 
</div>
</div><p>
<a class="anchor" name="4367daf991397024b918fb0ab1a0389d"></a><!-- doxytag: member="XMLPlatformUtils::isNELRecognized" ref="4367daf991397024b918fb0ab1a0389d" args="()" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static bool XMLPlatformUtils::isNELRecognized           </td>
          <td>(</td>
          <td class="paramname">          </td>
          <td>&nbsp;)&nbsp;</td>
          <td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Return the value of fgNEL flag. 
<p>

</div>
</div><p>
<a class="anchor" name="467744b197025769630c61e940336434"></a><!-- doxytag: member="XMLPlatformUtils::strictIANAEncoding" ref="467744b197025769630c61e940336434" args="(const bool state)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static void XMLPlatformUtils::strictIANAEncoding           </td>
          <td>(</td>
          <td class="paramtype">const bool&nbsp;</td>
          <td class="paramname"> <em>state</em>          </td>
          <td>&nbsp;)&nbsp;</td>
          <td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
This function enables/disables strict IANA encoding names checking. 
<p>
The strict checking is disabled by default.<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>state</em>&nbsp;</td><td>If true, a strict IANA encoding name check is performed, otherwise, no checking. </td></tr>
  </table>
</dl>

</div>
</div><p>
<a class="anchor" name="996f16ad1aad195eb2e7e618b5f89f94"></a><!-- doxytag: member="XMLPlatformUtils::isStrictIANAEncoding" ref="996f16ad1aad195eb2e7e618b5f89f94" args="()" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static bool XMLPlatformUtils::isStrictIANAEncoding           </td>
          <td>(</td>
          <td class="paramname">          </td>
          <td>&nbsp;)&nbsp;</td>
          <td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Returns whether a strict IANA encoding name check is enabled or disabled. 
<p>

</div>
</div><p>
<a class="anchor" name="560fd9eecc8651995a4d6af70d71f23a"></a><!-- doxytag: member="XMLPlatformUtils::alignPointerForNewBlockAllocation" ref="560fd9eecc8651995a4d6af70d71f23a" args="(XMLSize_t ptrSize)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">static <a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#c0f7e36996cd03eb43bcee10321f77cd">XMLSize_t</a> XMLPlatformUtils::alignPointerForNewBlockAllocation           </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="Xerces__autoconf__config_8msvc_8hpp.html#c0f7e36996cd03eb43bcee10321f77cd">XMLSize_t</a>&nbsp;</td>
          <td class="paramname"> <em>ptrSize</em>          </td>
          <td>&nbsp;)&nbsp;</td>
          <td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Aligns the specified pointer per platform block allocation requirements. 
<p>
The results of this function may be altered by defining XML_PLATFORM_NEW_BLOCK_ALIGNMENT. 
</div>
</div><p>
<hr><h2>Member Data Documentation</h2>
<a class="anchor" name="6bbba118a3327b2e7c1952bf04de2787"></a><!-- doxytag: member="XMLPlatformUtils::fgNetAccessor" ref="6bbba118a3327b2e7c1952bf04de2787" args="" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classXMLNetAccessor.html">XMLNetAccessor</a>* <a class="el" href="classXMLPlatformUtils.html#6bbba118a3327b2e7c1952bf04de2787">XMLPlatformUtils::fgNetAccessor</a><code> [static]</code>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
The network accessor. 
<p>
This is provided by the per-platform driver, so each platform can choose what actual implementation it wants to use. The object must be dynamically allocated.<p>
<em>Note that you may optionally, if your platform driver does not install a network accessor, set it manually from your client code after calling <a class="el" href="classXMLPlatformUtils.html#aa98f8d1346b8b531ee8886d9ce36173" title="Perform per-process parser initialization.">Initialize()</a>. This works because this object is not required during initialization, and only comes into play during actual XML parsing.</em> 
</div>
</div><p>
<a class="anchor" name="bb0ad83db922cbf891a70319b2e6702b"></a><!-- doxytag: member="XMLPlatformUtils::fgTransService" ref="bb0ad83db922cbf891a70319b2e6702b" args="" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classXMLTransService.html">XMLTransService</a>* <a class="el" href="classXMLPlatformUtils.html#bb0ad83db922cbf891a70319b2e6702b">XMLPlatformUtils::fgTransService</a><code> [static]</code>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
The transcoding service. 
<p>
This is provided by the per platform driver, so each platform can choose what implemenation it wants to use. When the platform independent initialization code needs to get a transcoding service object, it will call <code>makeTransService()</code> to ask the per-platform code to create one. Only one transcoding service object is reqeusted per-process, so it is shared and synchronized among parser instances within that process. 
</div>
</div><p>
<a class="anchor" name="ac6484e7073d5fb515ea791ee873b5bd"></a><!-- doxytag: member="XMLPlatformUtils::fgUserPanicHandler" ref="ac6484e7073d5fb515ea791ee873b5bd" args="" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classPanicHandler.html">PanicHandler</a>* <a class="el" href="classXMLPlatformUtils.html#ac6484e7073d5fb515ea791ee873b5bd">XMLPlatformUtils::fgUserPanicHandler</a><code> [static]</code>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
The Panic Handler. 
<p>
This is the application provided panic handler. 
</div>
</div><p>
<a class="anchor" name="db96471b53887380718f80e54934925f"></a><!-- doxytag: member="XMLPlatformUtils::fgDefaultPanicHandler" ref="db96471b53887380718f80e54934925f" args="" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classPanicHandler.html">PanicHandler</a>* <a class="el" href="classXMLPlatformUtils.html#db96471b53887380718f80e54934925f">XMLPlatformUtils::fgDefaultPanicHandler</a><code> [static]</code>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
The Panic Handler. 
<p>
This is the default panic handler. 
</div>
</div><p>
<a class="anchor" name="97eff0d9fff3567bea3acd3ca4d95252"></a><!-- doxytag: member="XMLPlatformUtils::fgMemoryManager" ref="97eff0d9fff3567bea3acd3ca4d95252" args="" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classMemoryManager.html">MemoryManager</a>* <a class="el" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252">XMLPlatformUtils::fgMemoryManager</a><code> [static]</code>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
The configurable memory manager. 
<p>
This is the pluggable memory manager. If it is not provided by an application, a default implementation is used. 
</div>
</div><p>
<a class="anchor" name="14ce4194a811184a9e1e17ca2adeee9d"></a><!-- doxytag: member="XMLPlatformUtils::fgFileMgr" ref="14ce4194a811184a9e1e17ca2adeee9d" args="" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classXMLFileMgr.html">XMLFileMgr</a>* <a class="el" href="classXMLPlatformUtils.html#14ce4194a811184a9e1e17ca2adeee9d">XMLPlatformUtils::fgFileMgr</a><code> [static]</code>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>

</div>
</div><p>
<a class="anchor" name="28f0c7e21b0ccf29bb38c90a544ebc8f"></a><!-- doxytag: member="XMLPlatformUtils::fgMutexMgr" ref="28f0c7e21b0ccf29bb38c90a544ebc8f" args="" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classXMLMutexMgr.html">XMLMutexMgr</a>* <a class="el" href="classXMLPlatformUtils.html#28f0c7e21b0ccf29bb38c90a544ebc8f">XMLPlatformUtils::fgMutexMgr</a><code> [static]</code>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>

</div>
</div><p>
<a class="anchor" name="aa3859ca77bec01d7c5c4da4632ab761"></a><!-- doxytag: member="XMLPlatformUtils::fgAtomicMutex" ref="aa3859ca77bec01d7c5c4da4632ab761" args="" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">XMLMutex* <a class="el" href="classXMLPlatformUtils.html#aa3859ca77bec01d7c5c4da4632ab761">XMLPlatformUtils::fgAtomicMutex</a><code> [static]</code>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Global mutex for fast or infrequent operations. 
<p>
Use this mutex only for fast (e.g., increment an integer, check flag, etc.) or infrequent (e.g., once-off initialization) operations. 
</div>
</div><p>
<a class="anchor" name="5d963ab2acfd08abcfcaab3a7e5819d2"></a><!-- doxytag: member="XMLPlatformUtils::fgXMLChBigEndian" ref="5d963ab2acfd08abcfcaab3a7e5819d2" args="" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">bool <a class="el" href="classXMLPlatformUtils.html#5d963ab2acfd08abcfcaab3a7e5819d2">XMLPlatformUtils::fgXMLChBigEndian</a><code> [static]</code>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>

</div>
</div><p>
<a class="anchor" name="41b2fc50c55ad21172a8e649d441aec0"></a><!-- doxytag: member="XMLPlatformUtils::fgSSE2ok" ref="41b2fc50c55ad21172a8e649d441aec0" args="" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">bool <a class="el" href="classXMLPlatformUtils.html#41b2fc50c55ad21172a8e649d441aec0">XMLPlatformUtils::fgSSE2ok</a><code> [static]</code>          </td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>

</div>
</div><p>
<hr>The documentation for this class was generated from the following file:<ul>
<li><a class="el" href="PlatformUtils_8hpp-source.html">PlatformUtils.hpp</a></ul>
</div>
<hr size="1"><address style="text-align: right;"><small>Generated on Fri Jan 29 15:30:49 2010 for Xerces-C++ by&nbsp;
<a href="http://www.doxygen.org/index.html">
<img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.5.6 </small></address>
</body>
</html>