satengine/SatServer/EventMonitors/src/CSatBIPDataAvailableMonitor.cpp
author hgs
Mon, 23 Aug 2010 15:50:31 +0300
changeset 42 35488577e233
parent 0 ff3b6d0fd310
permissions -rw-r--r--
201033

/*
* Copyright (c) 2002-2007 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:  Monitor for Data available
*
*/


// INCLUDE FILES
#include    "CSatBIPDataAvailableMonitor.h"
#include    "MSatEventMonitorUtils.h"
#include    "MSatBIPEventNotifier.h"
#include    "SatLog.h"

// ============================ MEMBER FUNCTIONS ===============================
// -----------------------------------------------------------------------------
// CSatBIPDataAvailableMonitor::CSatBIPDataAvailableMonitor
// C++ default constructor can NOT contain any code, that
// might leave.
// -----------------------------------------------------------------------------
//
CSatBIPDataAvailableMonitor::CSatBIPDataAvailableMonitor(
    MSatEventMonitorUtils& aUtils ) :
    CSatEventMonitorHandler( aUtils )
    {
    LOG( SIMPLE, "SATEVENTMONITORS: CSatBIPDataAvailableMonitor::\
        CSatBIPDataAvailableMonitor calling-exiting" )
    }

// Destructor
CSatBIPDataAvailableMonitor::~CSatBIPDataAvailableMonitor()
    {
    LOG( SIMPLE, "SATEVENTMONITORS: CSatBIPDataAvailableMonitor::\
        ~CSatBIPDataAvailableMonitor calling-exiting" )
    }

// -----------------------------------------------------------------------------
// CSatBIPDataAvailableMonitor::NewL
// Two-phased constructor.
// -----------------------------------------------------------------------------
//
CSatBIPDataAvailableMonitor* CSatBIPDataAvailableMonitor::NewL(
    MSatEventMonitorUtils& aUtils )
    {
    LOG( SIMPLE,
        "SATEVENTMONITORS: CSatBIPDataAvailableMonitor::NewL calling" )

    CSatBIPDataAvailableMonitor* self =
        new( ELeave ) CSatBIPDataAvailableMonitor( aUtils );
    CleanupStack::PushL( self );
    self->ConstructL();
    CleanupStack::Pop( self );

    LOG( SIMPLE,
        "SATEVENTMONITORS: CSatBIPDataAvailableMonitor::NewL exiting" )
    return self;
    }

// -----------------------------------------------------------------------------
// CSatBIPDataAvailableMonitor::ConstructL
// Symbian 2nd phase constructor can leave.
// -----------------------------------------------------------------------------
//
void CSatBIPDataAvailableMonitor::ConstructL()
    {
    LOG( SIMPLE,
        "SATEVENTMONITORS: CSatBIPDataAvailableMonitor::ConstructL calling" )

    // Create base class and give this monitors event as a parameter
    BaseConstructL( MSatEventMonitor::EDataAvailable );
    iIsActive = EFalse;

    LOG( SIMPLE,
        "SATEVENTMONITORS: CSatBIPDataAvailableMonitor::ConstructL exiting" )
    }

// -----------------------------------------------------------------------------
// CSatBIPDataAvailableMonitor::DoCancelMonitor
// Cancels monitor.
// -----------------------------------------------------------------------------
//
void CSatBIPDataAvailableMonitor::DoCancelMonitor()
    {
    LOG( SIMPLE, "SATEVENTMONITORS: CSatBIPDataAvailableMonitor::\
        DoCancelMonitor calling" )

    if ( iIsActive )
        {
        LOG( NORMAL, "SATEVENTMONITORS: CSatBIPDataAvailableMonitor::\
            DoCancelMonitor Canceling monitor" )
        // Call MSatBIPEventNotifier.CancelDataAvailable
        iEventUtils.BipNotifier().CancelDataAvailable();
        }

    LOG( SIMPLE, "SATEVENTMONITORS: CSatBIPDataAvailableMonitor::\
        DoCancelMonitor exiting" )
    }

// -----------------------------------------------------------------------------
// CSatBIPDataAvailableMonitor::StartMonitor
// Starts monitor.
// -----------------------------------------------------------------------------
//
TInt CSatBIPDataAvailableMonitor::StartMonitor()
    {
    LOG( SIMPLE,
        "SATEVENTMONITORS: CSatBIPDataAvailableMonitor::StartMonitor calling" )

    if ( !iIsActive )
        {
        LOG( NORMAL, "SATEVENTMONITORS: CSatBIPDataAvailableMonitor::\
            StartMonitor Activating monitor" )
        // Call MSatBIPEventNotifier.NotifyDataAvailable
        iEventUtils.BipNotifier().NotifyDataAvailable( this );
        }

    LOG( SIMPLE,
        "SATEVENTMONITORS: CSatBIPDataAvailableMonitor::StartMonitor exiting" )
    return KErrNone;
    }

// -----------------------------------------------------------------------------
// CSatBIPDataAvailableMonitor::DataAvailable
// Called when data is received
// -----------------------------------------------------------------------------
//
void CSatBIPDataAvailableMonitor::DataAvailable( const TInt aChannelId,
    const TInt aLength )
    {
    LOG( SIMPLE,
        "SATEVENTMONITORS: CSatBIPDataAvailableMonitor::DataAvailable calling" )

    // Inform SAT Engine that data is available.
    EventOccured( aChannelId, aLength );

    LOG( SIMPLE,
        "SATEVENTMONITORS: CSatBIPDataAvailableMonitor::DataAvailable exiting" )
    }

// End of file