lbs/common/inc/LbsLogWriterEngine.h
author Maciej Seroka <maciejs@symbian.org>
Mon, 19 Apr 2010 11:21:20 +0100
branchSymbian3
changeset 23 794c6106a7e2
parent 6 c108117318cb
permissions -rw-r--r--
Changed record separator in delproxy.pl from default to LF.

/**
* 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:
*
*/





/**
 @file
 @internalTechnology
 @released
*/

#ifndef LBS_LOG_WRITER_ENGINE_H
#define LBS_LOG_WRITER_ENGINE_H

#include <e32base.h>
#include <lbslogevent.h>

enum TLbsLogEventType
/**
 enum for type of LbsLogging event handled by Lbs Logging Engine	
*/
	{
	ELbsLogNoEvent = 0,
	ELbsLogAddEvent,
	ELbsLogUpdateEvent
	};
	
	
typedef TUint32 TLbsLogWriterEventTypeGroup;

enum TLbsLogWriterEventTypes
	{
	ELbsNoEventType = 				0x00000000,
	ELbsSelfLocateEventType = 		0x00000001,
	ELbsExternalLocateEventType = 	0x00000002,
	ELbsTransmitLocationEventType = 0x00000004,
	ELbsNetworkLocateEventType = 	0x00000008,
	ELbsAssistanceDataEventType = 	0x00000010
	};
	
class CLbsLogWriterEngine : public CActive
/**
 Active class which does the logging of LBS events. When it receives a new event, 
 if it isn't processing anything it starts logging that event, otherwise it elaves it 
 on a waiting queue.
 
*/
	{
public:
	static CLbsLogWriterEngine* NewL(TUint aMaxBufferSize);
	~CLbsLogWriterEngine();
	
	TInt AddEventL(CLbsLogEvent& aLogEvent);
	TInt UpdateEventL(CLbsLogEvent& aLogEvent);
	// Start to log the event request asyn
	TInt StartAddingEventType(CLogEventType& aType);
	
private:
	CLbsLogWriterEngine(TUint aMaxBufferSize);
	void ConstructL();

	// Start to log the event request asyn
	void StartLoggingEventL(CLbsLogEvent& aLogEvent);
	void InitialiseLogEventTypeL(CLbsLogEvent& aLogEvent);
	void AddLogEventToQueueL(CLbsLogEvent& aLogEvent);
	
private: // from CActive
	void RunL();
	void DoCancel();
	TInt RunError(TInt aError);

private:
	/** The maximum numer of events that can be queued */
	TUint 							iMaxBufferSize;
	/** Flag indicating if there is an ID available of the last logged event */
	TBool 							iLastLogIdAvailable;
	/** The ID of the last logged event */
	TLogId 							iLastLogId;
	/** The array with the queued events */
	RPointerArray<CLbsLogEvent> 	iLogEvents;
	/** The array with the queued event types */
	RArray<TLbsLogEventType>		iLogEventTypes;
	/** Current processing event type */
	TLbsLogEventType				iLastLogEventType;
	/** Bitmask listing which event types have already been added */
	TLbsLogWriterEventTypeGroup		iInitLogEventTypes;
	/** The event type currently being logged */
	CLogEventType* 					iEventTypeBeingLogged; 
	/** Flag indicating if an event type is currently being added */
	TBool 							iLogEventTypeInit;
	/** The event that is being logged now */
	CLogEvent* 						iEventBeingLogged;

	/***/
	TBool							iLoggingType;
	/** Handle to the db file file sesstion */
	RFs 							iFs;
	/** CLogClient handler */
	CLogClient* 					iClient;	
	

	
__DECLARE_TEST; // Declaration for the invariant
	}; // class CLbsLogWriterEngine

#endif // LBS_LOG_WRITER_ENGINE_H