os/security/securityanddataprivacytools/securitytools/certapp/store--/us_func.cpp
author sl
Tue, 10 Jun 2014 14:32:02 +0200
changeset 1 260cb5ec6c19
permissions -rw-r--r--
Update contrib.
     1 /*
     2 * Copyright (c) 2008-2009 Nokia Corporation and/or its subsidiary(-ies).
     3 * All rights reserved.
     4 * This component and the accompanying materials are made available
     5 * under the terms of the License "Eclipse Public License v1.0"
     6 * which accompanies this distribution, and is available
     7 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
     8 *
     9 * Initial Contributors:
    10 * Nokia Corporation - initial contribution.
    11 *
    12 * Contributors:
    13 *
    14 * Description: 
    15 *
    16 */
    17 
    18 
    19 #include <e32base.h>
    20 #include <e32panic.h>
    21 #include <s32file.h>
    22 #include <s32ucmp.h>
    23 
    24 
    25 void Mem::FillZ(TAny *aTrg, TInt aLength)
    26 	{
    27 	memset(aTrg, 0, aLength);
    28 	}
    29 
    30 TUint8* Mem::Move(TAny *aTrg, const TAny *aSrc, TInt aLength)
    31 {
    32 	TUint8 *s1 = (TUint8 *)aTrg;
    33 	TUint8 *s2 = (TUint8 *)aSrc;
    34 	memmove(s1, s2, aLength);
    35 	return s2 + aLength;
    36 }
    37 
    38 
    39 const TUint crcTab[256] =
    40     {
    41 	0x0000,0x1021,0x2042,0x3063,0x4084,0x50a5,0x60c6,0x70e7,0x8108,0x9129,0xa14a,
    42 	0xb16b,0xc18c,0xd1ad,0xe1ce,0xf1ef,0x1231,0x0210,0x3273,0x2252,0x52b5,0x4294,
    43 	0x72f7,0x62d6,0x9339,0x8318,0xb37b,0xa35a,0xd3bd,0xc39c,0xf3ff,0xe3de,0x2462,
    44 	0x3443,0x0420,0x1401,0x64e6,0x74c7,0x44a4,0x5485,0xa56a,0xb54b,0x8528,0x9509,
    45 	0xe5ee,0xf5cf,0xc5ac,0xd58d,0x3653,0x2672,0x1611,0x0630,0x76d7,0x66f6,0x5695,
    46 	0x46b4,0xb75b,0xa77a,0x9719,0x8738,0xf7df,0xe7fe,0xd79d,0xc7bc,0x48c4,0x58e5,
    47 	0x6886,0x78a7,0x0840,0x1861,0x2802,0x3823,0xc9cc,0xd9ed,0xe98e,0xf9af,0x8948,
    48 	0x9969,0xa90a,0xb92b,0x5af5,0x4ad4,0x7ab7,0x6a96,0x1a71,0x0a50,0x3a33,0x2a12,
    49 	0xdbfd,0xcbdc,0xfbbf,0xeb9e,0x9b79,0x8b58,0xbb3b,0xab1a,0x6ca6,0x7c87,0x4ce4,
    50 	0x5cc5,0x2c22,0x3c03,0x0c60,0x1c41,0xedae,0xfd8f,0xcdec,0xddcd,0xad2a,0xbd0b,
    51 	0x8d68,0x9d49,0x7e97,0x6eb6,0x5ed5,0x4ef4,0x3e13,0x2e32,0x1e51,0x0e70,0xff9f,
    52 	0xefbe,0xdfdd,0xcffc,0xbf1b,0xaf3a,0x9f59,0x8f78,0x9188,0x81a9,0xb1ca,0xa1eb,
    53 	0xd10c,0xc12d,0xf14e,0xe16f,0x1080,0x00a1,0x30c2,0x20e3,0x5004,0x4025,0x7046,
    54 	0x6067,0x83b9,0x9398,0xa3fb,0xb3da,0xc33d,0xd31c,0xe37f,0xf35e,0x02b1,0x1290,
    55 	0x22f3,0x32d2,0x4235,0x5214,0x6277,0x7256,0xb5ea,0xa5cb,0x95a8,0x8589,0xf56e,
    56 	0xe54f,0xd52c,0xc50d,0x34e2,0x24c3,0x14a0,0x0481,0x7466,0x6447,0x5424,0x4405,
    57 	0xa7db,0xb7fa,0x8799,0x97b8,0xe75f,0xf77e,0xc71d,0xd73c,0x26d3,0x36f2,0x0691,
    58 	0x16b0,0x6657,0x7676,0x4615,0x5634,0xd94c,0xc96d,0xf90e,0xe92f,0x99c8,0x89e9,
    59 	0xb98a,0xa9ab,0x5844,0x4865,0x7806,0x6827,0x18c0,0x08e1,0x3882,0x28a3,0xcb7d,
    60 	0xdb5c,0xeb3f,0xfb1e,0x8bf9,0x9bd8,0xabbb,0xbb9a,0x4a75,0x5a54,0x6a37,0x7a16,
    61 	0x0af1,0x1ad0,0x2ab3,0x3a92,0xfd2e,0xed0f,0xdd6c,0xcd4d,0xbdaa,0xad8b,0x9de8,
    62 	0x8dc9,0x7c26,0x6c07,0x5c64,0x4c45,0x3ca2,0x2c83,0x1ce0,0x0cc1,0xef1f,0xff3e,
    63 	0xcf5d,0xdf7c,0xaf9b,0xbfba,0x8fd9,0x9ff8,0x6e17,0x7e36,0x4e55,0x5e74,0x2e93,
    64 	0x3eb2,0x0ed1,0x1ef0
    65     };
    66 static const TUint32 CrcTab32[256] =
    67 	{
    68 	0x00000000, 0x77073096, 0xee0e612c, 0x990951ba,
    69 	0x076dc419, 0x706af48f, 0xe963a535, 0x9e6495a3,
    70 	0x0edb8832, 0x79dcb8a4, 0xe0d5e91e, 0x97d2d988,
    71 	0x09b64c2b, 0x7eb17cbd, 0xe7b82d07, 0x90bf1d91,
    72 	0x1db71064, 0x6ab020f2, 0xf3b97148, 0x84be41de,
    73 	0x1adad47d, 0x6ddde4eb, 0xf4d4b551, 0x83d385c7,
    74 	0x136c9856, 0x646ba8c0, 0xfd62f97a, 0x8a65c9ec,
    75 	0x14015c4f, 0x63066cd9, 0xfa0f3d63, 0x8d080df5,
    76 	0x3b6e20c8, 0x4c69105e, 0xd56041e4, 0xa2677172,
    77 	0x3c03e4d1, 0x4b04d447, 0xd20d85fd, 0xa50ab56b,
    78 	0x35b5a8fa, 0x42b2986c, 0xdbbbc9d6, 0xacbcf940,
    79 	0x32d86ce3, 0x45df5c75, 0xdcd60dcf, 0xabd13d59,
    80 	0x26d930ac, 0x51de003a, 0xc8d75180, 0xbfd06116,
    81 	0x21b4f4b5, 0x56b3c423, 0xcfba9599, 0xb8bda50f,
    82 	0x2802b89e, 0x5f058808, 0xc60cd9b2, 0xb10be924,
    83 	0x2f6f7c87, 0x58684c11, 0xc1611dab, 0xb6662d3d,
    84 	0x76dc4190, 0x01db7106, 0x98d220bc, 0xefd5102a,
    85 	0x71b18589, 0x06b6b51f, 0x9fbfe4a5, 0xe8b8d433,
    86 	0x7807c9a2, 0x0f00f934, 0x9609a88e, 0xe10e9818,
    87 	0x7f6a0dbb, 0x086d3d2d, 0x91646c97, 0xe6635c01,
    88 	0x6b6b51f4, 0x1c6c6162, 0x856530d8, 0xf262004e,
    89 	0x6c0695ed, 0x1b01a57b, 0x8208f4c1, 0xf50fc457,
    90 	0x65b0d9c6, 0x12b7e950, 0x8bbeb8ea, 0xfcb9887c,
    91 	0x62dd1ddf, 0x15da2d49, 0x8cd37cf3, 0xfbd44c65,
    92 	0x4db26158, 0x3ab551ce, 0xa3bc0074, 0xd4bb30e2,
    93 	0x4adfa541, 0x3dd895d7, 0xa4d1c46d, 0xd3d6f4fb,
    94 	0x4369e96a, 0x346ed9fc, 0xad678846, 0xda60b8d0,
    95 	0x44042d73, 0x33031de5, 0xaa0a4c5f, 0xdd0d7cc9,
    96 	0x5005713c, 0x270241aa, 0xbe0b1010, 0xc90c2086,
    97 	0x5768b525, 0x206f85b3, 0xb966d409, 0xce61e49f,
    98 	0x5edef90e, 0x29d9c998, 0xb0d09822, 0xc7d7a8b4,
    99 	0x59b33d17, 0x2eb40d81, 0xb7bd5c3b, 0xc0ba6cad,
   100 	0xedb88320, 0x9abfb3b6, 0x03b6e20c, 0x74b1d29a,
   101 	0xead54739, 0x9dd277af, 0x04db2615, 0x73dc1683,
   102 	0xe3630b12, 0x94643b84, 0x0d6d6a3e, 0x7a6a5aa8,
   103 	0xe40ecf0b, 0x9309ff9d, 0x0a00ae27, 0x7d079eb1,
   104 	0xf00f9344, 0x8708a3d2, 0x1e01f268, 0x6906c2fe,
   105 	0xf762575d, 0x806567cb, 0x196c3671, 0x6e6b06e7,
   106 	0xfed41b76, 0x89d32be0, 0x10da7a5a, 0x67dd4acc,
   107 	0xf9b9df6f, 0x8ebeeff9, 0x17b7be43, 0x60b08ed5,
   108 	0xd6d6a3e8, 0xa1d1937e, 0x38d8c2c4, 0x4fdff252,
   109 	0xd1bb67f1, 0xa6bc5767, 0x3fb506dd, 0x48b2364b,
   110 	0xd80d2bda, 0xaf0a1b4c, 0x36034af6, 0x41047a60,
   111 	0xdf60efc3, 0xa867df55, 0x316e8eef, 0x4669be79,
   112 	0xcb61b38c, 0xbc66831a, 0x256fd2a0, 0x5268e236,
   113 	0xcc0c7795, 0xbb0b4703, 0x220216b9, 0x5505262f,
   114 	0xc5ba3bbe, 0xb2bd0b28, 0x2bb45a92, 0x5cb36a04,
   115 	0xc2d7ffa7, 0xb5d0cf31, 0x2cd99e8b, 0x5bdeae1d,
   116 	0x9b64c2b0, 0xec63f226, 0x756aa39c, 0x026d930a,
   117 	0x9c0906a9, 0xeb0e363f, 0x72076785, 0x05005713,
   118 	0x95bf4a82, 0xe2b87a14, 0x7bb12bae, 0x0cb61b38,
   119 	0x92d28e9b, 0xe5d5be0d, 0x7cdcefb7, 0x0bdbdf21,
   120 	0x86d3d2d4, 0xf1d4e242, 0x68ddb3f8, 0x1fda836e,
   121 	0x81be16cd, 0xf6b9265b, 0x6fb077e1, 0x18b74777,
   122 	0x88085ae6, 0xff0f6a70, 0x66063bca, 0x11010b5c,
   123 	0x8f659eff, 0xf862ae69, 0x616bffd3, 0x166ccf45,
   124 	0xa00ae278, 0xd70dd2ee, 0x4e048354, 0x3903b3c2,
   125 	0xa7672661, 0xd06016f7, 0x4969474d, 0x3e6e77db,
   126 	0xaed16a4a, 0xd9d65adc, 0x40df0b66, 0x37d83bf0,
   127 	0xa9bcae53, 0xdebb9ec5, 0x47b2cf7f, 0x30b5ffe9,
   128 	0xbdbdf21c, 0xcabac28a, 0x53b39330, 0x24b4a3a6,
   129 	0xbad03605, 0xcdd70693, 0x54de5729, 0x23d967bf,
   130 	0xb3667a2e, 0xc4614ab8, 0x5d681b02, 0x2a6f2b94,
   131 	0xb40bbe37, 0xc30c8ea1, 0x5a05df1b, 0x2d02ef8d
   132 	};
   133 
   134 EXPORT_C void Mem::Crc(TUint16& aCrc,const TAny* aPtr,TInt aLength)
   135 /**
   136 Performs a CCITT CRC checksum on the specified data.
   137 
   138 On return from this function, the referenced 16 bit integer contains the checksummed 
   139 value.
   140 
   141 @param aCrc    A reference to a 16 bit integer to contain the checksummed value. 
   142 @param aPtr    A pointer to the start of the data to be checksummed. 
   143 @param aLength The length of the data to be checksummed.
   144 */
   145 	{
   146 
   147 	const TUint8* pB=(const TUint8*)aPtr;
   148 	const TUint8* pE=pB+aLength;
   149 	TUint crc=aCrc;
   150     while (pB<pE)
   151 		crc=(crc<<8)^crcTab[((crc>>8)^*pB++)&0xff];
   152 	aCrc=(TUint16)crc;
   153 	}
   154 
   155 /**
   156 Performs a CCITT CRC-32 checksum on the specified data.
   157 
   158 On return from this function, the referenced 32 bit integer contains the CRC
   159 value.
   160 
   161 @param aCrc		A reference to a 32 bit integer to contain the CRC value. 
   162 @param aPtr		A pointer to the start of the data to be checksummed. 
   163 @param aLength	The length of the data to be checksummed.
   164 */
   165 EXPORT_C void Mem::Crc32(TUint32& aCrc, const TAny* aPtr, TInt aLength)
   166 	{
   167 	const TUint8* p = (const TUint8*)aPtr;
   168 	const TUint8* q = p + aLength;
   169 	TUint32 crc = aCrc;
   170 	while (p < q)
   171 		crc = (crc >> 8) ^ CrcTab32[(crc ^ *p++) & 0xff];
   172 	aCrc = crc;
   173 	}
   174 
   175 
   176 LOCAL_C TUint checkSum(const TAny *aPtr)
   177 //
   178 // Checksum every other byte
   179 //
   180 	{
   181 
   182 	const TUint8* pB=(const TUint8*)aPtr;
   183 	const TUint8* pE=pB+(KMaxCheckedUid*sizeof(TUid));
   184 	TUint8 buf[(KMaxCheckedUid*sizeof(TUid))>>1];
   185 	TUint8* pT=(&buf[0]);
   186 	while (pB<pE)
   187 		{
   188 		*pT++=(*pB);
   189 		pB+=2;
   190 		}
   191 	TUint16 crc=0;
   192 	Mem::Crc(crc,&buf[0],(KMaxCheckedUid*sizeof(TUid))>>1);
   193 	return(crc);
   194 	}
   195 
   196 
   197 
   198 
   199 EXPORT_C TCheckedUid::TCheckedUid()
   200 /**
   201 Default constructor.
   202 
   203 Initialises the object to binary zeroes.
   204 */
   205 	{
   206 	//	Mem::FillZ(this,sizeof(TCheckedUid));
   207 	iCheck = 0;
   208 	}
   209 
   210 
   211 
   212 
   213 EXPORT_C TCheckedUid::TCheckedUid(const TUidType& aUidType)
   214 /**
   215 Constructor taking an existing Uid type.
   216 
   217 The constructor calculates a checksum.
   218 
   219 @param aUidType The Uid type to be packaged.
   220 */
   221 	{
   222 
   223     Set(aUidType);
   224     }
   225 
   226 
   227 
   228 
   229 EXPORT_C TCheckedUid::TCheckedUid(const TDesC8& aPtr)
   230 /**
   231 Constructor taking an existing TCheckedUid object encapsulated within
   232 a descriptor.
   233 
   234 The checksum is recalculated and must match the checksum value passed in the 
   235 encapsulated TCheckedUid object, otherwise the content of this object is reset 
   236 to binary zeroes.
   237 
   238 @param aPtr A pointer to a descriptor containing an existing TCheckedUid object. 
   239                         
   240 @panic USER 38 If the length of the descriptor is not the same as the size 
   241        of a TCheckedUid object.
   242 */
   243 	{
   244 
   245 	Set(aPtr);
   246 	}
   247 
   248 
   249 
   250 
   251 EXPORT_C void TCheckedUid::Set(const TUidType& aUidType)
   252 /**
   253 Sets the specified Uid type to be packaged, and recalculates the checksum.
   254 
   255 @param aUidType The Uid type to be packaged.
   256 */
   257 	{
   258 
   259     iType=aUidType;
   260     iCheck=Check();
   261     }
   262 
   263 
   264 
   265 EXPORT_C void TCheckedUid::Set(const TDesC8& aPtr)
   266 /**
   267 Sets an existing TCheckedUid object encapsulated within a descriptor.
   268 
   269 The checksum is recalculated and must match the checksum value passed in the 
   270 encapsulated TCheckedUid object, otherwise the content of this object is reset 
   271 to binary zeroes.
   272 
   273 @param aPtr A pointer to a descriptor containing an existing
   274             TCheckedUid object.
   275 
   276 @panic USER 38 If the length of the descriptor is not the same as the size 
   277        of a TCheckedUid object.
   278 */
   279 	{
   280 
   281 	__ASSERT_ALWAYS(aPtr.Length()==sizeof(TCheckedUid),Panic(ETFuncCheckedUidBadSet));
   282 	Mem::Move(this,aPtr.Ptr(),sizeof(TCheckedUid));
   283 	if (iCheck!=Check())
   284 		Mem::FillZ(this,sizeof(TCheckedUid));
   285 	}
   286 
   287 
   288 
   289 
   290 EXPORT_C TPtrC8 TCheckedUid::Des() const
   291 /**
   292 Gets a pointer descriptor to represent this object's data.
   293 
   294 @return The pointer descriptor for this object's data. The descriptor's length
   295         is the same as the length of a TCheckedUid object.
   296 */
   297 	{
   298 
   299 	return(TPtrC8((const TUint8*)this,sizeof(TCheckedUid)));
   300 	}
   301 
   302 
   303 
   304 EXPORT_C TUint TCheckedUid::Check() const
   305 /**
   306 Calculates the checksum of the UIDs.
   307 
   308 @return The checksum.
   309 */
   310 	{
   311 
   312 	return((checkSum(((TUint8*)this)+1)<<16)|checkSum(this));
   313 	}
   314 
   315 EXPORT_C TUidType::TUidType()
   316 /**
   317 Default constructor.
   318 
   319 Creates a UID type, and sets all three component UIDs to KNullUid.
   320 */
   321     {
   322 	Mem::FillZ(this,sizeof(TUidType));
   323     }
   324 
   325 
   326 
   327 
   328 EXPORT_C TUidType::TUidType(TUid aUid1)
   329 /**
   330 Constructor that creates a UID type and sets the UID1 component
   331 to the specified value.
   332 
   333 The UID2 and UID3 components are set to KNullUid.
   334 
   335 @param aUid1 Value for UID1.
   336 */
   337     {
   338 
   339 
   340 	Mem::FillZ(this,sizeof(TUidType));
   341     iUid[0]=aUid1;
   342     }
   343 
   344 
   345 
   346 
   347 EXPORT_C TUidType::TUidType(TUid aUid1,TUid aUid2)
   348 /**
   349 Constructor that creates a UID type and sets the UID1 and UID2 components
   350 to the specified values. 
   351 
   352 The UID3 component is set to KNullUid.
   353 
   354 @param aUid1 Value for UID1. 
   355 @param aUid2 Value for UID2.
   356 */
   357     {
   358 
   359     iUid[0]=aUid1;
   360     iUid[1]=aUid2;
   361     iUid[2]=KNullUid;
   362     }
   363 
   364 
   365 
   366 
   367 EXPORT_C TUidType::TUidType(TUid aUid1,TUid aUid2,TUid aUid3)
   368 /**
   369 Constructor that creates a UID type and sets all three UID components
   370 to the specified values.
   371 
   372 @param aUid1 Value for UID1.
   373 @param aUid2 Value for UID2.
   374 @param aUid3 Value for UID3.
   375 */
   376     {
   377 
   378 
   379     iUid[0]=aUid1;
   380     iUid[1]=aUid2;
   381     iUid[2]=aUid3;
   382     }
   383 
   384 
   385 
   386 
   387 EXPORT_C TBool TUidType::operator==(const TUidType& aUidType) const
   388 /**
   389 Compares this UID type for equality with the specified UID type.
   390 
   391 @param aUidType The UID type to be compared. 
   392 
   393 @return True, if each component UID is equal to the corresponding component 
   394         UID in the specified UID type; false, otherwise.
   395 */
   396     {
   397 
   398     return(iUid[0]==aUidType.iUid[0] &&
   399            iUid[1]==aUidType.iUid[1] &&
   400            iUid[2]==aUidType.iUid[2]);
   401     }
   402 
   403 
   404 
   405 
   406 EXPORT_C TBool TUidType::operator!=(const TUidType& aUidType) const
   407 /** 
   408 Compares this UID type for inequality with the specified UID type.
   409 
   410 @param aUidType The UID type to be compared.
   411 
   412 @return True, if any component UID is not equal to the corresponding component 
   413 UID in the specified UID type; false otherwise.
   414 */
   415     {
   416 
   417 
   418     return(!(*this==aUidType));
   419     }
   420 
   421 
   422 
   423 
   424 EXPORT_C const TUid& TUidType::operator[](TInt aIndex) const
   425 /**
   426 Gets the UID component as identified by the specified index.
   427 
   428 @param aIndex Index value indicating which UID component to return.
   429                0 specifies UID1,
   430                1 specifies UID2,
   431                2 specifies UID3.
   432 
   433 @return A reference to the required UID component.
   434 
   435 @panic USER 37 if aIndex is not in the range 0 to 2, inclusive.
   436 */
   437     {
   438 
   439 	__ASSERT_ALWAYS(aIndex>=0 && aIndex<KMaxCheckedUid,Panic(ETFuncUidTypeBadIndex));
   440 	return(iUid[aIndex]);
   441     }
   442 
   443 
   444 
   445 
   446 EXPORT_C TUid TUidType::MostDerived() const
   447 /**
   448 Gets the most derived UID.
   449 
   450 Taking the three UID components as a hierarchy with UID1 being the most general, 
   451 UID2 being more specific than UID1 and UID3 being more specific than UID2, 
   452 then the function returns:
   453 
   454 UID3, if UID3 is not KNullUid.
   455 
   456 UID2, if UID2 is not KNullUid.
   457 
   458 UID1, otherwise
   459 
   460 @return The most derived UID.
   461 
   462 @see KNullUid
   463 */
   464     {
   465 
   466     if (iUid[2]!=KNullUid)
   467         return(iUid[2]);
   468     if (iUid[1]!=KNullUid)
   469         return(iUid[1]);
   470     return(iUid[0]);
   471     }
   472 
   473 
   474 
   475 
   476 EXPORT_C TBool TUidType::IsPresent(TUid aUid) const
   477 /**
   478 Tests if any of the component UIDs are equal to the specified UID.
   479 
   480 @param aUid The UID to be tested.
   481 
   482 @return True, if any one of the component UIDs are the same as the specified 
   483         UID; false, if none of the component UIDs are the same.
   484 */
   485     {
   486 
   487 	return(iUid[0]==aUid || iUid[1]==aUid || iUid[2]==aUid);
   488     }
   489 
   490 
   491 
   492 
   493 EXPORT_C TBool TUidType::IsValid() const
   494 /**
   495 Tests the object for a valid (non-KNullUid) UID type.
   496 
   497 @return True, if at least one of the component UIDs is not KNullUid; false, 
   498         if all component UIDs are KNullUid.
   499 
   500 @see KNullUid
   501 */
   502     {
   503 
   504     return(MostDerived()!=KNullUid);
   505     }
   506 
   507 EXPORT_C void ExternalizeL(TInt64 anInt64,RWriteStream& aStream)
   508 //
   509 // Write a 64-bit integer out to aStream.
   510 //
   511 	{
   512 	aStream.WriteUint32L(I64LOW(anInt64));
   513 	aStream.WriteUint32L(I64HIGH(anInt64));
   514 	}
   515 
   516 EXPORT_C void InternalizeL(TInt64& anInt64,RReadStream& aStream)
   517 //
   518 // Read a 64-bit integer in from aStream.
   519 //
   520 	{
   521 	TUint low=aStream.ReadUint32L();
   522 	TUint high=aStream.ReadUint32L();
   523 	anInt64 = MAKE_TINT64(high,low);
   524 	}
   525 
   526 EXPORT_C void ExternalizeL(const TCheckedUid& aUid,RWriteStream& aStream)
   527 //
   528 // Write a checked uid type out to aStream.
   529 //
   530 	{
   531 	aStream.WriteL(aUid.Des());
   532 	}
   533 
   534 EXPORT_C void InternalizeL(TCheckedUid& aUid,RReadStream& aStream)
   535 //
   536 // Read a checked uid type in from aStream.
   537 //
   538 {
   539 	TUint32 buf[4];
   540 		
   541 	TPtr8 des((TUint8 *)buf, sizeof(buf));
   542 	aStream.ReadL(des);
   543 	aUid.Set(des);
   544 }
   545 
   546 #if 0
   547 EXPORT_C void ExternalizeL(TPoint aPoint,RWriteStream& aStream)
   548 //
   549 // Write a point out to aStream.
   550 //
   551 	{
   552 	aStream.WriteInt32L(aPoint.iX);
   553 	aStream.WriteInt32L(aPoint.iY);
   554 	}
   555 
   556 EXPORT_C void ExternalizeL(TSize aSize,RWriteStream& aStream)
   557 //
   558 // Write a size out to aStream.
   559 //
   560 	{
   561 	aStream.WriteInt32L(aSize.iWidth);
   562 	aStream.WriteInt32L(aSize.iHeight);
   563 	}
   564 
   565 EXPORT_C void ExternalizeL(const TRect& aRect,RWriteStream& aStream)
   566 //
   567 // Write a rectangle out to aStream.
   568 //
   569 	{
   570 	aStream<<aRect.iTl;
   571 	aStream<<aRect.iBr;
   572 	}
   573 
   574 EXPORT_C void InternalizeL(TPoint& aPoint,RReadStream& aStream)
   575 //
   576 // Read a point in from aStream.
   577 //
   578 	{
   579 	aPoint.iX=aStream.ReadInt32L();
   580 	aPoint.iY=aStream.ReadInt32L();
   581 	}
   582 
   583 EXPORT_C void InternalizeL(TSize& aSize,RReadStream& aStream)
   584 //
   585 // Read a size in from aStream.
   586 //
   587 	{
   588 	aSize.iWidth=aStream.ReadInt32L();
   589 	aSize.iHeight=aStream.ReadInt32L();
   590 	}
   591 
   592 EXPORT_C void InternalizeL(TRect& aRect,RReadStream& aStream)
   593 //
   594 // Read a rectangle in from aStream.
   595 //
   596 	{
   597 	aStream>>aRect.iTl;
   598 	aStream>>aRect.iBr;
   599 	}
   600 #endif
   601 
   602 RWriteStream& operator<<(RWriteStream&aStream, const TDesHeader &aDesHeader)
   603 {
   604 	aDesHeader.ExternalizeL(aStream);
   605 	return aStream;
   606 }
   607 
   608 RReadStream& operator>>(RReadStream&aStream,  TDesHeader &aDesHeader)
   609 {
   610 	aDesHeader.InternalizeL(aStream);
   611 	return aStream;
   612 }
   613 
   614 EXPORT_C void ExternalizeL(const TDesC8& aDes8,RWriteStream& aStream)
   615 //
   616 // Write an 8-bit descriptor out to aStream.
   617 //
   618 	{
   619 	TDesHeader header(aDes8);
   620 	aStream<<header;
   621 	aStream.WriteL(aDes8.Ptr(),aDes8.Length());
   622 	}
   623 
   624 RWriteStream& operator<<(RWriteStream&aStream, const TCardinality &aCardinality)
   625 {
   626 	aCardinality.ExternalizeL(aStream);
   627 	return aStream;
   628 }
   629 
   630 RReadStream& operator>>(RReadStream&aStream,  TCardinality &aCardinality)
   631 {
   632 	aCardinality.InternalizeL(aStream);
   633 	return aStream;
   634 }
   635 
   636 EXPORT_C void ExternalizeL(const TDesC16& aDes16,RWriteStream& aStream)
   637 //
   638 // Write a 16-bit descriptor out to aStream.
   639 //
   640 	{
   641 	TDesHeader header(aDes16);
   642 	aStream << header;
   643 
   644 #ifdef _UNICODE
   645 	// In the Unicode build, compress the data using the Standard Unicode Compression Scheme.
   646 	TMemoryUnicodeSource source(aDes16.Ptr());
   647 	TUnicodeCompressor compressor;
   648 	compressor.CompressL(aStream,source,KMaxTInt,aDes16.Length());
   649 	
   650 #else
   651 	aStream.WriteL(aDes16.Ptr(),aDes16.Length());
   652 #endif
   653 	}
   654 
   655 EXPORT_C void InternalizeL(TDes8& aDes8,RReadStream& aStream)
   656 //
   657 // Read an 8-bit descriptor in from aStream.
   658 //
   659 	{
   660 	TDesInternalizer interL;
   661 	aStream>>interL.Header();
   662 	interL(aDes8,aStream);
   663 	}
   664 
   665 EXPORT_C void InternalizeL(TDes16& aDes16,RReadStream& aStream)
   666 //
   667 // Read a 16-bit descriptor in from aStream.
   668 //
   669 	{
   670 	TDesInternalizer interL;
   671 	aStream>>interL.Header();
   672 	interL(aDes16,aStream);
   673 	}
   674 inline TDesHeader::TDesHeader(const TDesC8& aDes8)
   675 	: iVal((aDes8.Length()<<1)+1)
   676 	{}
   677 inline TDesHeader::TDesHeader(const TDesC16& aDes16)
   678 	: iVal((aDes16.Length()<<1))
   679 	{}
   680 inline TDesHeader& TDesHeader::operator=(const TDesC8& aDes8)
   681 	{return *this=TDesHeader(aDes8);}
   682 inline TDesHeader& TDesHeader::operator=(const TDesC16& aDes16)
   683 	{return *this=TDesHeader(aDes16);}
   684 inline TBool TDesHeader::IsWidth8() const
   685 	{return TInt(iVal)&0x1;}
   686 inline TBool TDesHeader::IsWidth16() const
   687 	{return !IsWidth8();}
   688 inline TInt TDesHeader::Length() const
   689 	{return TInt(iVal)>>1;}
   690 inline void TDesHeader::ExternalizeL(RWriteStream& aStream) const
   691 	{aStream<<iVal;}
   692 inline void TDesHeader::InternalizeL(RReadStream& aStream)
   693 	{aStream>>iVal;}
   694 
   695 // An MUnicodeSink implementation to write Unicode values into 8-bit bytes; anything outside 0..255 becomes 1
   696 #ifdef _UNICODE
   697 class TNarrowUnicodeSink: public MUnicodeSink
   698 	{
   699 	public:
   700 	TNarrowUnicodeSink(TUint8* aPtr): iPtr(aPtr) { }
   701 	void WriteUnicodeValueL(TUint16 aValue) { *iPtr++ = (TUint8)(aValue > 255 ? 1 : aValue); }
   702 
   703 	private:
   704 	TUint8* iPtr;
   705 	};
   706 #endif
   707 
   708 void TDesInternalizer::operator()(TDes8& aDes8,RReadStream& aStream) const
   709 //
   710 // Read an 8-bit descriptor in from aStream.
   711 //
   712 	{
   713 	TInt len=iHeader.Length();
   714 	if (len>aDes8.MaxLength())
   715 		__LEAVE(KErrOverflow);
   716 //
   717 	TUint8* ptr=(TUint8*)aDes8.Ptr();
   718 	if (iHeader.IsWidth8())
   719 		aStream.ReadL(ptr,len);
   720 	else
   721 		{
   722 		__ASSERT_DEBUG(iHeader.IsWidth16(),User::Invariant());
   723 #ifdef _UNICODE
   724 		// In the Unicode build 16-bit descriptors need to be expanded from the Standard Unicode Compression Scheme.
   725 		TNarrowUnicodeSink sink(ptr);
   726 		TUnicodeExpander expander;
   727 		expander.ExpandL(sink,aStream,len);
   728 
   729 #else
   730 		TUint8* end=ptr+len;
   731 		while (ptr!=end)
   732 			{
   733 			TUint c=aStream.ReadUint16L();
   734 			if (c>=0x100)
   735 				c=1;
   736 			*ptr++=TUint8(c);
   737 			}
   738 #endif
   739 		}
   740 	aDes8.SetLength(len);
   741 	}
   742 
   743 void TDesInternalizer::operator()(TDes16& aDes16,RReadStream& aStream) const
   744 //
   745 // Read a 16-bit descriptor in from aStream.
   746 //
   747 	{
   748 	TInt len=iHeader.Length();
   749 	if (len>aDes16.MaxLength())
   750 		__LEAVE(KErrOverflow);
   751 //
   752 	TUint16* ptr=(TUint16*)aDes16.Ptr();
   753 	if (iHeader.IsWidth16())
   754 		{
   755 #ifdef _UNICODE
   756 		// In the Unicode build 16-bit descriptors need to be expanded from the Standard Unicode Compression Scheme.
   757 		TMemoryUnicodeSink sink(ptr);
   758 		TUnicodeExpander expander;
   759 		expander.ExpandL(sink,aStream,len);
   760 
   761 #else
   762 		aStream.ReadL(ptr,len);
   763 #endif
   764 		}
   765 	else
   766 		{
   767 		__ASSERT_DEBUG(iHeader.IsWidth8(),User::Invariant());
   768 		TUint16* end=ptr+len;
   769 		while (ptr!=end)
   770 			*ptr++=aStream.ReadUint8L();
   771 		}
   772 	aDes16.SetLength(len);
   773 	}
   774 
   775 // End of file