ipsservices/ipssosplugin/src/ipsplgtimeroperation.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Thu, 27 May 2010 12:43:55 +0300
changeset 27 9ba4404ef423
parent 0 8466d47a6819
permissions -rw-r--r--
Revision: 201019 Kit: 2010121

/*
* Copyright (c) 2006 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: 
*       Simple Timer Operation. Completes observer when time expires
*
*/



#include "emailtrace.h"
#include "ipsplgheaders.h"

const TUint KIdleTimeout = 300000000;//5min
const TInt KIpsPlgTimerPriority = CActive::EPriorityIdle;

CIpsPlgTimerOperation* CIpsPlgTimerOperation::NewL(
    TFSMailMsgId aMailboxId,
    MIpsPlgTimerOperationCallBack& aObserver )
    {
    FUNC_LOG;
    CIpsPlgTimerOperation* self = new( ELeave ) CIpsPlgTimerOperation(
        aMailboxId, aObserver );
    CleanupStack::PushL( self );
    self->ConstructL( );
    CleanupStack::Pop( self );
    return self;
    }

// ----------------------------------------------------------------------------
// ----------------------------------------------------------------------------
CIpsPlgTimerOperation::CIpsPlgTimerOperation(
    TFSMailMsgId aMailboxId,
    MIpsPlgTimerOperationCallBack& aObserver ) : 
        CActive( KIpsPlgTimerPriority ), 
        iMailboxId( aMailboxId ), iObserver(aObserver), 
        iStateReActivate( EFalse )
    {
    FUNC_LOG;
    }

// ----------------------------------------------------------------------------
// ----------------------------------------------------------------------------
CIpsPlgTimerOperation::~CIpsPlgTimerOperation()
    {
    FUNC_LOG;
    Cancel();
    iTimer.Close();
    }

// ----------------------------------------------------------------------------
// ----------------------------------------------------------------------------
void CIpsPlgTimerOperation::ConstructL()
    {
    FUNC_LOG;
    User::LeaveIfError( iTimer.CreateLocal() );
    CActiveScheduler::Add(this);
    }

// ----------------------------------------------------------------------------
// ----------------------------------------------------------------------------
void CIpsPlgTimerOperation::After(TTimeIntervalMicroSeconds32 aInterval)
    {
    FUNC_LOG;
    Cancel();
    iTimer.After(iStatus, aInterval);
    SetActive();
    }
    
    
// ----------------------------------------------------------------------------
// ----------------------------------------------------------------------------
void CIpsPlgTimerOperation::DoCancel()
    {
    FUNC_LOG;
    iTimer.Cancel();
    iStateReActivate = EFalse;
    }

// ----------------------------------------------------------------------------
// ----------------------------------------------------------------------------
void CIpsPlgTimerOperation::RunL()
    {
    FUNC_LOG;
    // cancel is normal code when re-activating timer
    if ( iStateReActivate )
        {
        iTimer.Cancel();
        iTimer.After(iStatus, KIdleTimeout);
        SetActive();
        iStateReActivate = EFalse;
        }
    else
        {
        iObserver.HandleTimerFiredL( iMailboxId );
        }
    }
    
// ----------------------------------------------------------------------------
// ----------------------------------------------------------------------------
void CIpsPlgTimerOperation::ResetTimerOperation()
    {
    FUNC_LOG;
    if ( iStateReActivate )
        {
        // already re-active state
        return;
        }
    else if ( IsActive() )
        {
        iTimer.Cancel();
        iStateReActivate = ETrue;
        }
    else 
        {
        iTimer.After( iStatus, KIdleTimeout );
        SetActive();
        }
    }

// ----------------------------------------------------------------------------
// ----------------------------------------------------------------------------
TFSMailMsgId CIpsPlgTimerOperation::FSMailboxId() const
    {
    FUNC_LOG;

    return iMailboxId;
    }


    
//EOF