messagingfw/msgsrvnstore/server/inc/msventryfreepool.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Thu, 02 Sep 2010 20:55:53 +0300
changeset 47 d176b53f330f
parent 40 320ec5cd0227
child 46 d51193d814ea
permissions -rw-r--r--
Revision: 201033 Kit: 201035

// Copyright (c) 2007-2010 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:
// MACRO DEFINITION
// 
//
  
#ifndef __MSVENTRYFREEPOOL_H__
#define __MSVENTRYFREEPOOL_H__


/**
 * HEADER FILES
 */ 
#include <e32base.h>
#include "msvcacheentry.h"
#include "msvcachevisiblefolder.h"

#if !defined(MSVSEARCHSORTCACHEMANAGER_H_)
#include "msvsearchsortcachemanager.h"
#endif


class CMsvIndexAdapter;


/**
 * The class provides implementation for pool of unused CMsvCacheEntry.
 * It is a singleton class. A CMsvIndexAdapter instance should create and
 * delete the instance of this class. It reads a msgcache.ini file which
 * stores amount of CMsvCacheEntry to be created at startup. The file 
 * can be configured by licencees.
 * The destructor is made private so that only friend function can delete 
 * the instance of this class. Moreover static function Destroy() should 
 * be called to delete the instance of the class.
 *
 @internalComponent
 @prototype
 */

NONSHARABLE_CLASS (CMsvEntryFreePool): public CBase
{
public:
	static CMsvEntryFreePool* Instance();	
	CMsvCacheEntry* EntryL();
	void ReleaseEntryL(CMsvCacheEntry* aMsvCacheEntry, TBool aBypassTransaction = EFalse);
	void ReleaseEntrySet(RPointerArray<CMsvCacheEntry>& aMsvCacheEntryArray);
	void DoReleaseEntrySetL(RPointerArray<CMsvCacheEntry>& aMsvCacheEntryArray);
	void SetEssentialParam(TDblQue<CMsvCacheVisibleFolder>* aEntryCache, CMsvIndexAdapter* aAdapterObj);
	inline void BeginTransaction();
	void RollbackTransaction();
	void CommitTransaction();
	inline TInt ExcessMemoryAllocated();
	inline void RecordExcessMemoryL(CMsvCacheEntry* aEntry);
	void FlushExcessMemory();
	void RoutineFreePoolCleanUpL();
	void ReleaseEntryWithoutTransaction(CMsvCacheEntry* aMsvCacheEntry);
	
#ifdef SYMBIAN_MESSAGESTORE_UNIT_TESTCODE
	inline TInt GetMaximumCacheSize();
	inline TInt GetGranularity();
	inline TInt GetCacheThreshold();
	inline TInt GetCacheNumberOfEntriesCreated();
	inline TInt GetNumberOfEntriesPresentInFreePool();
	inline TInt GetMaxEntries();
	inline TInt GetUsedEntriesCount();
#endif
	
	
private:
	static CMsvEntryFreePool* CreateL(TDblQue<CMsvCacheVisibleFolder>* aEntryCache = NULL);
	CMsvEntryFreePool(TDblQue<CMsvCacheVisibleFolder>* aEntryCache);
	CMsvEntryFreePool(const CMsvEntryFreePool&);
	~CMsvEntryFreePool();
	void ConstructL();
	void SwapEntriesL(TInt aEntriesToSwap);
	TInt ConvertMemToEntry(TInt aMem);
	TBool IsAllocationRequiredL();
	void AllocateMemoryL();
	TInt CacheSizeL();
	
#ifdef _DEBUG
	static void Destroy(CMsvEntryFreePool* aFreePoolInstance);
#endif

private:
	static CMsvEntryFreePool* iMsvEntryFreePool;
	RPointerArray<CMsvCacheEntry>* iMsvEntries;
	RPointerArray<CMsvCacheEntry> iUsedCacheEntries;
	
	// Reference to catch object.
	// Needed for entry swapping.
	TDblQue<CMsvCacheVisibleFolder>* iEntryCache;
	CMsvIndexAdapter* iAdapter;
	
	// Needed for transaction.
	RPointerArray<CMsvCacheEntry> iMsvTmpEntries;
	TBool isTransactionOpen;
	
	TInt iMsvMaximumCacheSize;
	//TInt iMsvGranularity;
	TInt iMsvCacheThreshold;
	TInt iMsvCacheNumberOfEntriesCreated;
	
	TInt iMsvInitialCacheSize;
	TInt iMsvCacheIncrement;
	TInt iMsvPercentageAllocated;
	TInt iMsvCacheSize;
	TInt iMsvSearchSortCache;
	TInt iMsvMaxEntries;
		
	/**
	 * FRIEND CLASSES:
	 * These classes can access destructor and Destroy().
	 */
	friend class CMsvIndexAdapter;
	friend class CMsvServer;
	friend class CMSvSearchSortCacheManager;

#ifdef SYMBIAN_MESSAGESTORE_UNIT_TESTCODE
	TBool iReleaseError;
	TInt iReleaseErrorOffset;
	friend class CTestEntryFreePool;	
	friend class CTestDbAdapter;
	friend class CTestIndexTableEntry;
	friend class CTestVisibleFolder;
#endif
};





/**
 ***********  INLINE FUNCTIONS   ************
 */

void CMsvEntryFreePool::BeginTransaction()
	{
	isTransactionOpen = ETrue;
	}


TInt CMsvEntryFreePool::ExcessMemoryAllocated()
	{
	if (iMsvMaxEntries < iMsvCacheNumberOfEntriesCreated)
		{
		return (iMsvCacheNumberOfEntriesCreated - iMsvMaxEntries);	
		}
	return NULL;	
	}
	
	
/**
 * RecordExcessMemoryL()
 */
void CMsvEntryFreePool::RecordExcessMemoryL(CMsvCacheEntry* aEntry)
	{	
	if(aEntry)
		{
		iUsedCacheEntries.AppendL(aEntry);
		}
	}
	
	
	
#ifdef SYMBIAN_MESSAGESTORE_UNIT_TESTCODE 
TInt CMsvEntryFreePool::GetMaximumCacheSize()
	{
	return iMsvMaximumCacheSize;
	}


TInt CMsvEntryFreePool::GetCacheThreshold()
	{
	return iMsvCacheThreshold;
	}


TInt CMsvEntryFreePool::GetCacheNumberOfEntriesCreated()
	{
	return iMsvCacheNumberOfEntriesCreated;
	}


TInt CMsvEntryFreePool::GetNumberOfEntriesPresentInFreePool()
	{
	return iMsvEntries->Count();
	}
	
TInt CMsvEntryFreePool::GetMaxEntries()
	{
	return 	iMsvMaxEntries;
	}
	
TInt CMsvEntryFreePool::GetUsedEntriesCount()
	{
	return iUsedCacheEntries.Count();
	}

#endif



#endif