videoutils_plat/videoconnutility_api/tsrc/VCXTestCommon/src/CIptvTestTimer.cpp
branchRCL_3
changeset 48 13a33d82ad98
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/videoutils_plat/videoconnutility_api/tsrc/VCXTestCommon/src/CIptvTestTimer.cpp	Wed Sep 01 12:20:37 2010 +0100
@@ -0,0 +1,184 @@
+/*
+* 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() )
+    	{
+	    VCXLOGLO2("CIptvTestTimer::After: Setting active. (%d)", this);
+    	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