inputmethods_pub/ptiengine_iti_api/inc/PtiUserDictionary.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Wed, 18 Aug 2010 10:06:46 +0300
changeset 40 2cb9bae34d17
parent 0 eb1f2e154e89
permissions -rw-r--r--
Revision: 201031 Kit: 201033

/*
* Copyright (c) 2003-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:               Predective text input engine user dictionary 
*               class definition.
*
*/














#ifndef _PTI_USER_DICTIONARY_H
#define _PTI_USER_DICTIONARY_H

// INCLUDES
#include <e32base.h>

/**
* A base class for PtiEngine user dictionary implementations. Normally
* not needed by a client side application.
*/
class MPtiUserDictionary
	{
	public:
		/**
		* Returns user dictionary id value.
		*
		* @since S60 V2.6 
		* @return User dictionary id value.
		*/
		virtual TInt Id() const = 0;

		/**
		* Returns size of user dictionary.
		*
		* @since S60 V2.6 		
		* @return Size of user dictionary.
		*/
		virtual TInt Size() const = 0;

		/**
		* Returns Uid for core DLL.
		*
		* @since S60 V2.6 		
		* @return Uid value for core DLL.
		*/
		virtual TInt32 CoreUID() const = 0;

		/**
		* Returns a boolean value indicating whether this is the default user dictionary. 
		*
		* @since S60 V2.6 		
		* @return ETrue if this user dictionary is default user dictionary.
		*         EFalse if not.  
		*/
		virtual TBool IsDefault() const = 0;

		/**
		* Reuturns user dictionary file name.
		*
		* @since S60 V2.6 		
		* @return   User dictionary file name.
		*/
		virtual TPtrC FileName() const = 0;
		
		/**
		* Returns the amount of free space in user dictionary.
		*
		* @since S60 V2.6 		
		* @return  The Amount of free space in dictionary.
		*          Negative value if the amount of free space
		*          value couldn't be found out.
		*/		
		virtual TInt SpaceLeft() const = 0;

		/**
		* If this flag is set, PtiEngine framework calls
		* WriteL before exiting.
		*
		* @since S60 V2.6 		
		* @return A boolean valua indicating status of the update flag.
		*/
		virtual TBool UpdateFlag() const = 0;

		/**
		* Set update flag to given value. If update flag is set, PtiEngine tries
		* to save user dictionary when PtiEngine destructor is called.
		*  
		* @since S60 V2.6 				
		* @param aFlag New status for the update flag.
		*/
		virtual void SetUpdateFlag(TBool aFlag) = 0;	
	};


class CPtiUserDictionary : public CBase, public MPtiUserDictionary
	{
	public:
		IMPORT_C static CPtiUserDictionary* NewL(TInt aMaxSize);
		IMPORT_C static CPtiUserDictionary* NewL(TDesC& aFileName, TInt aMaxSize);
		IMPORT_C virtual ~CPtiUserDictionary();

		IMPORT_C virtual TInt OpenL(TDesC& aFileName, TInt aMaxSize);
		IMPORT_C virtual TInt WriteL(TDesC& aFileName);
		IMPORT_C virtual TInt WriteL();
		inline void SetFileName(TDesC& aFileName);
		inline TInt Id() const;
		inline void SetId(TInt aId);
		inline TInt Size() const;
		inline TInt32 CoreUID() const;
		inline void SetCoreUID(TInt32 aUid);
		inline virtual TPtr8 Data();
		inline TBool IsDefault() const;
		inline void SetDefault(TBool aValue);
		inline TPtrC FileName() const;
		inline TBool UpdateFlag() const;
		inline void SetUpdateFlag(TBool aFlag);	
		inline TInt SymbolClass() const;
		inline void SetSymbolClass(TInt aSymbolClass);
		IMPORT_C virtual TInt SpaceLeft() const;
		IMPORT_C virtual void SetDataL(TAny* aData, TInt aLength);

	protected:
		IMPORT_C CPtiUserDictionary();

	private:
		void ConstructL(TInt aMaxSize);
		void ConstructL(TDesC& aFileName, TInt aMaxSize);

	protected:	
		TFileName iFileName;
		HBufC8* iData;
		TInt    iId;
		TInt32  iCoreUID;
		TBool   iDefault;
		TBool   iUpdateFlag;
		TInt    iSymbolClass;
		TUint32 iChecksum;   // Holds checksum of lastest version that was saved to disk.
	};

#include "PtiUserDictionary.inl"

#endif

// End of file