terminalsecurity/SCP/SCPServer/src/SCPTimer.cpp
changeset 0 b497e44ab2fc
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/terminalsecurity/SCP/SCPServer/src/SCPTimer.cpp	Thu Dec 17 09:07:52 2009 +0200
@@ -0,0 +1,142 @@
+/*
+* Copyright (c) 2000 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: Implementation of terminalsecurity components
+*
+*/
+
+
+// INCLUDE FILES
+#include <e32debug.h>
+
+#include "SCPTimer.h"
+#include "SCPServer.h"
+
+// ================= MEMBER FUNCTIONS =======================
+
+// C++ default constructor can NOT contain any code, that
+// might leave.
+//
+CSCPTimer::CSCPTimer( TAny* aParam, MSCPTimeoutHandler* aHandler )
+	: CActive( EPriorityNormal ),
+	iParam( aParam ),
+	iHandler( aHandler )
+	{
+	Dprint( (_L("--> CSCPTimer::CSCPTimer()") ));
+ 
+    // No implementation required    
+	
+	Dprint( (_L("<-- CSCPTimer::CSCPTimer()") ));
+	}
+
+
+// Static constructor.
+CSCPTimer* CSCPTimer::NewL( TUint aTimeout, TAny* aParam, MSCPTimeoutHandler* aHandler )
+	{
+	Dprint( (_L("--> CSCPTimer::NewL()") ));
+
+	CSCPTimer* self = CSCPTimer::NewLC( aTimeout, aParam, aHandler );
+	CleanupStack::Pop( self ); 
+	
+	Dprint( (_L("<-- CSCPTimer::NewL()") ));
+	return self;	
+	}
+	
+
+// Static constructor, leaves object pointer to the cleanup stack.
+CSCPTimer* CSCPTimer::NewLC( TUint aTimeout, TAny* aParam, MSCPTimeoutHandler* aHandler )
+	{
+	Dprint( (_L("--> CSCPTimer::NewLC()") ));
+
+	CSCPTimer* self = new (ELeave) CSCPTimer( aParam, aHandler );
+
+    CleanupStack::PushL( self );
+    self->ConstructL( aTimeout );	
+    
+    Dprint( (_L("<-- CSCPTimer::NewLC()") ));
+    return self;	
+    }
+
+
+// Symbian 2nd phase constructor can leave.
+void CSCPTimer::ConstructL( TUint aTimeout )
+    {
+    Dprint( (_L("--> CSCPTimer::ConstructL()") ));        
+    CActiveScheduler::Add( this );
+    
+    iTimer.CreateLocal();
+    
+    // Start the timer
+    iTimer.After( iStatus, aTimeout );
+    // No need to check for isActive, this is the constructor
+    SetActive();
+   	
+    Dprint( (_L("<-- CSCPTimer::ConstructL()") ));
+    }
+
+    
+// Destructor
+CSCPTimer::~CSCPTimer()
+	{
+	Dprint( (_L("--> CSCPTimer::~CSCPTimer()") ));    
+    
+    if ( IsActive() )
+        {
+        Cancel();
+        }
+        
+    iParam = NULL;
+    iHandler = NULL;
+    
+    iTimer.Close();
+                  
+	Dprint( (_L("<-- CSCPTimer::~CSCPTimer()") ));
+	}
+
+
+// ---------------------------------------------------------
+// void CSCPTimer::RunL()
+// Handle the timeout by calling the callback method
+// 
+// Status : Approved
+// ---------------------------------------------------------
+//
+void CSCPTimer::RunL()
+    {
+    Dprint( (_L("--> CSCPTimer::RunL()") ));
+    
+    Dprint( (_L("--> CSCPTimer::RunL(): TIMEOUT occured, signalling the handler") ));
+    iHandler->Timeout( iParam );
+   
+    Dprint( (_L("<-- CSCPTimer::RunL()") ));
+    }   
+
+
+// ---------------------------------------------------------
+// void CSCPTimer::DoCancel()
+// Cancel the call using the RTimer member
+// 
+// Status : Approved
+// ---------------------------------------------------------
+//
+void CSCPTimer::DoCancel()
+    {
+    Dprint( (_L("--> CSCPTimer::DoCancel()") ));
+        
+    iTimer.Cancel();
+   
+    Dprint( (_L("<-- CSCPTimer::DoCancel()") ));
+    }   
+
+//  End of File  
+