本文整理汇总了C++中TDes8类的典型用法代码示例。如果您正苦于以下问题:C++ TDes8类的具体用法?C++ TDes8怎么用?C++ TDes8使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了TDes8类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: Read
TInt CRefTestAgentData::Read(TDes8& aDes)
{
return iServer.Read(aDes, aDes.MaxLength());
}
示例2: Read
/**
Read a portion of data from the device.
Note: at present it _APPENDS_ data to the aDataDes, so the caller must take care of setting its length
@param aPos media position in bytes
@param aLength how many bytes to read
@param aDataDes data descriptor
@return KErrNone on success, standard Epoc error code otherwise
*/
TInt CWinImgFileDevice::Read(TInt64 aPos,TInt aLength, TDes8& aDataDes)
{
//__PRINT3(_L("#-- CWinImgFileDevice::Read, pos:%LU, len:%u, desMaxLen:%u"), aPos, aLength, aDataDes.MaxLength());
ASSERT(HandleValid());
ASSERT(aLength <= aDataDes.MaxLength());
//-- check position on the volume
const TInt64 maxPos = iDrvGeometry.TotalSizeInBytes();
if(aPos < 0 || aPos > maxPos)
return KErrArgument;
const TInt64 lastPos = aPos+aLength;
if(lastPos > maxPos)
return KErrArgument;
TUint32 dataLen = aLength;
if(dataLen == 0)
return KErrNone;
DWORD dwRes;
DWORD dwBytesRead = 0;
//aDataDes.SetLength(0);
try
{
//-- 1. position to the media
LONG mediaPosHi = I64HIGH(aPos);
const TUint32 mediaPosLo = I64LOW(aPos);
dwRes = SetFilePointer(iDevHandle, mediaPosLo, &mediaPosHi, FILE_BEGIN);
if(dwRes == INVALID_SET_FILE_POINTER)
throw KDiskOpError;
//-- 2. read data to the scratch buffer and copy it to the descriptor.
ASSERT(ipScratchBuf);
TUint32 rem = dataLen;
while(rem)
{
const TUint32 bytesToRead = Min(KScratchBufSz, rem);
if(!ReadFile(iDevHandle, ipScratchBuf, bytesToRead, &dwBytesRead, NULL))
throw KDiskOpError;
aDataDes.Append(ipScratchBuf, bytesToRead);
rem-=bytesToRead;
}
}
catch(TInt nErrId)
{//-- some disk operation finished with the error
(void)nErrId;
ASSERT(nErrId == KDiskOpError);
const DWORD dwWinErr = GetLastError();
const TInt epocErr = MapWinError(dwWinErr);
__PRINT2(_L("#-- CWinImgFileDevice::Read() error! WinErr:%d, EpocErr:%d"), dwWinErr, epocErr);
ASSERT(epocErr != KErrNone);
return epocErr;
}
return KErrNone;
}
示例3: GetLocationValue
// ---------------------------------------------------------------------------
// TOMASuplLocationData::GetLocationValue
// (other items were commented in a header).
// ---------------------------------------------------------------------------
//
EXPORT_C void TOMASuplLocationData::GetLocationValue(TDes8& aLocationValue) const
{
if(aLocationValue.MaxLength() >= iLocationValue.Length())
aLocationValue.Copy(iLocationValue);
}
示例4: sizeof
/**
Get the capabilities of the device. This function is not called by the
Symbian OS. However can be used by the LDD to get the capabilities from
the device/hardware. There is no definition for encoding capabilities,
and is a matter of convention between the LDD and the PDD.
@param aDes
descriptor returned after filling with capabilities
*/
void DExDriverPhysicalDevice::GetCaps(TDes8& aDes) const
{
// Package buffer of TCommCapsV03. This creates a descriptor
// for the commcaps structure, and provide compatibility
// to use with API using descriptors
//
TCommCaps3 capsBuf;
// Retrieves the data structure from the package buffer
//
TCommCapsV03 &caps=capsBuf();
// Baud rates supported by the UART device. However, channel may
// be designed to support a subset of them as choice (applies to
// other configurations as well).
//
caps.iRate=KCapsBps110|KCapsBps150|KCapsBps300|KCapsBps600\
|KCapsBps1200|KCapsBps2400|KCapsBps4800|KCapsBps9600\
|KCapsBps19200|KCapsBps38400|KCapsBps57600|KCapsBps115200;
// Databit size
caps.iDataBits=KCapsData5|KCapsData6|KCapsData7|KCapsData8;
// Stop bits size supported
caps.iStopBits=KCapsStop1|KCapsStop2;
// Parity supported
caps.iParity=KCapsParityNone|KCapsParityEven|KCapsParityOdd|KCapsParityMark|KCapsParitySpace;
// Handshaking protocol supported by device
caps.iHandshake=KCapsObeyXoffSupported|KCapsSendXoffSupported|
KCapsObeyCTSSupported|KCapsFailCTSSupported|
KCapsObeyDSRSupported|KCapsFailDSRSupported|
KCapsObeyDCDSupported|KCapsFailDCDSupported|
KCapsFreeRTSSupported|KCapsFreeDTRSupported;
// Infrared mode
caps.iSIR=1;
// Signals supported
caps.iSignals=KCapsSignalCTSSupported|KCapsSignalRTSSupported|KCapsSignalDTRSupported|
KCapsSignalDSRSupported|KCapsSignalDCDSupported|KCapsSignalRNGSupported;
// FIFO enable/disable
caps.iFifo=KCapsHasFifo;
// Notifications supported
caps.iNotificationCaps=KNotifyDataAvailableSupported|KNotifySignalsChangeSupported;
caps.iRoleCaps=0;
caps.iFlowControlCaps=0;
// Break supported
caps.iBreakSupported=ETrue;
// [TDes8::MaxLength()] - Get the descriptor's length.
TInt len = aDes.MaxLength();
// [TDes8::FillZ(len)] -Fill the descriptor's data area with binary
// zeroes, replacing any existing data and change its length.
aDes.FillZ(len);
TInt size = sizeof(caps);
if (size>len)
size=len;
// [TDes8::Copy()] - Copy the data of length (size) into aDes descriptor
// replacing any existing data in the descriptor.
aDes.Copy((TUint8*)&caps, size);
aDes=capsBuf.Left(Min(capsBuf.Length(),aDes.MaxLength()));
}
示例5: Panic
TInt CBase64CodecBase::Encode(const TDesC8& aSource, TDes8& aResult) const
//
// Encode an arbitrary number of octets in aSource append the output to aResult.
// If the number of octets in aSource is not a multiple of 3
// padding will be added terminating the encoding
//
{
TInt sourceLength = aSource.Length();
if (sourceLength == 0)
return KErrNone;
__ASSERT_ALWAYS(((sourceLength * 4)/3 + sourceLength%3) <= (aResult.MaxLength()-aResult.Length()), Panic(EBase64Overflow));
sourceLength -= sourceLength%3;
TUint8 sixBit=NULL;
TText8 source;
TInt i;
for (i = 0; i < sourceLength; i++)
{
source=aSource[i];
sixBit = STATIC_CAST(TUint8,(source & 0xFC) >> 2);
aResult.Append(KBase64Alphabet[sixBit]);
sixBit = NULL;
sixBit = STATIC_CAST(TUint8,(source & 0x03) << 4);
source=aSource[++i];
sixBit |= STATIC_CAST(TUint8,(source & 0xF0) >> 4);
aResult.Append(KBase64Alphabet[sixBit]);
sixBit = NULL;
sixBit = STATIC_CAST(TUint8,(source & 0x0F) << 2);
source=aSource[++i];
sixBit |= STATIC_CAST(TUint8,(source & 0xC0) >> 6);
aResult.Append(KBase64Alphabet[sixBit]);
sixBit = NULL;
sixBit = STATIC_CAST(TUint8,(source & 0x3F));
aResult.Append(KBase64Alphabet[sixBit]);
}
switch (aSource.Length() % 3)
{
case 2:
source=aSource[i];
sixBit = STATIC_CAST(TUint8,(source & 0xFC) >> 2);
aResult.Append(KBase64Alphabet[sixBit]);
sixBit = NULL;
sixBit = STATIC_CAST(TUint8,(source & 0x03) << 4);
source=aSource[++i];
sixBit |= STATIC_CAST(TUint8,(source & 0xF0) >> 4);
aResult.Append(KBase64Alphabet[sixBit]);
sixBit = NULL;
sixBit = STATIC_CAST(TUint8,(source & 0x0F) << 2);
aResult.Append(KBase64Alphabet[sixBit]);
aResult.Append(KBase64Alphabet[KBase64Pad]);
break;
case 1:
source=aSource[i];
sixBit = STATIC_CAST(TUint8,(source & 0xFC) >> 2);
aResult.Append(KBase64Alphabet[sixBit]);
sixBit = NULL;
sixBit = STATIC_CAST(TUint8,(source & 0x03) << 4);
aResult.Append(KBase64Alphabet[sixBit]);
aResult.Append(KBase64Alphabet[KBase64Pad]);
aResult.Append(KBase64Alphabet[KBase64Pad]);
break;
default:
break;
}
return KErrNone;
}
示例6: ParseHeader
// -----------------------------------------------------------------------------
// CUpnpHttpChunkParser::ParseL
// Decoding the chunked-encoded buffer
// -----------------------------------------------------------------------------
//
TBool CUpnpHttpChunkParser::ParseHeader( TDes8& aBuffer, TInt& aPos )
{
if ( IsEmpty( aBuffer, aPos ) )
{
return ETrue;
}
iChunkSize = KErrNotFound;
iBytesAppended = 0;
TPtrC8 pointer(NULL,0);
//if '\r\n' exists
TInt lineFeed = aBuffer.Right( aBuffer.Length() - aPos ).FindF( UpnpString::KLineFeed );
//if ';' exists
TInt semiColon = aBuffer.Right( aBuffer.Length() - aPos ).FindF( UpnpString::KSemiColon );
//semicolon ignored if occurs after the linefeed
if ( semiColon !=KErrNotFound && lineFeed !=KErrNotFound && lineFeed<semiColon )
{
semiColon = KErrNotFound;
}
if ( semiColon !=KErrNotFound )
{
pointer.Set(aBuffer.Right( aBuffer.Length() - aPos ).Mid( 0,semiColon ) );
}
else if ( lineFeed !=KErrNotFound )
{
pointer.Set( aBuffer.Right( aBuffer.Length() - aPos ).Mid( 0,lineFeed ) );
}
else
{
pointer.Set( aBuffer.Right( aBuffer.Length() - aPos ) );
}
TLex8 lex( pointer );
//skip white spaces
lex.SkipSpace();
TUint size;
//neither semicolon nor linefeed found
if ( lineFeed == KErrNotFound && semiColon == KErrNotFound )
{
//remember the num of cut spaces
TInt len = lex.Offset();
if ( !lex.Eos() )
{
//check the chunk header size for the limit
TInt error = lex.Val( size, EHex );
if ( error!= KErrNone || size > KMaxTInt )
{
//size too big
iError = ( error ) ? error: EHttpInsufficientStorage;
iContext = EError;
return EFalse;
}
}
aBuffer.Delete( aPos,len );
return ETrue;
}
//get size
TInt error = lex.Val( size, EHex );
if ( error!= KErrNone || size > KMaxTInt )
{
//unexpected characters or size too big
iError = ( error ) ? error: EHttpInsufficientStorage ;
iContext = EError;
return EFalse;
}
iChunkSize = size;
//skip white spaces
lex.SkipSpace();
if ( !lex.Eos() )
{
//unexpected characters
iError = KErrGeneral;
iContext = EError;
return EFalse;
}
if ( lineFeed != KErrNotFound )
{
//the whole chunk header is parsed
aBuffer.Delete( aPos, lineFeed + UpnpString::KLineFeed().Length() );
//chunk size == 0
if ( !iChunkSize )
{
iContext = ELastChunk;
}
else
{
iContext = EBody;
}
return ( aPos == aBuffer.Length() );
}
else if ( semiColon != KErrNotFound )
{
//extension found,
//one character left - possible linefeed
//.........这里部分代码省略.........
示例7: UnPadL
void CPaddingNone::UnPadL(const TDesC8& aInput,TDes8& aOutput)
{
__ASSERT_DEBUG(aOutput.MaxLength() >= MaxPaddedLength(aInput.Length()), User::Panic(KCryptoPanic, ECryptoPanicOutputDescriptorOverflow));
aOutput.Append(aInput);
}
示例8: GetSipUri
/**
* Getter method to Get SIP URI
*/
EXPORT_C void COMASuplThirdpartyId::GetSipUri(TDes8& aSIPUri)
{
if(iSipUri && aSIPUri.MaxLength() >= iSipUri->Length())
aSIPUri.Copy(*iSipUri);
}
示例9: GetIMSPublicId
/**
* Getter method to Get IMS public id
*/
EXPORT_C void COMASuplThirdpartyId::GetIMSPublicId(TDes8& aPublicId)
{
if(iIMSPublicId && aPublicId.MaxLength() >= iIMSPublicId->Length())
aPublicId.Copy(*iIMSPublicId);
}
示例10: Write
TInt TClientRequest::Write(TInt aParam, const TDesC8& aDes, TInt aOffset) const
{
TDes8* desPtr = (TDes8*)iParams[aParam];
desPtr->Copy(aDes.Mid(aOffset));
return KErrNone;
}
示例11: GetMSISDN
/**
* Getter method to Get MSISDN
*/
EXPORT_C void COMASuplThirdpartyId::GetMSISDN(TDes8& aMSISDN)
{
if(aMSISDN.MaxLength() >= iMSISDN.Length())
aMSISDN.Copy(iMSISDN);
}
示例12: Read
void TClientRequest::Read(TInt aParam, TDes8& aDes, TInt aOffset) const
{
const TDesC8* desPtr = (const TDesC8*)iParams[aParam];
aDes.Copy(desPtr->Mid(aOffset));
}
示例13: passwordHash
inline void CPppMsChap2::GenerateAuthenticatorResponseL(
const TDesC16& aPassword,
const TDesC8& aNTResponse,
const TDesC8& aPeerChallenge,
const TDesC8& aAuthenticatorChallenge,
const TDesC8& aUserName,
TDes8& aAuthenticatorResponse)
/**
Generates the expected MS-CHAP-V2 Authenticator Response Value.
@param aPassword [in] The Microsoft Windows NT password (0 to 256
Unicode char).
@param aNTResponse [in] The MS-CHAP-V2 NT-Response (24 octets).
@param aPeerChallenge [in] The Peer Challenge (16 octets).
@param aAuthenticatorChallenge [in] The Authenticator Challenge (16
octets).
@param aUserName [in] The Microsoft Windows NT username (0 to 256
char).
@param aAuthenticatorResponse [out] The expected MS-CHAP-V2
Authenticator Response Value encoded in the format
"S=<auth_string>" as specified in RFC 2759 (42 octets).
@note This function implements the GenerateAuthenticatorResponse
routine specified in RFC 2759.
@internalComponent
*/
{
ASSERT(aPassword.Length()<=KPppMsChapMaxNTPasswordLength);
ASSERT(aNTResponse.Length() == KPppMsChap2NTResponseSize);
ASSERT(aPeerChallenge.Length() ==
KPppMsChap2PeerChallengeSize);
ASSERT(aAuthenticatorChallenge.Length() ==
KPppMsChap2AuthenticatorChallengeSize);
ASSERT(aUserName.Length()<=KPppMsChapMaxNTUserNameLength);
ASSERT(aAuthenticatorResponse.Length() ==
KPppMsChap2AuthenticatorResponseSize);
HBufC8* passwordHashBuf=HBufC8::NewMaxLC(KPppMsChap2HashSize);
TPtr8 passwordHash(passwordHashBuf->Des());
NtPasswordHashL(aPassword, passwordHash);
HashNtPasswordHashL(passwordHash, passwordHash);
CSHA1* sha1 = CSHA1::NewL();
CleanupStack::PushL(sha1);
// A magic string literal specified in RFC 2759 used in reponse
// generation by the GenerateAuthenticatorResponse routine for SHA-1
// encryption.
_LIT8(KMagic1, "Magic server to client signing constant");
sha1->Update(passwordHash);
sha1->Update(aNTResponse);
TPtrC8 hash(sha1->Final(KMagic1));
HBufC8* challengeHashBuf =
HBufC8::NewMaxLC(KPppMsChap2ChallengeHashSize);
TPtr8 challengeHash(challengeHashBuf->Des());
ChallengeHashL(aPeerChallenge,
aAuthenticatorChallenge,
aUserName,
challengeHash);
// Another magic string literal specified in RFC 2759 used in reponse
// generation by the GenerateAuthenticatorResponse routine for SHA-1
// encryption.
_LIT8(KMagic2, "Pad to make it do more than one iteration");
sha1->Update(hash);
sha1->Update(challengeHash);
const TUint8* pHash = sha1->Final(KMagic2).Ptr();
_LIT8(KFormat,
"S=%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X"
"%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X");
aAuthenticatorResponse.Format(KFormat,
*pHash,
*(pHash + 1),
*(pHash + 2),
*(pHash + 3),
*(pHash + 4),
*(pHash + 5),
*(pHash + 6),
*(pHash + 7),
*(pHash + 8),
*(pHash + 9),
*(pHash + 10),
*(pHash + 11),
*(pHash + 12),
*(pHash + 13),
*(pHash + 14),
*(pHash + 15),
*(pHash + 16),
*(pHash + 17),
*(pHash + 18),
*(pHash + 19));
//.........这里部分代码省略.........
示例14: input
inline void CPppMsChap2::ProcessFailureMessageL(
const TDesC8& aFailureMessage,
TUint& aErrorCode,
TUint8& aRetryFlag,
TDes8& aAuthChallenge,
TUint8& aPasswordProtoVersion,
TPtrC8& aMessage)
/**
Processes a MS-CHAP-V2 Failure Message.
@param aFailureMessage [in] A MS-CHAP-V2 Failure Message. The
Failure Message needs to be in the format specified in RFC 2759:
"E=eeeeeeeeee R=r C=cccccccccccccccccccccccccccccccc V=vvvvvvvvvv
M=<msg>".
@param aErrorCode [out] The MS-CHAP-V2 Failure error code.
@param aRetryFlag [out] The retry flag. The flag will be set to
"1" if a retry is allowed, and "0" if not. When the authenticator
sets this flag to "1" it disables short timeouts, expecting the
peer to prompt the user for new credentials and resubmit the
response.
@param aAuthChallenge [out] The new Authenticator Challenge Value.
@param aPasswordProtoVersion [out] The password changing protocol
supported by the peer.
@param aMessage [out] A failure text message.
@internalComponent
*/
{
ASSERT(aAuthChallenge.Length() ==
KPppMsChap2AuthenticatorChallengeSize);
TLex8 input(aFailureMessage);
if (input.Get() != 'E')
User::Leave(KErrGeneral);
if (input.Get() != '=')
User::Leave(KErrGeneral);
// RFC 2759: ""eeeeeeeeee" is the ASCII representation of a decimal
// error code (need not be 10 digits) corresponding to one of those
// listed below, though implementations should deal with codes not on
// this list gracefully."
TInt ret;
if ((ret = input.Val(aErrorCode))!=KErrNone)
if (ret!= KErrOverflow)
User::Leave(KErrGeneral);
else
// Gracefully handle unusually large, yet valid, MS-CHAP-V2 specific
// error code values. This code only handles the MS-CHAP-V2 specific
// error code values specified in RFC 2759.
aErrorCode=0;
input.SkipSpace();
if (input.Get() != 'R')
User::Leave(KErrGeneral);
if (input.Get() != '=')
User::Leave(KErrGeneral);
if (input.Val(aRetryFlag, EDecimal)!=KErrNone)
User::Leave(KErrGeneral);
input.SkipSpace();
if (input.Get() != 'C')
User::Leave(KErrGeneral);
if (input.Get() != '=')
User::Leave(KErrGeneral);
TPtrC8 token(input.NextToken());
// This field is 32 hexadecimal digits representing an ASCII
// representation of a new challenge value. Each octet is represented
// in 2 hexadecimal digits.
if (token.Length() != KPppMsChap2AuthenticatorChallengeSize*2)
User::Leave(KErrGeneral);
TLex8 lex;
TUint8 octet;
TUint8* pChallengeOctet =
const_cast<TUint8*>(aAuthChallenge.Ptr());
TUint8 i = 0;
do
{
lex.Assign(token.Mid(i*2, 2));
if (lex.Val(octet, EHex) != KErrNone)
User::Leave(KErrGeneral);
*(pChallengeOctet + i) = octet;
}
while (++i < KPppMsChap2AuthenticatorChallengeSize);
input.SkipSpace();
if (input.Get() != 'V')
User::Leave(KErrGeneral);
//.........这里部分代码省略.........
示例15: ProcessFailureMessageL
inline void CPppMsChap::ProcessFailureMessageL(
const TDesC8& aFailureMessage,
TUint& aErrorCode,
TUint8& aRetryFlag,
TBool& aHasNewChallenge,
TDes8& aChallenge,
TUint8& aPasswordProtoVersion)
/**
Processes a MS-CHAP Failure Message.
@param aFailureMessage [in] A MS-CHAP Failure Message. The Failure
Message needs to be in the format specified in RFC 2433:
"E=eeeeeeeeee R=r C=cccccccccccccccc V=vvvvvvvvvv".
@param aErrorCode [out] The MS-CHAP Failure error code.
@param aRetryFlag [out] The retry flag. The flag will be set to
"1" if a retry is allowed, and "0" if not. When the authenticator
sets this flag to "1" it disables short timeouts, expecting the
peer to prompt the user for new credentials and resubmit the
response.
@param aHasNewChallenge [out] The flag that indicates if the
Failure Message contains a new Challenge Value.
@param aChallenge [out] The new Challenge Value, if the Failure
Message contains a one.
@param aPasswordProtoVersion [out] The password changing protocol
supported by the peer.
@internalComponent
*/
{
ASSERT(aChallenge.Length() == KPppMsChapChallengeSize);
TLex8 input(aFailureMessage);
if (input.Get() != 'E')
User::Leave(KErrGeneral);
if (input.Get() != '=')
User::Leave(KErrGeneral);
// RFC 2433: ""eeeeeeeeee" is the ASCII representation of a decimal
// error code (need not be 10 digits) corresponding to one of those
// listed below, though implementations should deal with codes not on
// this list gracefully."
TInt ret;
if ((ret = input.Val(aErrorCode)) != KErrNone)
if (ret != KErrOverflow)
User::Leave(KErrGeneral);
else
// Gracefully handle unusually large, yet valid, MS-CHAP specific
// error code values. This code only handles the MS-CHAP specific
// error code values specified in RFC 2433.
aErrorCode=0;
input.SkipSpace();
if (input.Get() != 'R')
User::Leave(KErrGeneral);
if (input.Get() != '=')
User::Leave(KErrGeneral);
if (input.Val(aRetryFlag, EDecimal)!=KErrNone)
User::Leave(KErrGeneral);
input.SkipSpace();
switch (input.Get())
{
case 'C':
{
if (input.Get() != '=')
User::Leave(KErrGeneral);
TPtrC8 token(input.NextToken());
// This field is 16 hexadecimal digits representing an ASCII
// representation of a new challenge value. Each octet is represented
// in 2 hexadecimal digits.
if (token.Length() != KPppMsChapChallengeSize*2)
User::Leave(KErrGeneral);
TLex8 lex;
TUint8 octet;
TUint8* pChallengeOctet =
const_cast<TUint8*>(aChallenge.Ptr());
TUint8 i = 0;
do
{
lex.Assign(token.Mid(i*2, 2));
if (lex.Val(octet, EHex) != KErrNone)
User::Leave(KErrGeneral);
*(pChallengeOctet + i) = octet;
}
while (++i < KPppMsChapChallengeSize);
aHasNewChallenge = ETrue;
input.SkipSpace();
//.........这里部分代码省略.........