diff -r 000000000000 -r 164170e6151a wim/Scard/src/ScardConnectionTimer.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/wim/Scard/src/ScardConnectionTimer.cpp Tue Jan 26 15:20:08 2010 +0200 @@ -0,0 +1,135 @@ +/* +* Copyright (c) 2003 Nokia Corporation and/or its subsidiary(-ies). +* All rights reserved. +* This component and the accompanying materials are made available +* under the terms of "Eclipse Public License v1.0" +* which accompanies this distribution, and is available +* at the URL "http://www.eclipse.org/legal/epl-v10.html". +* +* Initial Contributors: +* Nokia Corporation - initial contribution. +* +* Contributors: +* +* Description: Timer for connections to smartcard +* +*/ + + + +// INCLUDE FILES +#include "ScardConnector.h" +#include "ScardConnectionTimer.h" +#include "WimTrace.h" + +#ifdef _DEBUG // for logging +#include "ScardLogs.h" +#include +#endif + + +// ============================ MEMBER FUNCTIONS =============================== + +// ----------------------------------------------------------------------------- +// CScardConnectionTimer::CScardConnectionTimer +// C++ default constructor can NOT contain any code, that +// might leave. +// ----------------------------------------------------------------------------- +// +CScardConnectionTimer::CScardConnectionTimer( + CScardConnector* aConnector, + TInt32 aTimeOut ) + : CActive( EPriorityNormal ), + iTimeOut( aTimeOut ), + iConnector( aConnector ) + { + _WIMTRACE(_L("WIM|Scard|CScardConnectionTimer::CScardConnectionTimer|Begin")); + CActiveScheduler::Add( this ); + } + +// ----------------------------------------------------------------------------- +// CScardConnectionTimer::ConstructL +// Symbian 2nd phase constructor can leave. +// ----------------------------------------------------------------------------- +// +void CScardConnectionTimer::ConstructL() + { + _WIMTRACE(_L("WIM|Scard|CScardConnectionTimer::ConstructL|Begin")); + iTimer = new( ELeave ) RTimer; + iTimer->CreateLocal(); +#ifdef _DEBUG + RFileLogger::WriteFormat( KScardLogDir, KScardLogFileName, + EFileLoggingModeAppend, + _L( "CScardConnectionTimer::ConstructL\n" ) ); +#endif + iTimer->After( iStatus, iTimeOut ); + SetActive(); + } + +// ----------------------------------------------------------------------------- +// CScardConnectionTimer::NewL +// Two-phased constructor. +// ----------------------------------------------------------------------------- +// +CScardConnectionTimer* CScardConnectionTimer::NewL( + CScardConnector* aConnector, + TInt32 aTimeOut ) + { + _WIMTRACE(_L("WIM|Scard|CScardConnectionTimer::NewL|Begin")); + __ASSERT_ALWAYS( aTimeOut >= 0, User::Leave( KScErrBadArgument ) ); + CScardConnectionTimer* self = new( ELeave ) CScardConnectionTimer( + aConnector, aTimeOut ); + + CleanupStack::PushL( self ); + self->ConstructL(); + CleanupStack::Pop( self ); + + return self; + } + + +// Destructor +CScardConnectionTimer::~CScardConnectionTimer() + { + _WIMTRACE(_L("WIM|Scard|CScardConnectionTimer::~CScardConnectionTimer|Begin")); +#ifdef _DEBUG + RFileLogger::WriteFormat( KScardLogDir, KScardLogFileName, + EFileLoggingModeAppend, + _L( "CScardConnectionTimer::Destructor\n" ) ); +#endif + Cancel(); + delete iTimer; + } + + +// ----------------------------------------------------------------------------- +// CScardConnectionTimer::RunL +// ----------------------------------------------------------------------------- +// +void CScardConnectionTimer::RunL() + { + _WIMTRACE(_L("WIM|Scard|CScardConnectionTimer::RunL|Begin")); +#ifdef _DEBUG + RFileLogger::WriteFormat( KScardLogDir, KScardLogFileName, + EFileLoggingModeAppend, + _L( "CScardConnectionTimer::RunL\n" ) ); +#endif + iConnector->ConnectionTimedOut(); + } + +// ----------------------------------------------------------------------------- +// CScardConnectionTimer::DoCancel +// ----------------------------------------------------------------------------- +// +void CScardConnectionTimer::DoCancel() + { + _WIMTRACE(_L("WIM|Scard|CScardConnectionTimer::DoCancel|Begin")); +#ifdef _DEBUG + RFileLogger::WriteFormat( KScardLogDir, KScardLogFileName, + EFileLoggingModeAppend, + _L( "CScardConnectionTimer::DoCancel\n" ) ); +#endif + iTimer->Cancel(); + } + +// End of File