videoutils_plat/videoconnutility_api/tsrc/VCXTestCommon/src/VCXTestMessageWait.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 26 Jan 2010 12:55:56 +0200
changeset 3 bdf78597b41c
parent 0 822a42b6c3f1
permissions -rw-r--r--
Revision: 201001 Kit: 201004

/*
* 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 the License "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: 
*
*/


// INCLUDE FILES
#include "VCXTestMessageWait.h"
#include "VCXTestLog.h"
#include "CIptvTestActiveWait.h"
#include "CIptvTestTimer.h"

// EXTERNAL DATA STRUCTURES

// EXTERNAL FUNCTION PROTOTYPES

// CONSTANTS
const TInt KTimeoutSecond = 1000000;

// MACROS

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

// -----------------------------------------------------------------------------
// CVCXTestMessageWait::
// C++ default constructor can NOT contain any code, that
// might leave.
// -----------------------------------------------------------------------------
//
EXPORT_C CVCXTestMessageWait* CVCXTestMessageWait::NewL( MVCXTestMessageWaitObserver* aObserver )
    {
    VCXLOGLO1(">>>CVCXTestMessageWait::NewL");
    CVCXTestMessageWait* self = new (ELeave) CVCXTestMessageWait( aObserver );
    CleanupStack::PushL(self);
    self->ConstructL();
    CleanupStack::Pop();
    VCXLOGLO1("<<<CVCXTestMessageWait::NewL");
    return self;
    }

// -----------------------------------------------------------------------------
// CVCXTestMessageWait::~CVCXTestMessageWait
// destructor
// -----------------------------------------------------------------------------
//
EXPORT_C CVCXTestMessageWait::~CVCXTestMessageWait()
    {
    VCXLOGLO1(">>>CVCXTestMessageWait::~CVCXTestMessageWait");
    
    iActiveWaitBlocking->Stop();
    delete iActiveWaitBlocking;
    iActiveWaitBlocking = NULL;

    if( iTimeoutTimer )
        {
        iTimeoutTimer->CancelTimer();
        delete iTimeoutTimer;
        iTimeoutTimer = NULL;
        }

    iReceivedMessages.Reset();
    iWaitedMessages.Reset();
    
    VCXLOGLO1("<<<CVCXTestMessageWait::~CVCXTestMessageWait");
    }

// -----------------------------------------------------------------------------
// CVCXTestMessageWait::~CVCXTestMessageWait
// destructor
// -----------------------------------------------------------------------------
//
EXPORT_C CVCXTestMessageWait::CVCXTestMessageWait( MVCXTestMessageWaitObserver* aObserver )
 : iObserver( aObserver )
    {
    VCXLOGLO1(">>>CVCXTestMessageWait::CVCXTestMessageWait");

    VCXLOGLO1("<<<CVCXTestMessageWait::CVCXTestMessageWait");
    }

// -----------------------------------------------------------------------------
// CVCXTestMessageWait::ConstructL
// -----------------------------------------------------------------------------
//
EXPORT_C void CVCXTestMessageWait::ConstructL()
    {
    VCXLOGLO1(">>>CVCXTestMessageWait::ConstructL");
    
    iActiveWaitBlocking = CIptvTestActiveWait::NewL();
    iTimeoutTimer = CIptvTestTimer::NewL(*this, 0);

    VCXLOGLO1("<<<CVCXTestMessageWait::ConstructL");
    }

// -----------------------------------------------------------------------------
// CVCXTestMessageWait::Reset
// -----------------------------------------------------------------------------
//
EXPORT_C void CVCXTestMessageWait::Reset()
    {
    VCXLOGLO1(">>>CVCXTestMessageWait::Reset");
    iCoolingDown = EFalse;
    iWaitStarted = EFalse;
    iWaitedMessages.Reset();
    iReceivedMessages.Reset();
    iTimeoutTimer->Cancel();
    iActiveWaitBlocking->Stop();
    VCXLOGLO1("<<<CVCXTestMessageWait::Reset");
    }

// -----------------------------------------------------------------------------
// CVCXTestMessageWait::ResetReceivedMessages
// -----------------------------------------------------------------------------
//
EXPORT_C void CVCXTestMessageWait::ResetReceivedMessages()
	{
    VCXLOGLO1(">>>CVCXTestMessageWait::ResetReceivedMessages");
    iReceivedMessages.Reset();    
    VCXLOGLO1("<<<CVCXTestMessageWait::ResetReceivedMessages");
	}

// -----------------------------------------------------------------------------
// CVCXTestMessageWait::AddMessage
// -----------------------------------------------------------------------------
//
EXPORT_C void CVCXTestMessageWait::AddMessage( TInt32 aMsg )
    {
    VCXLOGLO1(">>>CVCXTestMessageWait::AddMessage");
    iWaitedMessages.Append( aMsg );    
    VCXLOGLO1("<<<CVCXTestMessageWait::AddMessage");
    }

// -----------------------------------------------------------------------------
// CVCXTestMessageWait::WaitForMessageL
// -----------------------------------------------------------------------------
//
EXPORT_C void CVCXTestMessageWait::WaitForMessageL( TInt32 aMsg, TInt aTimeoutSeconds, TBool aDoBlock )
	{
    VCXLOGLO1(">>>CVCXTestMessageWait::WaitForMessageL");

    iWaitedMessages.Reset();
    iWaitedMessages.Append( aMsg );
    
    iTimeoutSeconds = aTimeoutSeconds;
    WaitForAllL( aTimeoutSeconds, aDoBlock );
    
    VCXLOGLO1("<<<CVCXTestMessageWait::WaitForMessageL");
	}

