diff -r 000000000000 -r ff3b6d0fd310 satengine/SatServer/EventMonitors/src/CSatBIPDataAvailableMonitor.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/satengine/SatServer/EventMonitors/src/CSatBIPDataAvailableMonitor.cpp Tue Feb 02 01:11:09 2010 +0200 @@ -0,0 +1,150 @@ +/* +* 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