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