<!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++: Hash2KeysSetOf.hpp Source File</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 Page</span></a></li> <li><a href="pages.html"><span>Related Pages</span></a></li> <li><a href="classes.html"><span>Classes</span></a></li> <li class="current"><a href="files.html"><span>Files</span></a></li> </ul> </div> <h1>Hash2KeysSetOf.hpp</h1><a href="Hash2KeysSetOf_8hpp.html">Go to the documentation of this file.</a><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 <span class="comment">/*</span> <a name="l00002"></a>00002 <span class="comment"> * Licensed to the Apache Software Foundation (ASF) under one or more</span> <a name="l00003"></a>00003 <span class="comment"> * contributor license agreements. See the NOTICE file distributed with</span> <a name="l00004"></a>00004 <span class="comment"> * this work for additional information regarding copyright ownership.</span> <a name="l00005"></a>00005 <span class="comment"> * The ASF licenses this file to You under the Apache License, Version 2.0</span> <a name="l00006"></a>00006 <span class="comment"> * (the "License"); you may not use this file except in compliance with</span> <a name="l00007"></a>00007 <span class="comment"> * the License. You may obtain a copy of the License at</span> <a name="l00008"></a>00008 <span class="comment"> *</span> <a name="l00009"></a>00009 <span class="comment"> * http://www.apache.org/licenses/LICENSE-2.0</span> <a name="l00010"></a>00010 <span class="comment"> *</span> <a name="l00011"></a>00011 <span class="comment"> * Unless required by applicable law or agreed to in writing, software</span> <a name="l00012"></a>00012 <span class="comment"> * distributed under the License is distributed on an "AS IS" BASIS,</span> <a name="l00013"></a>00013 <span class="comment"> * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.</span> <a name="l00014"></a>00014 <span class="comment"> * See the License for the specific language governing permissions and</span> <a name="l00015"></a>00015 <span class="comment"> * limitations under the License.</span> <a name="l00016"></a>00016 <span class="comment"> */</span> <a name="l00017"></a>00017 <a name="l00018"></a>00018 <span class="comment">/*</span> <a name="l00019"></a>00019 <span class="comment"> * $Id: Hash2KeysSetOf.hpp 883368 2009-11-23 15:28:19Z amassari $</span> <a name="l00020"></a>00020 <span class="comment"> */</span> <a name="l00021"></a>00021 <a name="l00022"></a>00022 <span class="preprocessor">#if !defined(XERCESC_INCLUDE_GUARD_HASH2KEYSSETOF_HPP)</span> <a name="l00023"></a><a class="code" href="Hash2KeysSetOf_8hpp.html#c4af8a8088534b6fc9371ceb10340b2d">00023</a> <span class="preprocessor"></span><span class="preprocessor">#define XERCESC_INCLUDE_GUARD_HASH2KEYSSETOF_HPP</span> <a name="l00024"></a>00024 <span class="preprocessor"></span> <a name="l00025"></a>00025 <a name="l00026"></a>00026 <span class="preprocessor">#include <xercesc/util/Hashers.hpp></span> <a name="l00027"></a>00027 <span class="preprocessor">#include <<a class="code" href="IllegalArgumentException_8hpp.html">xercesc/util/IllegalArgumentException.hpp</a>></span> <a name="l00028"></a>00028 <span class="preprocessor">#include <<a class="code" href="NoSuchElementException_8hpp.html">xercesc/util/NoSuchElementException.hpp</a>></span> <a name="l00029"></a>00029 <span class="preprocessor">#include <<a class="code" href="RuntimeException_8hpp.html">xercesc/util/RuntimeException.hpp</a>></span> <a name="l00030"></a>00030 <span class="preprocessor">#include <<a class="code" href="PlatformUtils_8hpp.html">xercesc/util/PlatformUtils.hpp</a>></span> <a name="l00031"></a>00031 <a name="l00032"></a>00032 <a class="code" href="XercesDefs_8hpp.html#43d74fa53d868d978f3e97cbb78b194d">XERCES_CPP_NAMESPACE_BEGIN</a> <a name="l00033"></a>00033 <a name="l00034"></a>00034 <span class="comment">// This hash table is similar to Hash2KeysSetOf with an additional integer as key2</span> <a name="l00035"></a>00035 <a name="l00036"></a>00036 <span class="comment">// Forward declare the enumerator so it can be our friend.</span> <a name="l00037"></a>00037 <span class="comment">//</span> <a name="l00038"></a>00038 <span class="keyword">template</span> <<span class="keyword">class</span> THasher> <a name="l00039"></a>00039 <span class="keyword">class </span><a class="code" href="classHash2KeysSetOfEnumerator.html">Hash2KeysSetOfEnumerator</a>; <a name="l00040"></a>00040 <a name="l00041"></a>00041 <span class="comment">//</span> <a name="l00042"></a>00042 <span class="comment">// This should really be a nested class, but some of the compilers we</span> <a name="l00043"></a>00043 <span class="comment">// have to support cannot deal with that!</span> <a name="l00044"></a>00044 <span class="comment">//</span> <a name="l00045"></a><a class="code" href="structHash2KeysSetBucketElem.html">00045</a> <span class="keyword">struct </span><a class="code" href="structHash2KeysSetBucketElem.html">Hash2KeysSetBucketElem</a> <a name="l00046"></a>00046 { <a name="l00047"></a><a class="code" href="structHash2KeysSetBucketElem.html#8d08b09bf0d098f4fe2034c5bd997dd7">00047</a> <a class="code" href="structHash2KeysSetBucketElem.html">Hash2KeysSetBucketElem</a>* <a class="code" href="structHash2KeysSetBucketElem.html#8d08b09bf0d098f4fe2034c5bd997dd7">fNext</a>; <a name="l00048"></a><a class="code" href="structHash2KeysSetBucketElem.html#6dd5f631adc5fff45ef527e28992464c">00048</a> <span class="keyword">const</span> <span class="keywordtype">void</span>* <a class="code" href="structHash2KeysSetBucketElem.html#6dd5f631adc5fff45ef527e28992464c">fKey1</a>; <a name="l00049"></a><a class="code" href="structHash2KeysSetBucketElem.html#546279d40c5465afe2477f56fda31f3b">00049</a> <span class="keywordtype">int</span> <a class="code" href="structHash2KeysSetBucketElem.html#546279d40c5465afe2477f56fda31f3b">fKey2</a>; <a name="l00050"></a>00050 }; <a name="l00051"></a>00051 <a name="l00052"></a>00052 <a name="l00053"></a>00053 <span class="keyword">template</span> <<span class="keyword">class</span> THasher> <a name="l00054"></a><a class="code" href="classHash2KeysSetOf.html">00054</a> <span class="keyword">class </span><a class="code" href="classHash2KeysSetOf.html">Hash2KeysSetOf</a> : <span class="keyword">public</span> <a class="code" href="classXMemory.html" title="This class makes it possible to override the C++ memory management by adding new/delete...">XMemory</a> <a name="l00055"></a>00055 { <a name="l00056"></a>00056 <span class="keyword">public</span>: <a name="l00057"></a>00057 <span class="comment">// -----------------------------------------------------------------------</span> <a name="l00058"></a>00058 <span class="comment">// Constructors and Destructor</span> <a name="l00059"></a>00059 <span class="comment">// -----------------------------------------------------------------------</span> <a name="l00060"></a>00060 <a name="l00061"></a>00061 <a class="code" href="classHash2KeysSetOf.html#cc03e3deb61a1ca7079138c8e03854b1">Hash2KeysSetOf</a>( <a name="l00062"></a>00062 <span class="keyword">const</span> <a class="code" href="Xerces__autoconf__config_8borland_8hpp.html#c0f7e36996cd03eb43bcee10321f77cd">XMLSize_t</a> modulus, <a name="l00063"></a>00063 <a class="code" href="classMemoryManager.html" title="Configurable memory manager.">MemoryManager</a>* <span class="keyword">const</span> manager = <a class="code" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252" title="The configurable memory manager.">XMLPlatformUtils::fgMemoryManager</a>); <a name="l00064"></a>00064 <a name="l00065"></a>00065 <a class="code" href="classHash2KeysSetOf.html#cc03e3deb61a1ca7079138c8e03854b1">Hash2KeysSetOf</a>( <a name="l00066"></a>00066 <span class="keyword">const</span> <a class="code" href="Xerces__autoconf__config_8borland_8hpp.html#c0f7e36996cd03eb43bcee10321f77cd">XMLSize_t</a> modulus, <a name="l00067"></a>00067 <span class="keyword">const</span> THasher& hasher, <a name="l00068"></a>00068 <a class="code" href="classMemoryManager.html" title="Configurable memory manager.">MemoryManager</a>* <span class="keyword">const</span> manager = <a class="code" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252" title="The configurable memory manager.">XMLPlatformUtils::fgMemoryManager</a>); <a name="l00069"></a>00069 <a name="l00070"></a>00070 <a class="code" href="classHash2KeysSetOf.html#d8f750e70e521e6e2329a9cb8f3434f5">~Hash2KeysSetOf</a>(); <a name="l00071"></a>00071 <a name="l00072"></a>00072 <a name="l00073"></a>00073 <span class="comment">// -----------------------------------------------------------------------</span> <a name="l00074"></a>00074 <span class="comment">// Element management</span> <a name="l00075"></a>00075 <span class="comment">// -----------------------------------------------------------------------</span> <a name="l00076"></a>00076 <span class="keywordtype">bool</span> <a class="code" href="classHash2KeysSetOf.html#f661dcfb5d2377df58f508a85585716b">isEmpty</a>() <span class="keyword">const</span>; <a name="l00077"></a>00077 <span class="keywordtype">bool</span> <a class="code" href="classHash2KeysSetOf.html#e6d965a91f8ab065d2f6f9dd483e4bfb">containsKey</a>(<span class="keyword">const</span> <span class="keywordtype">void</span>* <span class="keyword">const</span> key1, <span class="keyword">const</span> <span class="keywordtype">int</span> key2) <span class="keyword">const</span>; <a name="l00078"></a>00078 <span class="keywordtype">void</span> <a class="code" href="classHash2KeysSetOf.html#b5276bad50338c378af5e1f7047bd5a5">removeKey</a>(<span class="keyword">const</span> <span class="keywordtype">void</span>* <span class="keyword">const</span> key1, <span class="keyword">const</span> <span class="keywordtype">int</span> key2); <a name="l00079"></a>00079 <span class="keywordtype">void</span> <a class="code" href="classHash2KeysSetOf.html#b5276bad50338c378af5e1f7047bd5a5">removeKey</a>(<span class="keyword">const</span> <span class="keywordtype">void</span>* <span class="keyword">const</span> key1); <a name="l00080"></a>00080 <span class="keywordtype">void</span> <a class="code" href="classHash2KeysSetOf.html#19e8e84264037a73f575ef4e34376fea">removeAll</a>(); <a name="l00081"></a>00081 <a name="l00082"></a>00082 <span class="comment">// -----------------------------------------------------------------------</span> <a name="l00083"></a>00083 <span class="comment">// Getters</span> <a name="l00084"></a>00084 <span class="comment">// -----------------------------------------------------------------------</span> <a name="l00085"></a>00085 <a class="code" href="classMemoryManager.html" title="Configurable memory manager.">MemoryManager</a>* <a class="code" href="classHash2KeysSetOf.html#fc8cfb0bb20fc2e6f2a9a5527d05ec66">getMemoryManager</a>() <span class="keyword">const</span>; <a name="l00086"></a>00086 <a class="code" href="Xerces__autoconf__config_8borland_8hpp.html#c0f7e36996cd03eb43bcee10321f77cd">XMLSize_t</a> <a class="code" href="classHash2KeysSetOf.html#ade6f3476d4b4afceed14896b5e094f0">getHashModulus</a>() <span class="keyword">const</span>; <a name="l00087"></a>00087 <a name="l00088"></a>00088 <span class="comment">// -----------------------------------------------------------------------</span> <a name="l00089"></a>00089 <span class="comment">// Putters</span> <a name="l00090"></a>00090 <span class="comment">// -----------------------------------------------------------------------</span> <a name="l00091"></a>00091 <span class="keywordtype">void</span> <a class="code" href="classHash2KeysSetOf.html#6e6943a1f6986f2edf5aa99860b7cfe5">put</a>(<span class="keyword">const</span> <span class="keywordtype">void</span>* key1, <span class="keywordtype">int</span> key2); <a name="l00092"></a>00092 <span class="keywordtype">bool</span> <a class="code" href="classHash2KeysSetOf.html#7ef8daa6bbaa760b27572b008aa6fc57">putIfNotPresent</a>(<span class="keyword">const</span> <span class="keywordtype">void</span>* key1, <span class="keywordtype">int</span> key2); <a name="l00093"></a>00093 <a name="l00094"></a>00094 <span class="keyword">private</span> : <a name="l00095"></a>00095 <span class="comment">// -----------------------------------------------------------------------</span> <a name="l00096"></a>00096 <span class="comment">// Declare our friends</span> <a name="l00097"></a>00097 <span class="comment">// -----------------------------------------------------------------------</span> <a name="l00098"></a><a class="code" href="classHash2KeysSetOf.html#69fd7a56b10f9d2c4e9f750a7540bcf1">00098</a> <span class="keyword">friend</span> <span class="keyword">class </span><a class="code" href="classHash2KeysSetOfEnumerator.html">Hash2KeysSetOfEnumerator</a><THasher>; <a name="l00099"></a>00099 <a name="l00100"></a>00100 <a name="l00101"></a>00101 <span class="keyword">private</span>: <a name="l00102"></a>00102 <span class="comment">// -----------------------------------------------------------------------</span> <a name="l00103"></a>00103 <span class="comment">// Unimplemented constructors and operators</span> <a name="l00104"></a>00104 <span class="comment">// -----------------------------------------------------------------------</span> <a name="l00105"></a>00105 <a class="code" href="classHash2KeysSetOf.html#cc03e3deb61a1ca7079138c8e03854b1">Hash2KeysSetOf</a>(<span class="keyword">const</span> <a class="code" href="classHash2KeysSetOf.html">Hash2KeysSetOf<THasher></a>&); <a name="l00106"></a>00106 <a class="code" href="classHash2KeysSetOf.html">Hash2KeysSetOf<THasher></a>& operator=(<span class="keyword">const</span> <a class="code" href="classHash2KeysSetOf.html">Hash2KeysSetOf<THasher></a>&); <a name="l00107"></a>00107 <a name="l00108"></a>00108 <span class="comment">// -----------------------------------------------------------------------</span> <a name="l00109"></a>00109 <span class="comment">// Private methods</span> <a name="l00110"></a>00110 <span class="comment">// -----------------------------------------------------------------------</span> <a name="l00111"></a>00111 <a class="code" href="structHash2KeysSetBucketElem.html">Hash2KeysSetBucketElem</a>* findBucketElem(<span class="keyword">const</span> <span class="keywordtype">void</span>* <span class="keyword">const</span> key1, <span class="keyword">const</span> <span class="keywordtype">int</span> key2, <a class="code" href="Xerces__autoconf__config_8borland_8hpp.html#c0f7e36996cd03eb43bcee10321f77cd">XMLSize_t</a>& hashVal); <a name="l00112"></a>00112 <span class="keyword">const</span> <a class="code" href="structHash2KeysSetBucketElem.html">Hash2KeysSetBucketElem</a>* findBucketElem(<span class="keyword">const</span> <span class="keywordtype">void</span>* <span class="keyword">const</span> key1, <span class="keyword">const</span> <span class="keywordtype">int</span> key2, <a class="code" href="Xerces__autoconf__config_8borland_8hpp.html#c0f7e36996cd03eb43bcee10321f77cd">XMLSize_t</a>& hashVal) <span class="keyword">const</span>; <a name="l00113"></a>00113 <span class="keywordtype">void</span> initialize(<span class="keyword">const</span> <a class="code" href="Xerces__autoconf__config_8borland_8hpp.html#c0f7e36996cd03eb43bcee10321f77cd">XMLSize_t</a> modulus); <a name="l00114"></a>00114 <span class="keywordtype">void</span> rehash(); <a name="l00115"></a>00115 <a name="l00116"></a>00116 <a name="l00117"></a>00117 <span class="comment">// -----------------------------------------------------------------------</span> <a name="l00118"></a>00118 <span class="comment">// Data members</span> <a name="l00119"></a>00119 <span class="comment">//</span> <a name="l00120"></a>00120 <span class="comment">// fBucketList</span> <a name="l00121"></a>00121 <span class="comment">// This is the array that contains the heads of all of the list</span> <a name="l00122"></a>00122 <span class="comment">// buckets, one for each possible hash value.</span> <a name="l00123"></a>00123 <span class="comment">//</span> <a name="l00124"></a>00124 <span class="comment">// fHashModulus</span> <a name="l00125"></a>00125 <span class="comment">// The modulus used for this hash table, to hash the keys. This is</span> <a name="l00126"></a>00126 <span class="comment">// also the number of elements in the bucket list.</span> <a name="l00127"></a>00127 <span class="comment">//</span> <a name="l00128"></a>00128 <span class="comment">// fCount</span> <a name="l00129"></a>00129 <span class="comment">// The number of elements currently in the map</span> <a name="l00130"></a>00130 <span class="comment">//</span> <a name="l00131"></a>00131 <span class="comment">// fHash</span> <a name="l00132"></a>00132 <span class="comment">// The hasher for the key1 data type.</span> <a name="l00133"></a>00133 <span class="comment">// -----------------------------------------------------------------------</span> <a name="l00134"></a>00134 <a class="code" href="classMemoryManager.html" title="Configurable memory manager.">MemoryManager</a>* fMemoryManager; <a name="l00135"></a>00135 <a class="code" href="structHash2KeysSetBucketElem.html">Hash2KeysSetBucketElem</a>** fBucketList; <a name="l00136"></a>00136 <a class="code" href="Xerces__autoconf__config_8borland_8hpp.html#c0f7e36996cd03eb43bcee10321f77cd">XMLSize_t</a> fHashModulus; <a name="l00137"></a>00137 <a class="code" href="Xerces__autoconf__config_8borland_8hpp.html#c0f7e36996cd03eb43bcee10321f77cd">XMLSize_t</a> fCount; <a name="l00138"></a>00138 <a class="code" href="structHash2KeysSetBucketElem.html">Hash2KeysSetBucketElem</a>* fAvailable; <a name="l00139"></a>00139 THasher fHasher; <a name="l00140"></a>00140 }; <a name="l00141"></a>00141 <a name="l00142"></a>00142 <a name="l00143"></a>00143 <a name="l00144"></a>00144 <span class="comment">//</span> <a name="l00145"></a>00145 <span class="comment">// An enumerator for a value array. It derives from the basic enumerator</span> <a name="l00146"></a>00146 <span class="comment">// class, so that value vectors can be generically enumerated.</span> <a name="l00147"></a>00147 <span class="comment">//</span> <a name="l00148"></a>00148 <span class="keyword">template</span> <<span class="keyword">class</span> THasher> <a name="l00149"></a><a class="code" href="classHash2KeysSetOfEnumerator.html">00149</a> <span class="keyword">class </span><a class="code" href="classHash2KeysSetOfEnumerator.html">Hash2KeysSetOfEnumerator</a> : <span class="keyword">public</span> <a class="code" href="classXMemory.html" title="This class makes it possible to override the C++ memory management by adding new/delete...">XMemory</a> <a name="l00150"></a>00150 { <a name="l00151"></a>00151 <span class="keyword">public</span> : <a name="l00152"></a>00152 <span class="comment">// -----------------------------------------------------------------------</span> <a name="l00153"></a>00153 <span class="comment">// Constructors and Destructor</span> <a name="l00154"></a>00154 <span class="comment">// -----------------------------------------------------------------------</span> <a name="l00155"></a>00155 <a class="code" href="classHash2KeysSetOfEnumerator.html#ad5261aa63301ecd26e86f376d1b02a6">Hash2KeysSetOfEnumerator</a>(<a class="code" href="classHash2KeysSetOf.html">Hash2KeysSetOf<THasher></a>* <span class="keyword">const</span> toEnum <a name="l00156"></a>00156 , <span class="keyword">const</span> <span class="keywordtype">bool</span> adopt = <span class="keyword">false</span> <a name="l00157"></a>00157 , <a class="code" href="classMemoryManager.html" title="Configurable memory manager.">MemoryManager</a>* <span class="keyword">const</span> manager = <a class="code" href="classXMLPlatformUtils.html#97eff0d9fff3567bea3acd3ca4d95252" title="The configurable memory manager.">XMLPlatformUtils::fgMemoryManager</a>); <a name="l00158"></a>00158 <span class="keyword">virtual</span> <a class="code" href="classHash2KeysSetOfEnumerator.html#4db566a9d0d2fff5427efa3214e99ada">~Hash2KeysSetOfEnumerator</a>(); <a name="l00159"></a>00159 <a name="l00160"></a>00160 <a name="l00161"></a>00161 <span class="comment">// -----------------------------------------------------------------------</span> <a name="l00162"></a>00162 <span class="comment">// Enum interface</span> <a name="l00163"></a>00163 <span class="comment">// -----------------------------------------------------------------------</span> <a name="l00164"></a>00164 <span class="keywordtype">bool</span> <a class="code" href="classHash2KeysSetOfEnumerator.html#d4eac9e4ed5b65b18526b582e95ecb2a">hasMoreElements</a>() <span class="keyword">const</span>; <a name="l00165"></a>00165 <span class="keywordtype">void</span> <a class="code" href="classHash2KeysSetOfEnumerator.html#fb79e84424d6c08d30c791e7e7767733">Reset</a>(); <a name="l00166"></a>00166 <a name="l00167"></a>00167 <span class="comment">// -----------------------------------------------------------------------</span> <a name="l00168"></a>00168 <span class="comment">// New interface</span> <a name="l00169"></a>00169 <span class="comment">// -----------------------------------------------------------------------</span> <a name="l00170"></a>00170 <span class="keywordtype">void</span> <a class="code" href="classHash2KeysSetOfEnumerator.html#38fd719b736cc3e2eabbb5e83687bf6c">nextElementKey</a>(<span class="keyword">const</span> <span class="keywordtype">void</span>*&, <span class="keywordtype">int</span>&); <a name="l00171"></a>00171 <span class="keywordtype">void</span> <a class="code" href="classHash2KeysSetOfEnumerator.html#dff18578b2f76a28f6a24719d1a1dc94">setPrimaryKey</a>(<span class="keyword">const</span> <span class="keywordtype">void</span>* key); <a name="l00172"></a>00172 <a name="l00173"></a>00173 <span class="keyword">private</span> : <a name="l00174"></a>00174 <span class="comment">// -----------------------------------------------------------------------</span> <a name="l00175"></a>00175 <span class="comment">// Unimplemented constructors and operators</span> <a name="l00176"></a>00176 <span class="comment">// -----------------------------------------------------------------------</span> <a name="l00177"></a>00177 <a class="code" href="classHash2KeysSetOfEnumerator.html#ad5261aa63301ecd26e86f376d1b02a6">Hash2KeysSetOfEnumerator</a>(<span class="keyword">const</span> <a class="code" href="classHash2KeysSetOfEnumerator.html">Hash2KeysSetOfEnumerator<THasher></a>&); <a name="l00178"></a>00178 <a class="code" href="classHash2KeysSetOfEnumerator.html">Hash2KeysSetOfEnumerator<THasher></a>& operator=(<span class="keyword">const</span> <a class="code" href="classHash2KeysSetOfEnumerator.html">Hash2KeysSetOfEnumerator<THasher></a>&); <a name="l00179"></a>00179 <a name="l00180"></a>00180 <span class="comment">// -----------------------------------------------------------------------</span> <a name="l00181"></a>00181 <span class="comment">// Private methods</span> <a name="l00182"></a>00182 <span class="comment">// -----------------------------------------------------------------------</span> <a name="l00183"></a>00183 <span class="keywordtype">void</span> findNext(); <a name="l00184"></a>00184 <a name="l00185"></a>00185 <a name="l00186"></a>00186 <span class="comment">// -----------------------------------------------------------------------</span> <a name="l00187"></a>00187 <span class="comment">// Data Members</span> <a name="l00188"></a>00188 <span class="comment">//</span> <a name="l00189"></a>00189 <span class="comment">// fAdopted</span> <a name="l00190"></a>00190 <span class="comment">// Indicates whether we have adopted the passed vector. If so then</span> <a name="l00191"></a>00191 <span class="comment">// we delete the vector when we are destroyed.</span> <a name="l00192"></a>00192 <span class="comment">//</span> <a name="l00193"></a>00193 <span class="comment">// fCurElem</span> <a name="l00194"></a>00194 <span class="comment">// This is the current bucket bucket element that we are on.</span> <a name="l00195"></a>00195 <span class="comment">//</span> <a name="l00196"></a>00196 <span class="comment">// fCurHash</span> <a name="l00197"></a>00197 <span class="comment">// The is the current hash buck that we are working on. Once we hit</span> <a name="l00198"></a>00198 <span class="comment">// the end of the bucket that fCurElem is in, then we have to start</span> <a name="l00199"></a>00199 <span class="comment">// working this one up to the next non-empty bucket.</span> <a name="l00200"></a>00200 <span class="comment">//</span> <a name="l00201"></a>00201 <span class="comment">// fToEnum</span> <a name="l00202"></a>00202 <span class="comment">// The value array being enumerated.</span> <a name="l00203"></a>00203 <span class="comment">//</span> <a name="l00204"></a>00204 <span class="comment">// fLockPrimaryKey</span> <a name="l00205"></a>00205 <span class="comment">// Indicates that we are requested to iterate over the secondary keys</span> <a name="l00206"></a>00206 <span class="comment">// associated with the given primary key</span> <a name="l00207"></a>00207 <span class="comment">//</span> <a name="l00208"></a>00208 <span class="comment">// -----------------------------------------------------------------------</span> <a name="l00209"></a>00209 <span class="keywordtype">bool</span> fAdopted; <a name="l00210"></a>00210 <a class="code" href="structHash2KeysSetBucketElem.html">Hash2KeysSetBucketElem</a>* fCurElem; <a name="l00211"></a>00211 <a class="code" href="Xerces__autoconf__config_8borland_8hpp.html#c0f7e36996cd03eb43bcee10321f77cd">XMLSize_t</a> fCurHash; <a name="l00212"></a>00212 <a class="code" href="classHash2KeysSetOf.html">Hash2KeysSetOf<THasher></a>* fToEnum; <a name="l00213"></a>00213 <a class="code" href="classMemoryManager.html" title="Configurable memory manager.">MemoryManager</a>* <span class="keyword">const</span> fMemoryManager; <a name="l00214"></a>00214 <span class="keyword">const</span> <span class="keywordtype">void</span>* fLockPrimaryKey; <a name="l00215"></a>00215 }; <a name="l00216"></a>00216 <a name="l00217"></a>00217 <a class="code" href="XercesDefs_8hpp.html#f03d5cb905763ef7a7bd22ab82718285">XERCES_CPP_NAMESPACE_END</a> <a name="l00218"></a>00218 <a name="l00219"></a>00219 <span class="preprocessor">#if !defined(XERCES_TMPLSINC)</span> <a name="l00220"></a>00220 <span class="preprocessor"></span><span class="preprocessor">#include <xercesc/util/Hash2KeysSetOf.c></span> <a name="l00221"></a>00221 <span class="preprocessor">#endif</span> <a name="l00222"></a>00222 <span class="preprocessor"></span> <a name="l00223"></a>00223 <span class="preprocessor">#endif</span> </pre></div></div> <hr size="1"><address style="text-align: right;"><small>Generated on Fri Jan 29 15:30:48 2010 for Xerces-C++ by <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>