williamr@2
|
1 |
/*
|
williamr@4
|
2 |
* Copyright (c) 2002-2005 Nokia Corporation and/or its subsidiary(-ies).
|
williamr@2
|
3 |
* All rights reserved.
|
williamr@2
|
4 |
* This component and the accompanying materials are made available
|
williamr@4
|
5 |
* under the terms of "Eclipse Public License v1.0"
|
williamr@2
|
6 |
* which accompanies this distribution, and is available
|
williamr@4
|
7 |
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
|
williamr@2
|
8 |
*
|
williamr@2
|
9 |
* Initial Contributors:
|
williamr@2
|
10 |
* Nokia Corporation - initial contribution.
|
williamr@2
|
11 |
*
|
williamr@2
|
12 |
* Contributors:
|
williamr@2
|
13 |
*
|
williamr@4
|
14 |
* Description: Pointermap class declaration
|
williamr@2
|
15 |
*
|
williamr@2
|
16 |
*/
|
williamr@2
|
17 |
|
williamr@4
|
18 |
|
williamr@4
|
19 |
|
williamr@4
|
20 |
|
williamr@2
|
21 |
#ifndef POINTERMAP_H
|
williamr@2
|
22 |
#define POINTERMAP_H
|
williamr@2
|
23 |
|
williamr@2
|
24 |
// INCLUDES
|
williamr@2
|
25 |
#include <e32std.h>
|
williamr@2
|
26 |
|
williamr@2
|
27 |
// CLASS DECLARATION
|
williamr@2
|
28 |
template <typename K, typename V>
|
williamr@2
|
29 |
class RSenPointerMap
|
williamr@2
|
30 |
{
|
williamr@2
|
31 |
public: // Constructors and destructor
|
williamr@2
|
32 |
|
williamr@2
|
33 |
RSenPointerMap(TBool aTakeOwnershipKey, TBool aTakeOwnershipValue)
|
williamr@2
|
34 |
:
|
williamr@2
|
35 |
iTakeOwnershipKey(aTakeOwnershipKey),
|
williamr@2
|
36 |
iTakeOwnershipValue(aTakeOwnershipValue)
|
williamr@2
|
37 |
{}
|
williamr@2
|
38 |
|
williamr@2
|
39 |
~RSenPointerMap()
|
williamr@2
|
40 |
{
|
williamr@2
|
41 |
Reset();
|
williamr@2
|
42 |
}
|
williamr@2
|
43 |
|
williamr@2
|
44 |
// New functions
|
williamr@2
|
45 |
|
williamr@2
|
46 |
TInt Append(const K* aKey, const V* aValue)
|
williamr@2
|
47 |
{
|
williamr@2
|
48 |
TInt err = iKeys.Append(aKey);
|
williamr@2
|
49 |
if (err == KErrNone)
|
williamr@2
|
50 |
{
|
williamr@2
|
51 |
err = iValues.Append(aValue);
|
williamr@2
|
52 |
if (err != KErrNone)
|
williamr@2
|
53 |
{
|
williamr@2
|
54 |
// last element of iKeys should be removed
|
williamr@2
|
55 |
TInt lastElementIndex = iKeys.Count() - 1;
|
williamr@2
|
56 |
iKeys.Remove(lastElementIndex);
|
williamr@2
|
57 |
}
|
williamr@2
|
58 |
}
|
williamr@2
|
59 |
return err;
|
williamr@2
|
60 |
}
|
williamr@2
|
61 |
|
williamr@2
|
62 |
TInt Find(const K& aKey) const
|
williamr@2
|
63 |
{
|
williamr@4
|
64 |
TInt index( KErrNotFound );
|
williamr@4
|
65 |
for (TInt i = 0; i < iKeys.Count(); i++)
|
williamr@2
|
66 |
{
|
williamr@2
|
67 |
if (*iKeys[i] == aKey)
|
williamr@2
|
68 |
{
|
williamr@2
|
69 |
index = i;
|
williamr@2
|
70 |
break;
|
williamr@2
|
71 |
}
|
williamr@2
|
72 |
}
|
williamr@2
|
73 |
return index;
|
williamr@2
|
74 |
}
|
williamr@2
|
75 |
|
williamr@4
|
76 |
TInt FindReverse(const K& aKey) const
|
williamr@4
|
77 |
{
|
williamr@4
|
78 |
TInt index( KErrNotFound );
|
williamr@4
|
79 |
TInt count( iKeys.Count() );
|
williamr@4
|
80 |
for (TInt i = count-1; i >=0 ; i--)
|
williamr@4
|
81 |
{
|
williamr@4
|
82 |
if (*iKeys[i] == aKey)
|
williamr@4
|
83 |
{
|
williamr@4
|
84 |
index = i;
|
williamr@4
|
85 |
break;
|
williamr@4
|
86 |
}
|
williamr@4
|
87 |
}
|
williamr@4
|
88 |
return index;
|
williamr@4
|
89 |
}
|
williamr@4
|
90 |
|
williamr@4
|
91 |
|
williamr@4
|
92 |
TInt RemoveAt( TInt aIndex )
|
williamr@4
|
93 |
{
|
williamr@4
|
94 |
K* key = KeyAt( aIndex );
|
williamr@4
|
95 |
return RemoveByKey( *key );
|
williamr@4
|
96 |
}
|
williamr@4
|
97 |
|
williamr@2
|
98 |
// @return the index of removed key-value pair, or
|
williamr@2
|
99 |
// KErrNotFound, if such key was not found
|
williamr@2
|
100 |
TInt RemoveByKey(const K& aKey)
|
williamr@2
|
101 |
{
|
williamr@2
|
102 |
TInt index = Find(aKey);
|
williamr@2
|
103 |
if (index != KErrNotFound)
|
williamr@2
|
104 |
{
|
williamr@2
|
105 |
if(iTakeOwnershipKey)
|
williamr@2
|
106 |
{
|
williamr@2
|
107 |
K* key = KeyAt(index);
|
williamr@2
|
108 |
delete key;
|
williamr@2
|
109 |
}
|
williamr@2
|
110 |
if(iTakeOwnershipValue)
|
williamr@2
|
111 |
{
|
williamr@2
|
112 |
V* value = iValues[index];
|
williamr@2
|
113 |
delete value;
|
williamr@2
|
114 |
}
|
williamr@2
|
115 |
iKeys.Remove(index);
|
williamr@2
|
116 |
iValues.Remove(index);
|
williamr@2
|
117 |
}
|
williamr@2
|
118 |
return index;
|
williamr@2
|
119 |
}
|
williamr@2
|
120 |
|
williamr@2
|
121 |
// @return the index of removed key-value pair, or
|
williamr@2
|
122 |
// KErrNotFound, if such key was not found
|
williamr@2
|
123 |
TInt Remove(const V& aValue)
|
williamr@2
|
124 |
{
|
williamr@2
|
125 |
TInt index = FindValue(aValue);
|
williamr@2
|
126 |
if (index != KErrNotFound)
|
williamr@2
|
127 |
{
|
williamr@2
|
128 |
if (iTakeOwnershipValue)
|
williamr@2
|
129 |
{
|
williamr@2
|
130 |
V* value = iValues[index];
|
williamr@2
|
131 |
delete value;
|
williamr@2
|
132 |
}
|
williamr@2
|
133 |
if (iTakeOwnershipKey)
|
williamr@2
|
134 |
{
|
williamr@2
|
135 |
K* key = iKeys[index];
|
williamr@2
|
136 |
delete key;
|
williamr@2
|
137 |
}
|
williamr@2
|
138 |
iValues.Remove(index);
|
williamr@2
|
139 |
iKeys.Remove(index);
|
williamr@2
|
140 |
}
|
williamr@2
|
141 |
return index;
|
williamr@2
|
142 |
}
|
williamr@2
|
143 |
|
williamr@2
|
144 |
TInt FindValue(const V& aValue) const
|
williamr@2
|
145 |
{
|
williamr@2
|
146 |
TInt index = KErrNotFound;
|
williamr@4
|
147 |
for (TInt i = 0; i < iValues.Count(); i++)
|
williamr@2
|
148 |
{
|
williamr@2
|
149 |
if ((iValues[i]) && (*iValues[i] == aValue))
|
williamr@2
|
150 |
{
|
williamr@2
|
151 |
index = i;
|
williamr@2
|
152 |
break;
|
williamr@2
|
153 |
}
|
williamr@2
|
154 |
}
|
williamr@2
|
155 |
return index;
|
williamr@2
|
156 |
}
|
williamr@2
|
157 |
|
williamr@2
|
158 |
|
williamr@2
|
159 |
// Note: deletes the current value of this key
|
williamr@2
|
160 |
TInt UpdateValue(const K* aKey, const V* aValue)
|
williamr@2
|
161 |
{
|
williamr@2
|
162 |
TInt index=Find(*aKey);
|
williamr@2
|
163 |
if (index==KErrNotFound)
|
williamr@2
|
164 |
{
|
williamr@2
|
165 |
return Append(aKey, aValue);
|
williamr@2
|
166 |
}
|
williamr@2
|
167 |
|
williamr@2
|
168 |
V* bValue=iValues[index];
|
williamr@2
|
169 |
if (iTakeOwnershipValue)
|
williamr@2
|
170 |
{
|
williamr@2
|
171 |
// Since OWNED value is going to be replaced with aValue,
|
williamr@2
|
172 |
// destroy old value instance first:
|
williamr@2
|
173 |
delete bValue;
|
williamr@2
|
174 |
}
|
williamr@2
|
175 |
|
williamr@2
|
176 |
iValues[index]=(V*)aValue;
|
williamr@2
|
177 |
return KErrNone;
|
williamr@2
|
178 |
}
|
williamr@2
|
179 |
|
williamr@2
|
180 |
|
williamr@2
|
181 |
K* KeyAt(TInt aIndex)
|
williamr@2
|
182 |
{
|
williamr@2
|
183 |
return iKeys[aIndex];
|
williamr@2
|
184 |
}
|
williamr@2
|
185 |
|
williamr@2
|
186 |
const V* ValueAt(TInt aIndex) const
|
williamr@2
|
187 |
{
|
williamr@2
|
188 |
return iValues[aIndex];
|
williamr@2
|
189 |
}
|
williamr@2
|
190 |
|
williamr@2
|
191 |
TInt Count() const
|
williamr@2
|
192 |
{
|
williamr@2
|
193 |
return iKeys.Count();
|
williamr@2
|
194 |
}
|
williamr@2
|
195 |
|
williamr@2
|
196 |
void Reset()
|
williamr@2
|
197 |
{
|
williamr@2
|
198 |
if ( iTakeOwnershipKey )
|
williamr@2
|
199 |
{
|
williamr@2
|
200 |
iKeys.ResetAndDestroy();
|
williamr@2
|
201 |
}
|
williamr@2
|
202 |
else
|
williamr@2
|
203 |
{
|
williamr@2
|
204 |
iKeys.Reset();
|
williamr@2
|
205 |
}
|
williamr@2
|
206 |
|
williamr@2
|
207 |
if ( iTakeOwnershipValue )
|
williamr@2
|
208 |
{
|
williamr@2
|
209 |
iValues.ResetAndDestroy();
|
williamr@2
|
210 |
}
|
williamr@2
|
211 |
else
|
williamr@2
|
212 |
{
|
williamr@2
|
213 |
iValues.Reset();
|
williamr@2
|
214 |
}
|
williamr@2
|
215 |
}
|
williamr@2
|
216 |
|
williamr@2
|
217 |
TInt Insert(const K* aKey, const V* aValue)
|
williamr@2
|
218 |
{
|
williamr@2
|
219 |
TInt count=iKeys.Count();
|
williamr@2
|
220 |
TInt err=KErrNone;
|
williamr@2
|
221 |
TBool inserted=EFalse;
|
williamr@2
|
222 |
|
williamr@2
|
223 |
for(TInt i=0; i<count; i++)
|
williamr@2
|
224 |
{
|
williamr@2
|
225 |
if(*iKeys[i] >= *aKey)
|
williamr@2
|
226 |
{
|
williamr@2
|
227 |
err = iKeys.Insert(aKey, i);
|
williamr@2
|
228 |
if (err == KErrNone)
|
williamr@2
|
229 |
{
|
williamr@2
|
230 |
err = iValues.Insert(aValue, i);
|
williamr@2
|
231 |
if (err != KErrNone)
|
williamr@2
|
232 |
{
|
williamr@2
|
233 |
// inserted element of iKeys should be removed
|
williamr@2
|
234 |
iKeys.Remove(i);
|
williamr@2
|
235 |
}
|
williamr@2
|
236 |
else
|
williamr@2
|
237 |
{
|
williamr@2
|
238 |
inserted=ETrue;
|
williamr@2
|
239 |
}
|
williamr@2
|
240 |
}
|
williamr@2
|
241 |
break;
|
williamr@2
|
242 |
}
|
williamr@2
|
243 |
}
|
williamr@2
|
244 |
|
williamr@2
|
245 |
if(!inserted)
|
williamr@2
|
246 |
{
|
williamr@2
|
247 |
err = iKeys.Append(aKey);
|
williamr@2
|
248 |
if (err == KErrNone)
|
williamr@2
|
249 |
{
|
williamr@2
|
250 |
err = iValues.Append(aValue);
|
williamr@2
|
251 |
if (err != KErrNone)
|
williamr@2
|
252 |
{
|
williamr@2
|
253 |
// last element of iKeys should be removed
|
williamr@2
|
254 |
TInt lastElementIndex = iKeys.Count() - 1;
|
williamr@2
|
255 |
iKeys.Remove(lastElementIndex);
|
williamr@2
|
256 |
}
|
williamr@2
|
257 |
}
|
williamr@2
|
258 |
}
|
williamr@2
|
259 |
return err;
|
williamr@2
|
260 |
}
|
williamr@2
|
261 |
|
williamr@2
|
262 |
private: // Data
|
williamr@2
|
263 |
TBool iTakeOwnershipKey;
|
williamr@2
|
264 |
TBool iTakeOwnershipValue;
|
williamr@2
|
265 |
RPointerArray<K> iKeys;
|
williamr@2
|
266 |
RPointerArray<V> iValues;
|
williamr@2
|
267 |
};
|
williamr@2
|
268 |
|
williamr@2
|
269 |
#endif // POINTERMAP_H
|
williamr@2
|
270 |
|
williamr@2
|
271 |
// End of File
|
williamr@2
|
272 |
|