wim/Scard/src/ScardConnectionTimer.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 31 Aug 2010 16:04:40 +0300
branchRCL_3
changeset 21 09b1ac925e3f
parent 0 164170e6151a
permissions -rw-r--r--
Revision: 201033 Kit: 201035

/*
* 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