diff -r 000000000000 -r 094583676ce7 IMPSengine/client/src/impshandlertimer.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/IMPSengine/client/src/impshandlertimer.cpp Thu Dec 17 08:41:52 2009 +0200 @@ -0,0 +1,101 @@ +/* +* Copyright (c) 2005 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 class for imps handler. +* +*/ + + +// INCLUDE FILES +#include +#include +#include "impsutils.h" +#include "impshandler.h" +#include "impshandlertimer.h" + +// MACROS +#ifndef _DEBUG +#define _NO_IMPS_LOGGING_ +#endif + +const TInt KWaitTime = 5; + +// ----------------------------------------------------------------------------- +// CImpsHandlerTimer::Start +// ----------------------------------------------------------------------------- +CImpsHandlerTimer::CImpsHandlerTimer( + TInt aPriority, + CImpsHandler2& aHandler ) + : CActive( aPriority ), + iHandler( aHandler ) + { +#ifndef _NO_IMPS_LOGGING_ + CImpsClientLogger::Log(_L("CImpsHandlerTimer: Constructor")); +#endif + // Add this to the scheduler + (void) iTimer.CreateLocal(); + CActiveScheduler::Add(this); + } + +CImpsHandlerTimer::~CImpsHandlerTimer() + { + Cancel(); + iTimer.Close(); +#ifndef _NO_IMPS_LOGGING_ + CImpsClientLogger::Log(_L("CImpsHandlerTimer: Destructor")); +#endif + } + +// ----------------------------------------------------------------------------- +// CImpsHandlerTimer::Start +// ----------------------------------------------------------------------------- +void CImpsHandlerTimer::Start( ) + { + if ( IsActive() ) + { + return; + } +#ifndef _NO_IMPS_LOGGING_ + CImpsClientLogger::Log(_L("CImpsHandlerTimer: Start")); +#endif + iTimer.After( iStatus, KWaitTime * 1000000 ); + iStatus = KRequestPending; + SetActive(); + } + +// ----------------------------------------------------------------------------- +// CImpsHandlerTimer::RunL +// ----------------------------------------------------------------------------- +void CImpsHandlerTimer::RunL() + { +#ifndef _NO_IMPS_LOGGING_ + CImpsClientLogger::Log(_L("CImpsHandlerTimer: RunL, calling EventHandled")); +#endif + iHandler.StartRun(); + iHandler.EventHandled(); + } + +// ----------------------------------------------------------------------------- +// CImpsHandlerTimer::DoCancel +// ----------------------------------------------------------------------------- +void CImpsHandlerTimer::DoCancel() + { + iTimer.Cancel(); + } + +// End of File + + + +