serviceproviders/sapi_landmarks/landmarksservice/inc/clandmarkcmdbase.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 14 Sep 2010 22:59:08 +0300
branchRCL_3
changeset 46 5146369cfdc9
parent 5 989d2f495d90
permissions -rw-r--r--
Revision: 201033 Kit: 201035

/*
* Copyright (c) 2005-2006 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:  CLandmarkCmdBase class
 *
*/


#ifndef __CLANDMARKCMDBASE_H__
#define __CLANDMARKCMDBASE_H__

// INCLUDES
#include <e32base.h>

//FORWARD DECLARATION
class CLandmarkHandler;
class CLandmarkFilter;
class MLandmarkObserver;
class CPosLmOperation;
class CLandmarkManageObjects;

/**
 * CLandmarkCmdBase
 * This class inherits from CActive. 
 * This forms the base class for all active objects related to landmarks database async requests.
 * TransactionId()  returns the transaction id of the active object.
 * StartL ( CLandmarkHandler* aHandle, TInt32 aTransactionId, 
 *					 CLandmarkFilter* aFilter ) is a pure virtual function that has to be implemented.
 */
// CLASS DECLARATION
NONSHARABLE_CLASS(CLandmarkCmdBase): public CActive
	{
public: //destructor

	/**
	 * ~CLandmarkCmdBase.
	 * Destructor.
	 */
	virtual ~CLandmarkCmdBase()
		{}

	/**
	 * TransactionId.
	 * @return The transaction id of the active object.
	 */
	inline TInt32 TransactionId();

	/**
	 * StartL.
	 * This function has to be implemented for starting the asynchronous search operation.
	 * @param aHandle The CLandmarkHandler instance that has the handle to the database 
	 * on which the search operation is to be made.
	 * @param aTransactionId The transaction id assigned to the asynchronous call.
	 * @param aFilter The filter to be used for the search.
	 */
	virtual void StartL ( CLandmarkHandler* aHandle, TInt32 aTransactionId,
			CLandmarkFilter& aFilter ) = 0;

protected: //constructor

	/**
	 * CLandmarkCmdBase.
	 * Constructor.
	 */
	inline CLandmarkCmdBase();

protected: // Data members

	/**
	 * iTransactionId
	 * The tranaction id assigned to aync request.
	 */
	TInt32 iTransactionId;

	/**
	 * iObserver
	 * The handle to the MLandmarkObserver.
	 */
	MLandmarkObserver* iObserver;

	/**
	 * iHandle
	 * The handle to the CLandmarkHandler.
	 */
	CLandmarkHandler* iHandle;

	/**
	 * iSearchOperation
	 * The handle to the CPosLmOperation.
	 */
	CPosLmOperation* iSearchOperation;

	/**
	 * iManageObjects
	 * The handle to the garbage collector.
	 */
	CLandmarkManageObjects* iManageObjects;

	/**
	 * iProgress
	 * To keep track of search progress.
	 */
	TReal32 iProgress;
	};

#include "clandmarkcmdbase.inl"

#endif // __CLANDMARKCMDBASE_H__

// End of File