contextframework/cfw/src/cfserver/cfasynccmdqueue.cpp
author William Roberts <williamr@symbian.org>
Mon, 08 Mar 2010 21:43:36 +0000
branchCompilerCompatibility
changeset 6 10da190cf381
parent 0 2e3d3ce01487
permissions -rw-r--r--
Create CompilerCompatibility branch

/*
* Copyright (c) 2008 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:  CCFAsyncCmdQueue implementation.
*
*/


// SYSTEM INCLUDES

// USER INCLUDES
#include "cfasynccmdqueue.h"
#include "cfcmd.h"
#include "cftrace.h"

// ======== MEMBER FUNCTIONS ========

// ---------------------------------------------------------------------------
// C++ constructor.
// ---------------------------------------------------------------------------
//
CCFAsyncCmdQueue::CCFAsyncCmdQueue()
    :   CActive( EPriorityHigh ),
        iQueue( CCFCmd::SglQueLinkOffset() ),
        iQueueIter( iQueue )
    {
    FUNC_LOG;

    CActiveScheduler::Add( this );
    }

// ---------------------------------------------------------------------------
// Symbian two phased constructor.
// ---------------------------------------------------------------------------
//
CCFAsyncCmdQueue* CCFAsyncCmdQueue::NewL( )
    {
    FUNC_LOG;

    CCFAsyncCmdQueue* self = CCFAsyncCmdQueue::NewLC();
    CleanupStack::Pop( self );
    return self;
    }

// ---------------------------------------------------------------------------
// Symbian two phased constructor.
// Leaves pointer in the cleanup stack.
// ---------------------------------------------------------------------------
//
CCFAsyncCmdQueue* CCFAsyncCmdQueue::NewLC()
    {
    FUNC_LOG;

    CCFAsyncCmdQueue* self = new( ELeave ) CCFAsyncCmdQueue();
    CleanupStack::PushL( self );
    return self;
    }

// ---------------------------------------------------------------------------
// C++ destructor.
// ---------------------------------------------------------------------------
//
CCFAsyncCmdQueue::~CCFAsyncCmdQueue()
    {
    FUNC_LOG;

    Cancel();
    if ( !iQueue.IsEmpty() )
        {
        CCFCmd* cmd = NULL;
        iQueueIter.SetToFirst(); 
        while ( ( cmd = iQueueIter++ ) != NULL )
            {
            iQueue.Remove( *cmd );
            delete cmd;
            }
        }
    delete iCurrentCmd;
    }


// ---------------------------------------------------------------------------
// CCFAsyncCmdQueue::Add
// ---------------------------------------------------------------------------
//
void CCFAsyncCmdQueue::Add( CCFCmd* aCmd )
    {
    FUNC_LOG;

    iQueue.AddLast( *aCmd );
    Activate();
    }

// ---------------------------------------------------------------------------
// CCFAsyncCmdQueue::AddFirst
// ---------------------------------------------------------------------------
//
void CCFAsyncCmdQueue::AddFirst( CCFCmd* aCmd )
    {
    FUNC_LOG;

    iQueue.AddFirst( *aCmd );
    Activate();
    }


// ---------------------------------------------------------------------------
// CCFAsyncCmdQueue::DoCancel
// ---------------------------------------------------------------------------
//
void CCFAsyncCmdQueue::DoCancel()
    {
    FUNC_LOG;
    // Nothing to do.
    }

// ---------------------------------------------------------------------------
// CCFAsyncCmdQueue::RunL
// ---------------------------------------------------------------------------
//
void CCFAsyncCmdQueue::RunL()
    {
    FUNC_LOG;

    if ( !iQueue.IsEmpty() )
        {
        iCurrentCmd = iQueue.First();
        iQueue.Remove( *iCurrentCmd );
        iCurrentCmd->ExecuteL();
        delete iCurrentCmd;
        iCurrentCmd = NULL;
        }

    Activate();
    }

// ---------------------------------------------------------------------------
// CCFAsyncCmdQueue::RunError
// ---------------------------------------------------------------------------
//
TInt CCFAsyncCmdQueue::RunError( TInt aError )
    {
    FUNC_LOG;

    if ( iCurrentCmd )
        {
        iCurrentCmd->LogError( aError );
        delete iCurrentCmd;
        iCurrentCmd = NULL;
        }

    ERROR( aError, "CCFAsyncCmdQueue::RunError - Ignoring the error" );

    Activate();

    return KErrNone; // Ignore errors.
    }

// -----------------------------------------------------------------------------
// CCFAsyncCmdQueue::Activate
// -----------------------------------------------------------------------------
//
void CCFAsyncCmdQueue::Activate()
    {
    FUNC_LOG;

    if ( !IsActive() && !iQueue.IsEmpty() )
        {
        iStatus = KRequestPending;
        SetActive();
        TRequestStatus* status = &iStatus;
        User::RequestComplete( status, KErrNone );
        }
    }

// End of file