imgtools/imglib/filesystem/include/cluster.h
author Richard Taylor <richard.i.taylor@nokia.com>
Thu, 22 Apr 2010 11:11:51 +0100
changeset 441 2a5f14510047
parent 0 044383f39525
child 590 360bd6b35136
permissions -rw-r--r--
Added tag 2.12.2 for changeset 1e23e973ab85

/*
* Copyright (c) 2006-2009 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of the License "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: 
* Cluster class for FileSystem component
* @internalComponent
* @released
*
*/


#ifndef CLUSTER_H
#define CLUSTER_H

#include "errorhandler.h"
#include "directory.h"

typedef std::multimap <unsigned int,unsigned int> TClustersPerEntryMap;

/*
 * This class is used by classes CDirRegion and CLongName. This class describes 
 * the basic Data members and Member functions related to cluster number 
 * allocation and FAT input map creation.
 *
 * @internalComponent
 * @released
 */

class CCluster
{
	public:
		static CCluster* Instance (unsigned int aClusterSize, 
								   unsigned int aTotalNumberOfClusters);

		unsigned int GetCurrentClusterNumber() const;
		void DecrementCurrentClusterNumber();
		unsigned short int GetHighWordClusterNumber() const;
		unsigned short int GetLowWordClusterNumber() const;
		void CreateMap(unsigned int aStartingClusterNumber,unsigned int aPairClusterNumber);
		TClustersPerEntryMap* GetClustersPerEntryMap();
		void UpdateNextAvailableClusterNumber();
		unsigned int GetClusterSize() const;
		~CCluster ();

	private:
		CCluster(unsigned int aClusterSize,
				 unsigned int aTotalNumberOfClusters);
		static CCluster* iClusterInstance;

		unsigned long int iClusterSize;
		unsigned int iRootClusterNumber;
		unsigned int iCurrentClusterNumber;
		unsigned int iTotalNumberOfClusters;

		
		/* used to store the mapping of Starting cluster and Number's of
		 * clusters occupied by the specific entry
		 */
		TClustersPerEntryMap iClustersPerEntry;
};

#endif //CLUSTER_H