logsui/AppSrc/CLogsTimer.cpp
changeset 0 e686773b3f54
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/logsui/AppSrc/CLogsTimer.cpp	Tue Feb 02 10:12:17 2010 +0200
@@ -0,0 +1,125 @@
+/*
+* Copyright (c) 2002, 2003 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:  Timer.
+*
+*/
+
+
+// INCLUDE FILES
+#include    "CLogsTimer.h"
+
+// ================= MEMBER FUNCTIONS =======================
+
+// ---------------------------------------------------------
+// CLogsTimer::CLogsTimer
+// ---------------------------------------------------------
+//
+CLogsTimer::CLogsTimer( TInt aPriority ) 
+    : CTimer( aPriority)
+    {
+    CActiveScheduler::Add( this );
+    }
+
+// ---------------------------------------------------------
+// CLogsTimer::ConstructL
+// ---------------------------------------------------------
+//
+void CLogsTimer::ConstructL()
+    {
+    CTimer::ConstructL();
+    }
+
+// ---------------------------------------------------------
+// CLogsTimer::NewL
+// ---------------------------------------------------------
+//
+CLogsTimer* CLogsTimer::NewL( TInt aPriority )
+    {
+    CLogsTimer* self = new (ELeave) CLogsTimer( aPriority );
+    
+    CleanupStack::PushL( self );
+    self->ConstructL();
+    CleanupStack::Pop();
+
+    return self;
+    }
+    
+// ---------------------------------------------------------
+// CLogsTimer::~CLogsTimer
+// ---------------------------------------------------------
+//
+CLogsTimer::~CLogsTimer()
+    {
+    CTimer::Cancel();    
+    }
+
+// ---------------------------------------------------------
+// CLogsTimer::RunL()
+// ---------------------------------------------------------
+//
+void CLogsTimer::RunL()
+    {
+    if ( iStatus != KErrNone )
+        {
+        //error code is ignored, as CPeriodic. 
+        return;
+        }
+   
+    if( iTimerObserver == NULL )
+        {
+        iCallBack.CallBack();
+        }
+    else
+        {
+        iTimerObserver->HandleLogsTimerL( iTimerObserverParam );
+        }
+    }
+
+// ---------------------------------------------------------
+// CLogsTimer::After()
+// ---------------------------------------------------------
+//
+void CLogsTimer::After( TTimeIntervalMicroSeconds32 anInterval, 
+                        TCallBack aCallBack )
+    {
+    if ( IsActive() )
+        {
+        Cancel();
+        }
+
+    iTimerObserver = NULL;
+    iCallBack = aCallBack;
+    CTimer::After( anInterval );
+    }
+
+// ---------------------------------------------------------
+// CLogsTimer::After()
+// ---------------------------------------------------------
+//
+void CLogsTimer::After( TTimeIntervalMicroSeconds32 anInterval, 
+                        MLogsTimer* aObserver,
+                        TAny* aPtr )
+    {
+    if ( IsActive() )
+        {
+        Cancel();
+        }
+        
+    iTimerObserver = aObserver;
+    iTimerObserverParam = aPtr;
+    CTimer::After( anInterval );
+    }
+
+//  End of File  
+