phonebookui/Phonebook2/CommonUI/src/CPbk2CompressPolicyManager.cpp
changeset 0 e686773b3f54
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/phonebookui/Phonebook2/CommonUI/src/CPbk2CompressPolicyManager.cpp	Tue Feb 02 10:12:17 2010 +0200
@@ -0,0 +1,227 @@
+/*
+* Copyright (c) 2005-2007 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:  Phonebook 2 compress policy manager.
+*
+*/
+
+
+#include "CPbk2CompressPolicyManager.h"
+
+// Phonebook 2
+#include "CPbk2CompressPolicyTimer.h"
+#include "CPbk2CompressPolicyDiskSpace.h"
+#include <MPbk2StoreObservationRegister.h>
+
+// Virtual Phonebook
+#include <CVPbkContactManager.h>
+#include <MVPbkContactOperationBase.h>
+
+// System includes
+#include <systemwarninglevels.hrh>
+
+// Debugging headers
+#include <Pbk2Debug.h>
+
+
+/// Unnamed namespace for local definitions
+namespace {
+
+ /// Time (in seconds) to wait after last database event before starting
+ /// compression. The timeout tries to prevent compression from starting
+ /// if there is a lot of database activity.
+const TInt KIntervalInSeconds(10);
+
+#ifdef _DEBUG
+
+enum TPanic
+    {
+    EPreCondPanic_OperationComplete = 1,
+    EPreCondPanic_AlreadyExist
+    };
+
+_LIT(KPanicCat, "CPbk2CompressPolicyManager");
+
+void Panic(TPanic aPanic)
+    {
+    User::Panic(KPanicCat, aPanic);
+    }
+
+#endif // _DEBUG
+
+} /// namespace
+
+
+// --------------------------------------------------------------------------
+// CPbk2CompressPolicyManager::CPbk2CompressPolicyManager
+// --------------------------------------------------------------------------
+//
+CPbk2CompressPolicyManager::CPbk2CompressPolicyManager
+        ( MPbk2StoreObservationRegister& aStoreObservationRegister,
+          CVPbkContactManager& aContactManager ) :
+            iStoreObservationRegister( aStoreObservationRegister ),
+            iContactManager( aContactManager )
+    {
+    }
+
+// --------------------------------------------------------------------------
+// CPbk2CompressPolicyManager::~CPbk2CompressPolicyManager
+// --------------------------------------------------------------------------
+//
+CPbk2CompressPolicyManager::~CPbk2CompressPolicyManager()
+    {
+    iPolicyArray.ResetAndDestroy();
+    delete iCompressOperation;
+    }
+
+// --------------------------------------------------------------------------
+// CPbk2CompressPolicyManager::NewL
+// --------------------------------------------------------------------------
+//
+CPbk2CompressPolicyManager* CPbk2CompressPolicyManager::NewL
+        ( MPbk2StoreObservationRegister& aStoreObservationRegister,
+          CVPbkContactManager& aContactManager )
+    {
+    CPbk2CompressPolicyManager* self =
+        new ( ELeave ) CPbk2CompressPolicyManager
+            ( aStoreObservationRegister, aContactManager );
+    CleanupStack::PushL(self);
+    self->ConstructL();
+    CleanupStack::Pop(self);
+    return self;
+    }
+
+// --------------------------------------------------------------------------
+// CPbk2CompressPolicyManager::ConstructL
+// --------------------------------------------------------------------------
+//
+void CPbk2CompressPolicyManager::ConstructL()
+    {
+    ConstructPoliciesL();
+    }
+
+// --------------------------------------------------------------------------
+// CPbk2CompressPolicyManager::CompressStores
+// --------------------------------------------------------------------------
+//
+void CPbk2CompressPolicyManager::CompressStores()
+    {
+    __ASSERT_DEBUG( !iCompressOperation, Panic(EPreCondPanic_AlreadyExist));
+    
+    TRAPD( err,
+        iCompressOperation = iContactManager.CompressStoresL( *this ) );
+
+    if (err != KErrNone)
+        {
+        // if error occured here, restart all policies
+        StartAllPolicies();
+        }
+    }
+
+// --------------------------------------------------------------------------
+// CPbk2CompressPolicyManager::CancelCompress
+// --------------------------------------------------------------------------
+//
+void CPbk2CompressPolicyManager::CancelCompress()
+    {
+    delete iCompressOperation;
+    iCompressOperation = NULL;
+    }
+
+// --------------------------------------------------------------------------
+// CPbk2CompressPolicyManager::StartAllPolicies
+// --------------------------------------------------------------------------
+//
+void CPbk2CompressPolicyManager::StartAllPolicies()
+    {
+    for (TInt i = 0; i < iPolicyArray.Count(); ++i)
+        {
+        MPbk2CompressPolicy* policy = iPolicyArray[i];
+        policy->Start();
+        }
+    }
+
+// --------------------------------------------------------------------------
+// CPbk2CompressPolicyManager::StopAllPolicies
+// --------------------------------------------------------------------------
+//
+void CPbk2CompressPolicyManager::StopAllPolicies()
+    {
+    CancelCompress();
+    for (TInt i = 0; i < iPolicyArray.Count(); ++i)
+        {
+        iPolicyArray[i]->Stop();
+        }
+    }
+
+// --------------------------------------------------------------------------
+// CPbk2CompressPolicyManager::StepComplete
+// --------------------------------------------------------------------------
+//
+void CPbk2CompressPolicyManager::StepComplete
+        ( MVPbkContactOperationBase& /*aOperation*/, TInt /*aStepSize*/ )
+    {
+    // Do nothing
+    }
+
+// --------------------------------------------------------------------------
+// CPbk2CompressPolicyManager::StepFailed
+// --------------------------------------------------------------------------
+//
+TBool CPbk2CompressPolicyManager::StepFailed
+        ( MVPbkContactOperationBase& /*aOperation*/, TInt /*aStepSize*/,
+          TInt /*aError*/ )
+    {
+    // The process should be stopped
+    return EFalse;
+    }
+
+// --------------------------------------------------------------------------
+// CPbk2CompressPolicyManager::OperationComplete
+// --------------------------------------------------------------------------
+//
+void CPbk2CompressPolicyManager::OperationComplete
+        ( MVPbkContactOperationBase& PBK2_DEBUG_ONLY( aOperation ) )
+    {
+    __ASSERT_DEBUG(iCompressOperation == &aOperation,
+        Panic(EPreCondPanic_OperationComplete));
+    delete iCompressOperation;
+    iCompressOperation = NULL;
+
+    // After compress operation complete, restart the policies
+    StartAllPolicies();
+    }
+
+// --------------------------------------------------------------------------
+// CPbk2CompressPolicyManager::ConstructPoliciesL
+// --------------------------------------------------------------------------
+//
+void CPbk2CompressPolicyManager::ConstructPoliciesL()
+    {
+    // Timer policy
+    CPbk2CompressPolicyTimer* timerPolicy = CPbk2CompressPolicyTimer::NewL
+        ( iStoreObservationRegister, *this, KIntervalInSeconds );
+    CleanupStack::PushL(timerPolicy);
+    iPolicyArray.AppendL(timerPolicy);
+    CleanupStack::Pop(timerPolicy);
+
+    // Disk space policy
+    CPbk2CompressPolicyDiskSpace* diskspacePolicy =
+        CPbk2CompressPolicyDiskSpace::NewL
+            ( *this, iContactManager.FsSession(), KDRIVECCRITICALTHRESHOLD );
+    CleanupStack::PushL(diskspacePolicy);
+    iPolicyArray.AppendL(diskspacePolicy);
+    CleanupStack::Pop(diskspacePolicy);
+    }
+
+// End of File