--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/tsrc/VCXTestCommon/src/CIptvTestTimer.cpp Mon Jan 18 20:21:12 2010 +0200
@@ -0,0 +1,183 @@
+/*
+* 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 "CIptvTestTimer.h"
+#include "MIptvTestTimerObserver.h"
+#include "VCXTestLog.h"
+
+// EXTERNAL DATA STRUCTURES
+
+// EXTERNAL FUNCTION PROTOTYPES
+
+// CONSTANTS
+
+// MACROS
+
+// LOCAL CONSTANTS AND MACROS
+
+// MODULE DATA STRUCTURES
+
+// LOCAL FUNCTION PROTOTYPES
+
+// FORWARD DECLARATIONS
+
+// ============================= LOCAL FUNCTIONS ===============================
+
+// ============================ MEMBER FUNCTIONS ===============================
+
+// -----------------------------------------------------------------------------
+// CIptvTestTimer::
+// C++ default constructor can NOT contain any code, that
+// might leave.
+// -----------------------------------------------------------------------------
+//
+EXPORT_C CIptvTestTimer* CIptvTestTimer::NewL(MIptvTestTimerObserver& aObserver, TInt aId)
+ {
+ VCXLOGLO1(">>>CIptvTestTimer::NewL");
+ CIptvTestTimer* self = new (ELeave) CIptvTestTimer(aObserver, aId);
+ CleanupStack::PushL(self);
+ self->ConstructL();
+ CleanupStack::Pop();
+ VCXLOGLO1("<<<CIptvTestTimer::NewL");
+ return self;
+ }
+
+// -----------------------------------------------------------------------------
+// CIptvTestTimer::~CIptvTestTimer
+// destructor
+// -----------------------------------------------------------------------------
+//
+EXPORT_C CIptvTestTimer::~CIptvTestTimer()
+ {
+ VCXLOGLO1(">>>CIptvTestTimer::~CIptvTestTimer");
+ iRestartAfterCancel = EFalse;
+ Cancel();
+ iTimer.Close();
+
+ if( IsAdded() )
+ {
+ Deque(); // calls also Cancel()
+ }
+
+ VCXLOGLO1("<<<CIptvTestTimer::~CIptvTestTimer");
+ }
+
+// -----------------------------------------------------------------------------
+// CIptvTestTimer::~CIptvTestTimer
+// destructor
+// -----------------------------------------------------------------------------
+//
+EXPORT_C void CIptvTestTimer::CancelTimer()
+ {
+ VCXLOGLO1(">>>CIptvTestTimer::CancelTimer");
+ if( IsActive() )
+ {
+ iRestartAfterCancel = EFalse;
+ Cancel();
+ }
+ VCXLOGLO1("<<<CIptvTestTimer::CancelTimer");
+ }
+
+// -----------------------------------------------------------------------------
+// CIptvTestTimer::CIptvTestTimer
+//
+// -----------------------------------------------------------------------------
+//
+CIptvTestTimer::CIptvTestTimer(MIptvTestTimerObserver& aObserver, TInt aId) : CActive(EPriorityStandard), iObserver(aObserver),
+ iId(aId)
+ {
+ VCXLOGLO1(">>>CIptvTestTimer::CIptvTestTimer");
+ CActiveScheduler::Add(this);
+ VCXLOGLO1("<<<CIptvTestTimer::CIptvTestTimer");
+ }
+
+// -----------------------------------------------------------------------------
+// CIptvTestTimer::ConstructL
+//
+// -----------------------------------------------------------------------------
+//
+void CIptvTestTimer::ConstructL()
+ {
+ VCXLOGLO1(">>>CIptvTestTimer::ConstructL");
+ User::LeaveIfError(iTimer.CreateLocal());
+ VCXLOGLO1("<<<CIptvTestTimer::ConstructL");
+ }
+
+// -----------------------------------------------------------------------------
+// CIptvTestTimer::After
+//
+// -----------------------------------------------------------------------------
+//
+EXPORT_C void CIptvTestTimer::After(TTimeIntervalMicroSeconds32 aInterval)
+ {
+
+ iInterval = aInterval;
+
+ if( !IsActive() )
+ {
+ iTimer.After( iStatus, aInterval );
+ SetActive();
+ iRestartAfterCancel = EFalse;
+ }
+ else
+ {
+ // Cancel and start again when cancel is done.
+ VCXLOGLO2("CIptvTestTimer::After: Restarting! (%d)", this);
+ iRestartAfterCancel = ETrue;
+ iTimer.Cancel();
+ }
+ }
+
+// -----------------------------------------------------------------------------
+// CIptvTestTimer::RunL
+//
+// -----------------------------------------------------------------------------
+//
+void CIptvTestTimer::RunL()
+ {
+ TInt status = iStatus.Int();
+
+ if( status == KErrNone )
+ {
+ iObserver.TimerComplete( iId, iStatus.Int() );
+ }
+ else
+ if( status == KErrCancel && iRestartAfterCancel )
+ {
+ iRestartAfterCancel = EFalse;
+ iTimer.After( iStatus, iInterval );
+ SetActive();
+ VCXLOGLO2("CIptvTestTimer::RunL: Restarted! (%d)", this);
+ }
+ }
+
+// -----------------------------------------------------------------------------
+// CIptvTestTimer::DoCancel
+//
+// -----------------------------------------------------------------------------
+//
+void CIptvTestTimer::DoCancel()
+ {
+ VCXLOGLO1(">>>CIptvTestTimer::DoCancel");
+ iTimer.Cancel();
+ VCXLOGLO1("<<<CIptvTestTimer::DoCancel");
+ }
+
+// End of File