Update contrib.
1 // Copyright (c) 1997-2009 Nokia Corporation and/or its subsidiary(-ies).
2 // All rights reserved.
3 // This component and the accompanying materials are made available
4 // under the terms of "Eclipse Public License v1.0"
5 // which accompanies this distribution, and is available
6 // at the URL "http://www.eclipse.org/legal/epl-v10.html".
8 // Initial Contributors:
9 // Nokia Corporation - initial contribution.
14 // Written by DavidW, October 1996
19 #if !defined(__BADESCA_H__)
22 #if !defined(__BAMDESCA_H__)
26 #if !defined(__E32BASE_H__)
31 class CDesC8Array : public CArrayFixBase, public MDesC8Array
32 /** An implementation base class for 8 bit descriptor arrays.
34 It provides some of the behaviour for 8 bit descriptor arrays. The class is
35 abstract and cannot be instantiated.
41 IMPORT_C CDesC8Array(TBufRep aRep,TInt aGranularity);
43 IMPORT_C ~CDesC8Array();
44 IMPORT_C void AppendL(const TDesC8& aPtr);
45 IMPORT_C void InsertL(TInt aPos,const TDesC8& aPtr);
46 IMPORT_C TInt InsertIsqL(const TDesC8& aPtr,TKeyCmpText aTextComparisonType=ECmpFolded);
47 IMPORT_C TInt InsertIsqAllowDuplicatesL(const TDesC8& aPtr,TKeyCmpText aTextComparisonType=ECmpFolded);
48 IMPORT_C void Sort(TKeyCmpText aTextComparisonType=ECmpFolded);
49 IMPORT_C TInt Find(const TDesC8& aPtr,TInt& aPos,TKeyCmpText aTextComparisonType=ECmpFolded) const;
50 IMPORT_C TInt FindIsq(const TDesC8& aPtr,TInt& aPos,TKeyCmpText aTextComparisonType=ECmpFolded) const;
51 IMPORT_C void Delete(TInt aPos);
52 IMPORT_C void Delete(TInt aIndex,TInt aCount);
53 IMPORT_C void Reset();
54 inline TPtrC8 operator[](TInt aIndex) const;
56 IMPORT_C TInt MdcaCount() const;
57 IMPORT_C TPtrC8 MdcaPoint(TInt aIndex) const;
60 inline TPtrC8 CDesC8Array::operator[](TInt aIndex) const
61 { return(MdcaPoint(aIndex)); }
64 class CDesC8ArrayFlat : public CDesC8Array
65 /** An array of 8 bit descriptors implemented using a flat buffer.
73 IMPORT_C CDesC8ArrayFlat(TInt aGranularity);
74 IMPORT_C ~CDesC8ArrayFlat();
78 class CDesC8ArraySeg : public CDesC8Array
79 /** An array of 8 bit descriptors implemented using a segmented buffer.
87 IMPORT_C CDesC8ArraySeg(TInt aGranularity);
88 IMPORT_C ~CDesC8ArraySeg();
92 class CDesC16Array : public CArrayFixBase, public MDesC16Array
93 /** An implementation base class for 16 bit descriptor arrays. It provides some
94 of the behaviour for 16 bit descriptor arrays.
96 The class is abstract and cannot be instantiated.
104 IMPORT_C CDesC16Array(TBufRep aRep,TInt aGranularity);
106 IMPORT_C ~CDesC16Array();
107 IMPORT_C void AppendL(const TDesC16& aPtr);
108 IMPORT_C void InsertL(TInt aPos,const TDesC16& aPtr);
109 IMPORT_C TInt InsertIsqL(const TDesC16& aPtr,TKeyCmpText aTextComparisonType=ECmpFolded);
110 IMPORT_C TInt InsertIsqAllowDuplicatesL(const TDesC16& aPtr,TKeyCmpText aTextComparisonType=ECmpFolded);
111 IMPORT_C void Sort(TKeyCmpText aTextComparisonType=ECmpFolded);
112 IMPORT_C TInt Find(const TDesC16& aPtr,TInt& aPos,TKeyCmpText aTextComparisonType=ECmpFolded) const;
113 IMPORT_C TInt FindIsq(const TDesC16& aPtr,TInt& aPos,TKeyCmpText aTextComparisonType=ECmpFolded) const;
114 IMPORT_C void Delete(TInt aPos);
115 IMPORT_C void Delete(TInt aIndex,TInt aCount);
116 IMPORT_C void Reset();
117 inline TPtrC16 operator[](TInt aIndex) const;
119 IMPORT_C TInt MdcaCount() const;
120 IMPORT_C TPtrC16 MdcaPoint(TInt aIndex) const;
125 inline TPtrC16 CDesC16Array::operator[](TInt aIndex) const
126 /** Returns a non-modifiable descriptor to represent the descriptor
127 element located at the specified index within the array.
129 @param aIndex The position of the descriptor element within the array.
130 The position is relative to zero; i.e. zero implies the first descriptor
131 element in the array. This value must be non-negative and less than the
132 number of descriptors currently within the array otherwise the operator
135 EArrayIndexOutOfRange
137 @return A 16 bit non-modifiable pointer descriptor. */
138 { return(MdcaPoint(aIndex)); }
141 class CDesC16ArrayFlat : public CDesC16Array
142 /** Array of 16 bit descriptors implemented using a flat buffer.
150 IMPORT_C CDesC16ArrayFlat(TInt aGranularity);
151 IMPORT_C ~CDesC16ArrayFlat();
155 class CDesC16ArraySeg : public CDesC16Array
156 /** An array of 16 bit descriptors implemented using a segmented buffer.
164 IMPORT_C CDesC16ArraySeg(TInt aGranularity);
165 IMPORT_C ~CDesC16ArraySeg();
169 class CPtrC8Array : public CArrayFixFlat<TPtrC8>, public MDesC8Array
170 /** Array of 8 bit non-modifiable pointer descriptors, TPtrC8, implemented using
179 IMPORT_C CPtrC8Array(TInt aGranularity);
180 IMPORT_C ~CPtrC8Array();
182 IMPORT_C void CopyL(const MDesC8Array& aArray);
183 inline void operator=(const MDesC8Array& aArray);
185 IMPORT_C TInt MdcaCount() const;
186 IMPORT_C TPtrC8 MdcaPoint(TInt aIndex) const;
190 class CPtrC16Array : public CArrayFixFlat<TPtrC16>, public MDesC16Array
191 /** An array of 16 bit non-modifiable pointer descriptors, TPtrC16, implemented
200 IMPORT_C CPtrC16Array(TInt aGranularity);
201 IMPORT_C ~CPtrC16Array();
203 IMPORT_C void CopyL(const MDesC16Array& aArray);
204 inline void operator=(const MDesC16Array& aArray);
206 IMPORT_C TInt MdcaCount() const;
207 IMPORT_C TPtrC16 MdcaPoint(TInt aIndex) const;
211 inline void CPtrC8Array::operator=(const MDesC8Array& aArray)
212 /** Copies a descriptor array into this array, deleting any pre-existing
215 The function constructs TPtrC8 elements for each descriptor element
216 in the specified descriptor array. This operator behaves in the
217 same ways as CPtrC8Array::CopyL().
219 @param aArrayA reference to any descriptor array which satisfies
220 the protocol defined by this mixin class. */
224 inline void CPtrC16Array::operator=(const MDesC16Array& aArray)
225 /** Copies a descriptor array into this array, deleting any pre-existing
228 The function constructs TPtrC16 elements for each descriptor element
229 in the specified descriptor array.This operator behaves in the
230 same ways as CPtrC16Array::CopyL().
232 @param aArray A reference to any descriptor array which satisfies
233 the protocol defined by this mixin class. */
236 // generic text array definitions
238 #if defined (_UNICODE)
239 /** Build independent implementation base class for descriptor arrays.
246 typedef CDesC16Array CDesCArray;
248 /** Build independent array of descriptors implemented using a flat buffer.
251 @see CDesC16ArrayFlat
255 typedef CDesC16ArrayFlat CDesCArrayFlat;
257 /** Build independent array of descriptors implemented using a segmented buffer.
264 typedef CDesC16ArraySeg CDesCArraySeg;
266 /** Build independent array of non-modifiable pointer descriptors.
268 A 16 bit build variant is generated for a Unicode build and an 8 bit build
269 variant generated for a non-Unicode build.
271 This build independent type should always be used unless an explicit 8 bit
272 or 16 bit build variant is required.
279 typedef CPtrC16Array CPtrCArray;
281 /** Build independent implementation base class for descriptor arrays.
288 typedef CDesC8Array CDesCArray;
289 /** Build independent array of descriptors implemented using a flat buffer.
292 @see CDesC16ArrayFlat
296 typedef CDesC8ArrayFlat CDesCArrayFlat;
297 /** Build independent array of descriptors implemented using a segmented buffer.
304 typedef CDesC8ArraySeg CDesCArraySeg;
305 /** Build independent array of non-modifiable pointer descriptors.
307 A 16 bit build variant is generated for a Unicode build and an 8 bit build
308 variant generated for a non-Unicode build.
310 This build independent type should always be used unless an explicit 8 bit
311 or 16 bit build variant is required.
318 typedef CPtrC8Array CPtrCArray;
322 #endif // __BADESCA_H__