00001 00002 00003 00004 00005 00006 00007 00008 00009 00010 00011 00012 00013 00014 00015 00016 00017 00018 00019 00020 00021 00022 00023 00024 00025 00026 00027 00028 00029 00030 00031 00032 00033 00034 00035 00036 00037 00038 00039 00040 00041 00042 00043 00044 00045 00046 00047 00048 00049 00050 00051 00052 00053 00054 00055
00056
00057 00058 00059 00060 00061 00062 00063 00064 00065 00066 00067 00068 00069 00070 00071
00072
00073 #if !defined(STRINGPOOL_HPP)
00074 #define STRINGPOOL_HPP
00075
00076 #include <util/RefHashTableOf.hpp>
00077
00078
00079
00080
00081
00082
00083
00084
00085
00086
00087
00088
00089
00090
00091 class XMLStringPool
00092 {
00093 public :
00094
00095
00096
00097 XMLStringPool
00098 (
00099 const unsigned int modulus = 109
00100 );
00101 ~XMLStringPool();
00102
00103
00104
00105
00106
00107 unsigned int addOrFind(const XMLCh* const newString);
00108 bool exists(const XMLCh* const newString) const;
00109 void flushAll();
00110 unsigned int getId(const XMLCh* const toFind) const;
00111 const XMLCh* getValueForId(const unsigned int id) const;
00112
00113
00114 private :
00115
00116
00117
00118 class PoolElem
00119 {
00120 public :
00121 PoolElem(const XMLCh* const string, const unsigned int id);
00122 ~PoolElem();
00123
00124 const XMLCh* getKey() const;
00125 void reset(const XMLCh* const string, const unsigned int id);
00126
00127 unsigned int fId;
00128 XMLCh* fString;
00129 };
00130
00131
00132
00133
00134
00135 XMLStringPool(const XMLStringPool&);
00136 void operator=(const XMLStringPool&);
00137
00138
00139
00140
00141
00142 unsigned int addNewEntry(const XMLCh* const newString);
00143
00144
00145
00146
00147
00148
00149
00150
00151
00152
00153
00154
00155
00156
00157
00158
00159
00160
00161
00162
00163
00164
00165 PoolElem** fIdMap;
00166 RefHashTableOf<PoolElem>* fHashTable;
00167 unsigned int fMapCapacity;
00168 unsigned int fCurId;
00169 };
00170
00171 #endif