ipsservices/ipssosplugin/src/ipsplgeventtimer.cpp
changeset 0 8466d47a6819
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/ipsservices/ipssosplugin/src/ipsplgeventtimer.cpp	Thu Dec 17 08:39:21 2009 +0200
@@ -0,0 +1,152 @@
+/*
+* Copyright (c) 2006 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: This file implements class CIpsPlgEventTimer.
+*
+*/
+
+
+
+#include "emailtrace.h"
+#include "ipsplgheaders.h"
+
+const TInt KIpsEventDelay = 1000000;//1 sec
+
+// ----------------------------------------------------------------------------
+// CIpsPlgEventTimer::NewL()
+// ----------------------------------------------------------------------------
+//
+CIpsPlgEventTimer* CIpsPlgEventTimer::NewL( 
+    CMsvSession& aMsvSession, 
+    TInt aPriority, 
+    TRequestStatus& aObserverRequestStatus,
+    TIpsPlgEvent aEvent, 
+    MFSMailEventObserver& aObserver )
+    {
+    FUNC_LOG;
+    CIpsPlgEventTimer* self = new(ELeave)CIpsPlgEventTimer( 
+        aMsvSession,
+        aPriority,
+        aObserverRequestStatus,
+        aEvent,
+        aObserver );
+
+    CleanupStack::PushL( self );
+    self->ConstructL();
+    CleanupStack::Pop( self );
+    return self;
+    }
+
+// ----------------------------------------------------------------------------
+// CIpsPlgEventTimer::CIpsPlgEventTimer()
+// ----------------------------------------------------------------------------
+//
+CIpsPlgEventTimer::CIpsPlgEventTimer(
+    CMsvSession& aMsvSession, 
+    TInt aPriority, 
+    TRequestStatus& aObserverRequestStatus,
+    TIpsPlgEvent aEvent,
+    MFSMailEventObserver& aObserver )
+: CMsvOperation(aMsvSession, aPriority, aObserverRequestStatus),
+iEvent( aEvent ),
+iObserver( aObserver )
+    {
+    FUNC_LOG;
+    }
+
+// ----------------------------------------------------------------------------
+// CIpsPlgEventTimer::~CIpsPlgEventTimer()
+// ----------------------------------------------------------------------------
+//
+CIpsPlgEventTimer::~CIpsPlgEventTimer()
+    {
+    FUNC_LOG;
+    Cancel();
+    iTimer.Close();
+    }
+
+// ----------------------------------------------------------------------------
+// CIpsPlgEventTimer::ConstructL()
+// ----------------------------------------------------------------------------
+//
+void CIpsPlgEventTimer::ConstructL()
+    {
+    FUNC_LOG;
+    User::LeaveIfError( iTimer.CreateLocal() );
+    CActiveScheduler::Add(this);
+    
+    After( KIpsEventDelay );
+    }
+
+// ----------------------------------------------------------------------------
+// CIpsPlgEventTimer::ProgressL()
+// ----------------------------------------------------------------------------
+//
+const TDesC8& CIpsPlgEventTimer::ProgressL()
+    {
+    FUNC_LOG;
+    return iProgress;
+    }
+
+// ----------------------------------------------------------------------------
+// CIpsPlgEventTimer::After()
+// ----------------------------------------------------------------------------
+//
+void CIpsPlgEventTimer::After( TTimeIntervalMicroSeconds32 aInterval )
+    {
+    FUNC_LOG;
+    iTimer.After(iStatus, aInterval);
+    SetActive();
+    }
+    
+// ----------------------------------------------------------------------------
+// CIpsPlgEventTimer::DoCancel()
+// ----------------------------------------------------------------------------
+//
+void CIpsPlgEventTimer::DoCancel()
+    {
+    FUNC_LOG;
+    iTimer.Cancel();
+    TRequestStatus* status = &iObserverRequestStatus;
+    if ( status && status->Int() == KRequestPending )
+        {
+        User::RequestComplete(status, KErrNone);
+        }
+    }
+
+// ----------------------------------------------------------------------------
+// CIpsPlgEventTimer::RunL()
+// ----------------------------------------------------------------------------
+//
+void CIpsPlgEventTimer::RunL()
+    {
+    FUNC_LOG;
+    if( &iObserver )
+        {        
+        iObserver.EventL( 
+            iEvent.iEvent, 
+            iEvent.iAccountId, 
+            iEvent.iArg1,
+            iEvent.iArg2,
+            iEvent.iArg3 );
+        }
+    
+    TRequestStatus* status = &iObserverRequestStatus;
+    User::RequestComplete(status, KErrNone);
+    }
+
+
+
+    
+//EOF    
+