Update contrib.
1 // Copyright (c) 2006-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.
19 #include <pcstore/checkeduid.h>
20 #include <pcstore/descriptors.h>
21 #include <pcstore/storeexception.h>
22 #include "pcstoreconst.h"
26 const TUint crcTab[256] =
28 0x0000,0x1021,0x2042,0x3063,0x4084,0x50a5,0x60c6,0x70e7,0x8108,0x9129,0xa14a,
29 0xb16b,0xc18c,0xd1ad,0xe1ce,0xf1ef,0x1231,0x0210,0x3273,0x2252,0x52b5,0x4294,
30 0x72f7,0x62d6,0x9339,0x8318,0xb37b,0xa35a,0xd3bd,0xc39c,0xf3ff,0xe3de,0x2462,
31 0x3443,0x0420,0x1401,0x64e6,0x74c7,0x44a4,0x5485,0xa56a,0xb54b,0x8528,0x9509,
32 0xe5ee,0xf5cf,0xc5ac,0xd58d,0x3653,0x2672,0x1611,0x0630,0x76d7,0x66f6,0x5695,
33 0x46b4,0xb75b,0xa77a,0x9719,0x8738,0xf7df,0xe7fe,0xd79d,0xc7bc,0x48c4,0x58e5,
34 0x6886,0x78a7,0x0840,0x1861,0x2802,0x3823,0xc9cc,0xd9ed,0xe98e,0xf9af,0x8948,
35 0x9969,0xa90a,0xb92b,0x5af5,0x4ad4,0x7ab7,0x6a96,0x1a71,0x0a50,0x3a33,0x2a12,
36 0xdbfd,0xcbdc,0xfbbf,0xeb9e,0x9b79,0x8b58,0xbb3b,0xab1a,0x6ca6,0x7c87,0x4ce4,
37 0x5cc5,0x2c22,0x3c03,0x0c60,0x1c41,0xedae,0xfd8f,0xcdec,0xddcd,0xad2a,0xbd0b,
38 0x8d68,0x9d49,0x7e97,0x6eb6,0x5ed5,0x4ef4,0x3e13,0x2e32,0x1e51,0x0e70,0xff9f,
39 0xefbe,0xdfdd,0xcffc,0xbf1b,0xaf3a,0x9f59,0x8f78,0x9188,0x81a9,0xb1ca,0xa1eb,
40 0xd10c,0xc12d,0xf14e,0xe16f,0x1080,0x00a1,0x30c2,0x20e3,0x5004,0x4025,0x7046,
41 0x6067,0x83b9,0x9398,0xa3fb,0xb3da,0xc33d,0xd31c,0xe37f,0xf35e,0x02b1,0x1290,
42 0x22f3,0x32d2,0x4235,0x5214,0x6277,0x7256,0xb5ea,0xa5cb,0x95a8,0x8589,0xf56e,
43 0xe54f,0xd52c,0xc50d,0x34e2,0x24c3,0x14a0,0x0481,0x7466,0x6447,0x5424,0x4405,
44 0xa7db,0xb7fa,0x8799,0x97b8,0xe75f,0xf77e,0xc71d,0xd73c,0x26d3,0x36f2,0x0691,
45 0x16b0,0x6657,0x7676,0x4615,0x5634,0xd94c,0xc96d,0xf90e,0xe92f,0x99c8,0x89e9,
46 0xb98a,0xa9ab,0x5844,0x4865,0x7806,0x6827,0x18c0,0x08e1,0x3882,0x28a3,0xcb7d,
47 0xdb5c,0xeb3f,0xfb1e,0x8bf9,0x9bd8,0xabbb,0xbb9a,0x4a75,0x5a54,0x6a37,0x7a16,
48 0x0af1,0x1ad0,0x2ab3,0x3a92,0xfd2e,0xed0f,0xdd6c,0xcd4d,0xbdaa,0xad8b,0x9de8,
49 0x8dc9,0x7c26,0x6c07,0x5c64,0x4c45,0x3ca2,0x2c83,0x1ce0,0x0cc1,0xef1f,0xff3e,
50 0xcf5d,0xdf7c,0xaf9b,0xbfba,0x8fd9,0x9ff8,0x6e17,0x7e36,0x4e55,0x5e74,0x2e93,
55 Performs a CCITT CRC checksum on the specified data.
57 On return from this function, the referenced 16 bit integer contains the checksum.
59 @param aCrc A reference to a 16 bit integer to contain the checksum.
60 @param aPtr A pointer to the start of the data to be checksum.
61 @param aLength The length of the data to be checksum.
63 void Crc(TUint16& aCrc,const void* aPtr,TInt aLength)
65 const TUint8* pB=static_cast<const TUint8*>(aPtr);
66 const TUint8* pE=pB+aLength;
70 crc=(crc<<8)^crcTab[((crc>>8)^*pB++)&0xff];
77 Generate a checksum for the object of TCheckedUid.
79 @param aPtr The pointer to the TCheckedUid.
80 @return The resulted checksum for the TCheckedUid.
82 TUint checkSum(const void *aPtr)
84 const TUint8* pB=static_cast<const TUint8*>(aPtr);
85 const TUint8* pE=pB+(KMaxCheckedUid*sizeof(TUid));
86 TUint8 buf[(KMaxCheckedUid*sizeof(TUid))>>1];
94 Crc(crc,&buf[0],(KMaxCheckedUid*sizeof(TUid))>>1);
99 Constructor that creates a zero-valued UID type.
103 memset(this,0,sizeof(TUidType));
108 Constructor that creates a UID type and sets the UID1 component
109 to the specified value.
111 The UID2 and UID3 components are set to KNullUid.
113 @param aUid1 Value for UID1.
115 TUidType::TUidType(TUid aUid1)
117 memset(this,0,sizeof(TUidType));
123 Constructor that creates a UID type and sets the UID1 and UID2 components
124 to the specified values.
126 The UID3 component is set to KNullUid.
128 @param aUid1 Value for UID1.
129 @param aUid2 Value for UID2.
131 TUidType::TUidType(TUid aUid1, TUid aUid2)
139 Constructor that creates a UID type and sets all three UID components
140 to the specified values.
142 @param aUid1 Value for UID1.
143 @param aUid2 Value for UID2.
144 @param aUid3 Value for UID3.
146 TUidType::TUidType(TUid aUid1, TUid aUid2, TUid aUid3)
155 Compares this UID type for inequality with the specified UID type.
157 @param aUidType The UID type to be compared.
158 @return TRUE, if any component UID is not equal to the corresponding component
159 UID in the specified UID type; FALSE otherwise.
161 TBool TUidType::operator !=(const TUidType& aUidType) const
163 return(!(*this==aUidType));
167 Compares this UID type for equality with the specified UID type.
169 @param aUidType The reference to the UID type to be compared.
170 @return TRUE, if each component UID is equal to the corresponding component
171 UID in the specified UID type; FALSE, otherwise.
173 TBool TUidType::operator ==(const TUidType& aUidType) const
175 return(iUid[0]==aUidType.iUid[0] &&
176 iUid[1]==aUidType.iUid[1] &&
177 iUid[2]==aUidType.iUid[2]);
182 Gets the most derived UID.
184 Taking the three UID components as a hierarchy with UID1 being the most general,
185 UID2 being more specific than UID1 and UID3 being more specific than UID2,
186 then the function returns:
188 UID3, if UID3 is not KNullUid.
189 UID2, if UID2 is not KNullUid.
192 @return The most derived UID.
194 TUid TUidType::MostDerived() const
196 if (iUid[2]!=KNullUid)
200 if (iUid[1]!=KNullUid)
208 Gets the UID component as identified by the specified index.
210 @param aIndex Index value indicating which UID component to return.
215 aIndex must be between 0 and 2.
217 @return The reference to the required UID component.
219 const TUid& TUidType::operator[](TInt aIndex) const
221 assert(aIndex >= 0 && aIndex <= 2);
222 return(iUid[aIndex]);
226 Tests the object for a valid (non-KNullUid) UID type.
228 @return TRUE, if at least one of the component UIDs is not KNullUid; FALSE,
229 if all component UIDs are KNullUid.
231 TBool TUidType::IsValid() const
233 return(MostDerived()!=KNullUid);
240 Initialises the object to binary zeroes.
242 TCheckedUid::TCheckedUid()
244 memset(this,0, sizeof(TCheckedUid));
249 Constructor taking an existing Uid type.
251 The constructor calculates a checksum.
253 @param aUidType The reference to a Uid type to be packaged.
255 TCheckedUid::TCheckedUid(const TUidType& aUidType)
262 Constructor taking an existing TCheckedUid object encapsulated within
265 The checksum is recalculated and must match the checksum value passed in the
266 encapsulated TCheckedUid object, otherwise the content of this object is reset
269 aDes should be an 8-bit descriptor which holds the contents of a TCheckedUid object.
271 @param aDes The reference to an 8-bit descriptor containing an existing TCheckedUid
274 TCheckedUid::TCheckedUid(const CDes8& aDes)
280 Sets the specified Uid type to be packaged, and recalculates the checksum.
282 @param aUidType The reference to a Uid type to be set.
284 void TCheckedUid::Set(const TUidType& aUidType)
291 Sets an existing TCheckedUid object encapsulated within a descriptor.
293 The checksum is recalculated and must match the checksum value passed in the
294 encapsulated TCheckedUid object, otherwise the content of this object is reset
297 aDes should be an 8-bit descriptor which holds the contents of a TCheckedUid object.
299 @param aDes The reference to a descriptor containing an existing TCheckedUid object.
301 void TCheckedUid::Set(const CDes8& aDes)
303 assert(aDes.Length() == sizeof(TCheckedUid));
304 memcpy(this,aDes.Ptr(),sizeof(TCheckedUid));
307 memset(this,0,sizeof(TCheckedUid));
312 Gets a descriptor to represent this object's data.
314 @return The descriptor for this object's data. The descriptor's length
315 is the same as the length of a TCheckedUid object.
317 CDes8 TCheckedUid::Des() const
319 return(CDes8 (reinterpret_cast<const TUint8*>(this),sizeof(TCheckedUid)));
323 Gets the Uid type contained in this object.
325 @return The Uid type.
327 const TUidType& TCheckedUid::UidType() const
333 Calculates the checksum of the UIDs.
335 @return The checksum.
337 TUint TCheckedUid::Check() const
339 return((checkSum((reinterpret_cast<TUint8*>(const_cast<TCheckedUid*>(this)))+1)<<16)|checkSum(this));