mmfenh/advancedaudiocontroller/tsrc/advancedaudiocontrollertestmodule/AudioStreamTestModule/src/MediaEvent.cpp
changeset 0 71ca22bcf22a
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/mmfenh/advancedaudiocontroller/tsrc/advancedaudiocontrollertestmodule/AudioStreamTestModule/src/MediaEvent.cpp	Tue Feb 02 01:08:46 2010 +0200
@@ -0,0 +1,147 @@
+/*
+* Copyright (c) 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:  Audio stream test component
+*
+*/
+
+
+#include "MediaEvent.h"
+
+CMediaEvent* CMediaEvent::NewL(CStifLogger *aLogger,
+		TTimeIntervalMicroSeconds32 aDelay , TTimeIntervalMicroSeconds32 aInterval,
+		MEventTarget *aTarget , CParameters *aParameters , TInt aPriority)
+	{
+	CMediaEvent *__self = CMediaEvent::NewLC(aLogger ,
+										aDelay , aInterval , aTarget,
+										aParameters, aPriority);
+	CleanupStack::Pop(__self);
+	return __self;
+	}
+
+CMediaEvent* CMediaEvent::NewLC(CStifLogger *aLogger,
+		TTimeIntervalMicroSeconds32 aDelay , TTimeIntervalMicroSeconds32 aInterval,
+		MEventTarget *aTarget, CParameters *aParameters , TInt aPriority)
+	{
+		CMediaEvent *__self = new(ELeave) CMediaEvent(aLogger , aDelay , aInterval , aTarget , aParameters);
+		CleanupStack::PushL(__self);
+		__self->ConstructL(aPriority);
+		return __self;
+	}
+
+CMediaEvent::CMediaEvent (CStifLogger *aLogger,
+		TTimeIntervalMicroSeconds32 aDelay, TTimeIntervalMicroSeconds32 aInterval,
+		MEventTarget *aTarget , CParameters *aParameters)
+	: iLogger(aLogger) ,
+		iDelay(aDelay) , iInterval(aInterval) , iEventTarget(aTarget),
+		iParameters(aParameters) , iCount(0)
+	{}
+
+void CMediaEvent::ConstructL(TInt aPriority=CActive::EPriorityStandard)
+	{
+	iLogger->Log(_L("Creating event with priority (%d)") , aPriority);
+	iPeriodic=CPeriodic::NewL(aPriority);
+	iPeriodic->Start(iDelay , iInterval , TCallBack(Tick, this));
+	}
+
+CMediaEvent::~CMediaEvent ()
+	{
+	iPeriodic->Cancel();
+	delete iPeriodic;
+	delete iParameters;
+	iParameters=NULL;
+	}
+
+TInt CMediaEvent::Tick(TAny *aObject)
+	{
+	return (static_cast<CMediaEvent*>(aObject) )->DoTick(); // cast, and call non-static function
+	}
+
+TInt CMediaEvent::DoTick()
+	{
+	iCount++;
+	if (! iEventTarget->ExecuteL(iParameters)) {
+		iPeriodic->Cancel();
+	}
+	return 0;
+	}
+
+TInt CMediaEvent::GetCount() const
+	{
+	return iCount;
+	}
+
+
+////////////////////////////
+CImmediateMediaEvent* CImmediateMediaEvent::NewL(CStifLogger *aLogger ,
+											MEventTarget *aTarget , CParameters *aParameters , TInt aPriority)
+	{
+		CImmediateMediaEvent *__self = CImmediateMediaEvent::NewLC(aLogger, aTarget, aParameters, aPriority);
+
+		CleanupStack::Pop(__self);
+		return __self;
+	}
+
+CImmediateMediaEvent* CImmediateMediaEvent::NewLC(CStifLogger *aLogger ,
+											MEventTarget *aTarget, CParameters *aParameters , TInt aPriority)
+	{
+		CImmediateMediaEvent *__self = new(ELeave) CImmediateMediaEvent(aLogger , aTarget , aParameters, aPriority);
+		CleanupStack::PushL(__self);
+		__self->ConstructL();
+		return __self;
+	}
+
+CImmediateMediaEvent::CImmediateMediaEvent (CStifLogger *aLogger ,
+						MEventTarget *aTarget , CParameters *aParameters, TInt aPriority)
+					: CActive(aPriority) , iLogger(aLogger) ,
+						iEventTarget(aTarget) , iParameters(aParameters) , iEnabled(ETrue)
+	{}
+
+void CImmediateMediaEvent::ConstructL(/*TInt aPriority=CActive::EPriorityStandard*/)
+	{
+	iLogger->Log(_L("Creating event with priority (%d)") , Priority() );
+	//iPeriodic=CPeriodic::NewL(aPriority);
+	//iPeriodic->Start(iDelay , iInterval , TCallBack(Tick, this));
+	CActiveScheduler::Add(this);
+	}
+
+CImmediateMediaEvent::~CImmediateMediaEvent ()
+	{
+	delete iParameters;
+	iParameters=NULL;
+	Cancel();
+	}
+
+void CImmediateMediaEvent::RunL()
+	{
+	if (iEnabled)
+		{
+		iEventTarget->ExecuteL(iParameters);
+		}
+	}
+
+void CImmediateMediaEvent::DoCancel()
+	{
+	iEnabled = EFalse;
+	}
+
+TBool CImmediateMediaEvent::FireExecute()
+	{
+	//__ASSERT_ALWAYS(!IsActive(), User::Panic(_L("Error with the "), KErrGeneral));
+	if ( IsActive() ) return EFalse;
+	iEnabled = ETrue;
+	TRequestStatus *status = &iStatus;
+	SetActive();
+	User::RequestComplete( status , KErrNone);
+	return ETrue;
+	}