contacts_plat/predictivesearch_utils_api/inc/CPsData.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Wed, 14 Apr 2010 15:45:35 +0300
branchRCL_3
changeset 23 5586b4d2ec3e
parent 0 e686773b3f54
permissions -rw-r--r--
Revision: 201013 Kit: 201015

/*
* Copyright (c) 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:  Utility class to hold data for predictive search.
*                Used to marshal data between the client, server and 
*                data plugins.
*
*/

#ifndef __C_PS_DATA_H__
#define __C_PS_DATA_H__

// SYSTEM INCLUDES
#include <e32base.h>
#include <s32strm.h>
#include <e32math.h>

// CLASS DECLARATION

/**
 * Utility class to store data for predictive search.
 * This is the basic data class that is used to marshal data between 
 * the client, server and data plugins.
 *
 * @lib pcsutils.lib
 * @since S60 v3.2
 */
class CPsData : public CBase
{

public:

	/**
	* Two phase construction
	* @return Instance of CPsData
	*/
	IMPORT_C static CPsData* NewL();	 		

	/**
	* Destructor
	*/
	IMPORT_C ~CPsData();

	/**
	* Provides the unique identifier of this object
	*
	* @return Unique identifier of this object
	*/
	IMPORT_C TInt Id() const;

	/**
	* Sets the unique identifier of this object 
	* @param aId The unique identifier
	*/
	IMPORT_C void SetId(const TInt aId);


	/**
	* Provides the unique URI identifier of this object
	*
	* @return Unique URI identifier of this object
	*/
	IMPORT_C TUint8 UriId() const;

	/**
	* Sets the unique URI identifier of this object 
	* @param aUriId The unique URI identifier
	*/
	IMPORT_C void SetUriId(const TUint8 aUriId);

	/**
	* Pointer to the data element at the specified location
	*
	* @param aIndex Index of data element
	* @param Pointer to data element
	*/
	IMPORT_C HBufC* Data(TInt aIndex) const;

	/**
	* Sets the data at the specified location
	*
	* @param aIndex Index of data element
	* @param aData Data descriptor to be searched
	*/
	IMPORT_C void SetDataL(const TInt aIndex,
	       const TDesC& aData);

	/**
	* Writes 'this' to the stream
	*
	* @param aStream WriteStream with externalized contents
	*/
	IMPORT_C virtual void ExternalizeL(RWriteStream& aStream) const;		

	/**
	* Initializes 'this' from stream
	*
	* @param aStream ReadStream with data contents to be internalized
	*/
	IMPORT_C virtual void InternalizeL(RReadStream& aStream);

	/**
	* Method to compare two CPsData objects  
	*
	* @param aObject1 Instance 1 to be compared
	* @param aObject2 Instance 2 to be compared
	* @return 0 if aObject1 == aObject2
	*       -1 if aObject1 < aObject2
	*        1 if aObject1 > aObject2
	*/
	IMPORT_C static TInt CompareByData ( const CPsData& aObject1, 
		     const CPsData& aObject2 );

	/**
	* Method to compare two CPsData objects based on unique Id
	*
	* @param aObject1 Instance 1 to be compared
	* @param aObject2 Instance 2 to be compared
	* @return ETrue if aObject1 == aObject2
	*         else EFalse
	*/				     
	IMPORT_C static TBool CompareById(const CPsData& aObject1, 
		     const CPsData& aObject2);

	/**
	* Checks if data at array index is matched for predictive search
	*
	* @param aIndex Index of data element
	* @return TRUE if matched for predictive search
	*        FALSE if not matched for predictive search
	*/
	IMPORT_C TBool IsDataMatch(TInt aIndex);

	/**
	* Sets data at array index has matched for predictive search
	*
	* @param aIndex Index of data element
	*/
	IMPORT_C void SetDataMatch(TInt aIndex);		

	/**
	* Returns the data match attribute
	*
	* @return Data Match Attribute
	*/
	IMPORT_C TUint8 DataMatch(); 

	/**
	* Clear all the bits set in data matches
	*/
	IMPORT_C void ClearDataMatches();

	/**
	* Returns the number of data elements
	*
	* @return Number of data elements
	*/
	IMPORT_C TInt DataElementCount() const;

	/**
	* Returns the data extension
	*
	* @return Pointer to data extension if supported. Else NULL.
	*/
	IMPORT_C TAny* DataExtension() const;

	/**
	* Set the data extension
	*
	* @param aDataExt Data Extension for this object
	*/
	IMPORT_C void SetDataExtension(TAny* aDataExt);

	/**
	* Add element to the Integer Data Extention 
	*
	* @param aDataExt - Integer Data Extension to be added
	*/
	IMPORT_C void AddIntDataExtL(TInt aDataExt);

	/**
	* Remove element from the Integer Data Extention
	*
	* @param aIndex - Integer Data Extension array index 
	*/
	IMPORT_C void RemoveIntDataExt(TInt aIndex);

	/**
	* Retrieve Integer Data Extention Array
	*
	* @param aDataExtArray - Integer Data Extension array  
	*/

	IMPORT_C void IntDataExt(RArray<TInt>& aDataExtArray);

private:

	/**
	* Default Constructor
	*/
	CPsData();

	/**
	* Second phase constructor
	*/
	void ConstructL();		
			
private:	
				
	/**
	* Unique id 
	*/
	TInt iId;	

	/**
	* URI ID. Indicates the data source.
	*/
	TUint8 iUriId;

	/**
	* Indicates in bit positions, what data fields 
	* are matched for predictive search
	*/	
	TUint8 iDataMatches;		

	/**
	* Data fields
	*/
	RPointerArray<HBufC>* iData;

	/**
	* Extended Data field
	*/	
	TAny* iDataExtension; 

	/**
	* Extended Data field of Integers
	*/
	RArray<TInt>* iIntDataExt;
	
	/**
	* Garbage collector to fix performance issue
	*/
	RPointerArray<HBufC>* iGc;
};

#endif // __C_PS_DATA_H__

// End of file