--- /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 <flogger.h>
+#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