// -----------------------------------------------------------------------------
// CVCXTestMessageWait::WaitForAllL
// -----------------------------------------------------------------------------
//
EXPORT_C void CVCXTestMessageWait::WaitForAllL( TInt aTimeoutSeconds, TBool aDoBlock )
	{
    VCXLOGLO1(">>>CVCXTestMessageWait::WaitForAllL");

    iWaitStarted = ETrue;
    
    iTimeoutSeconds = aTimeoutSeconds;
    
    // Nothing to wait.
    if( iWaitedMessages.Count() <= 0 )
        {
        VCXLOGLO1("<<<CVCXTestMessageWait::WaitForAllL");
        User::Leave( KErrNotReady );
        }    
    
    // Check already received messages.
    for( TInt i = iReceivedMessages.Count()-1; i >= 0; i-- )
        {
        for( TInt e = iWaitedMessages.Count()-1; e >= 0; e-- )
            {
            if( iReceivedMessages[i] == iWaitedMessages[e] )
                {
                iWaitedMessages.Remove( e );
                iReceivedMessages.Remove( i );
                break;
                }
            }
        }
    
    if( iWaitedMessages.Count() > 0 )
        {
        // There's messages to wait. Start timeout timer.
        iTimeoutTimer->After( aTimeoutSeconds * KTimeoutSecond );
    
        // Client wants blocking call.
        if( aDoBlock )
            {
            iActiveWaitBlocking->Start();
            User::LeaveIfError( iError );
            }
        }
    else
        {
        iWaitStarted = EFalse;
        
        // Nothing to wait for.
        iTimeoutTimer->CancelTimer();
        
        // Not blocking, inform client with callback.
        if( !aDoBlock )
            {
            iObserver->MessageWaitComplete( KErrNone );
            }
        }
    
    VCXLOGLO1("<<<CVCXTestMessageWait::WaitForAllL");
	}

// -----------------------------------------------------------------------------
// CVCXTestMessageWait::CoolDownL
// -----------------------------------------------------------------------------
//
EXPORT_C void CVCXTestMessageWait::CoolDownL( TInt aSeconds )
    {
    VCXLOGLO1(">>>CVCXTestMessageWait::CoolDownL");

    Reset();
    
    iTimeoutSeconds = aSeconds;
    
    iCoolingDown = ETrue;
    
    iTimeoutTimer->After( iTimeoutSeconds * KTimeoutSecond );
    
    iActiveWaitBlocking->Start();
        
    VCXLOGLO1("<<<CVCXTestMessageWait::CoolDownL");
    }

// -----------------------------------------------------------------------------
// CVCXTestMessageWait::ReceiveMessage
// -----------------------------------------------------------------------------
//
EXPORT_C void CVCXTestMessageWait::ReceiveMessage( TInt32 aMsg, TInt aError )
	{
    if( !iWaitStarted )
        {
        VCXLOGLO1("CVCXTestMessageWait::ReceiveMessage: Wait not active.");
        return;
        }

    VCXLOGLO1(">>>CVCXTestMessageWait::ReceiveMessage");

    if( aError != KErrNone )
        {
        iWaitStarted = EFalse;
        if( iActiveWaitBlocking->IsWaiting() )
            {
            iError = aError;
            iActiveWaitBlocking->Stop();
            }
        else
            {
            iObserver->MessageWaitComplete( aError );
            }
        iTimeoutTimer->CancelTimer();
        VCXLOGLO1("<<<CVCXTestMessageWait::ReceiveMessage");
        return;
        }
    
    if( iCoolingDown ) 
        {
        iTimeoutTimer->After( iTimeoutSeconds * KTimeoutSecond );
        VCXLOGLO1("<<<CVCXTestMessageWait::ReceiveMessage");
        return;
        }
    
    if( !iWaitStarted ) 
        {
        iReceivedMessages.Append( aMsg );
        VCXLOGLO1("<<<CVCXTestMessageWait::ReceiveMessage");
        return;
        }

    if( iWaitedMessages.Count() > 0 )
        {
        // Check if message is in wait queue.
        for( TInt i = iWaitedMessages.Count()-1; i >= 0; i-- )
            {
            if( iWaitedMessages[i] == aMsg )
                {
                iWaitedMessages.Remove( i );
                break;
                }
            }
        
        if( iWaitedMessages.Count() <= 0 )
            {
            iWaitStarted = EFalse;
            // Stop wait.
            if( iActiveWaitBlocking->IsWaiting() )
                {
                iError = KErrNone;
                iActiveWaitBlocking->Stop();
                }
            // Not waiting, client wants callback.
            else
                {
                iObserver->MessageWaitComplete( KErrNone );
                }
            // Stop timer too.
            iTimeoutTimer->CancelTimer();
            }
        }
    
    VCXLOGLO1("<<<CVCXTestMessageWait::ReceiveMessage");
	}

// -----------------------------------------------------------------------------
// CVCXTestMessageWait::TimerComplete
// -----------------------------------------------------------------------------
//
void CVCXTestMessageWait::TimerComplete( TInt /* aTimerId */, TInt aError )
    {
    if( aError != KErrCancel )
        {
        if( iCoolingDown )
            {
            VCXLOGLO1("CVCXTestMessageWait:: Cooldown done.");
            iActiveWaitBlocking->Stop();
            iCoolingDown = EFalse;
            }
        else
        if( iWaitedMessages.Count() > 0 )
            {
            iWaitStarted = EFalse;
            VCXLOGLO2("CVCXTestMessageWait:: Timeout. Messages left: %d", iWaitedMessages.Count());
            if( iActiveWaitBlocking->IsWaiting() )
                {
                iActiveWaitBlocking->Stop();
                iError = KErrTimedOut;
                }
            else
                {
                // Client wants callback.
                iObserver->MessageWaitComplete( KErrTimedOut );
                }
            }
        }
    }

//  End of File