kernel/eka/include/twintnotifier.h
changeset 9 96e5fb8b040d
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/kernel/eka/include/twintnotifier.h	Thu Dec 17 09:24:54 2009 +0200
@@ -0,0 +1,610 @@
+// Copyright (c) 1995-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:
+// e32\include\twintnotifier.h
+// Text Window Server text notifiers.
+// 
+// WARNING: This file contains some APIs which are internal and are subject
+//          to change without notice. Such APIs should therefore not be used
+//          outside the Kernel and Hardware Services package.
+//
+
+#ifndef __TWINTNOTIFIER_H__
+#define __TWINTNOTIFIER_H__
+
+#include <f32file.h>
+
+
+//  Notifier Plugin architecture copied from UIKON
+
+
+
+/**
+@internalComponent
+*/
+_LIT(KNotifierPlugInExt,"*.*");
+
+
+
+/**
+@publishedPartner
+@released
+
+Defines the path which is searched for notifier plugin DLLs.
+*/
+_LIT(KNotifierPlugInSearchPath,"\\sys\\bin\\tnotifiers\\");
+
+
+
+/**
+@publishedPartner
+@deprecated
+*/
+const TUid KUidNotifierPlugIn={0x10005522}; 
+
+
+
+/**
+@publishedPartner
+@released
+*/
+const TUid KUidTextNotifierPlugInV2={0x101fe38b}; 
+
+
+
+/**
+@internalComponent
+*/
+_LIT8(KNotifierPaused,"Eik_Notifier_Paused");
+
+
+
+/**
+@internalComponent
+*/
+_LIT8(KNotifierResumed,"Eik_Notifier_Resumed");
+
+
+
+enum TNotExtStatus
+/**
+@internalComponent
+*/
+	{
+	ENotExtRequestCompleted	=0,
+	ENotExtRequestQueued	=1,
+	};
+
+
+
+
+class MNotifierManager
+/**
+@publishedPartner
+@released
+
+An interface that allows notifiers to manage their own startup and shutdown.
+
+This class is likely to be of interest to notifiers that observe engines
+using publically available APIs rather than those that are run via RNotifier
+
+@see RNotifier
+*/
+	{
+public:
+    /**
+    Starts the specified notifier.
+
+	@param aNotifierUid The Uid that identifies the notifier.
+	@param aBuffer      Data that can be passed from the client-side.
+	                    The format and meaning of any data
+	                    is implementation dependent.
+	@param aResponse    Data that can be returned to the client-side.
+						The format and meaning of any data is implementation dependent.
+	*/
+	virtual void StartNotifierL(TUid aNotifierUid,const TDesC8& aBuffer,TDes8& aResponse)=0;
+	
+	
+	
+    /**
+    Cancels the specified notifier.
+ 	
+ 	@param aNotifierUid The Uid that identifies the notifier.
+    */
+	virtual void CancelNotifier(TUid aNotifierUid)=0;
+	
+	
+    /**
+    Updates a currently active notifier with new data.
+    
+    @param aNotifierUid The Uid that identifies the notifier.
+    @param aBuffer      New data that can be passed from the client-side.
+                        The format and meaning of any data is implementation dependent.
+    @param aResponse    Data that can be returned to the client-side.
+                        The format and meaning of any data is implementation dependent.
+    */
+	virtual void UpdateNotifierL(TUid aNotifierUid,const TDesC8& aBuffer,TDes8& aResponse)=0;
+	};
+
+
+
+
+class MNotifierBase2
+/**
+@publishedPartner
+@released
+
+Interface to a plug-in server side notifier for the text window server.
+
+Any number of MNotifierBase2 objects can be included in a single DLL.
+All notifiers are loaded during device startup and are not destroyed until
+the notifier server closes down.
+
+Note that the text window server is not used in production ROMs.
+It is used when testing low level code.
+*/
+	{
+public:
+    /**
+    Defines a set of notifier priorities. The use and application of these
+    values is implementation dependent. ENotifierPriorityAbsolute defines
+    the highest priority value; subsequent enum values define decreasing
+    priority values.
+    */
+	enum TNotifierPriority
+		{
+		ENotifierPriorityAbsolute=500,
+		ENotifierPriorityVHigh=400,	
+		ENotifierPriorityHigh=300,	
+		ENotifierPriorityLow=200,	
+		ENotifierPriorityVLow=100,	
+		ENotifierPriorityLowest=0	
+		};
+public:
+    /**
+    Encapsulates the notifier parameters.
+    */
+	class TNotifierInfo
+		{
+	public:
+	    /**
+	    The Uid that identifies the notifier.
+        */
+		TUid iUid;
+		
+		/**
+		The Uid that identifies the channel to be used by
+		the notifier (e.g. the screen, an LED etc).
+	    */
+		TUid iChannel;
+		
+	    /**
+	    The notifier priority, typically chosen from the standard set.
+	    
+	    @see MNotifierBase2::TNotifierPriority
+	    */
+		TInt iPriority;
+		};
+public:
+
+
+
+	/**
+	Frees all resources owned by this notifier.
+
+    This function is called by the notifier framework when all resources
+    allocated by notifiers should be freed. As a minimum, the implementation
+    should delete this object (i.e. delete this;).
+
+    Note that it is important to implement this function correctly
+    to avoid memory leaks.
+	*/
+	virtual void Release()=0;
+
+
+		
+    /**
+    Performs any initialisation that this notifier may require.
+
+    The function is called when the notifier is first loaded,
+    i.e. when the plug-in DLL is loaded. It is called only once.
+
+    As a minimum, the implementation should return a TNotifierInfo instance
+    describing the notifier parameters. A good implementation would be to set
+    up a TNotifierInfo as a data member, and then to return it. This is because
+    the same information is returned by Info().
+
+    The function is safe to leave from, so it is possible,
+    although rarely necessary, to allocate objects as you would normally do
+    in a ConstructL() function as part of two-phase construction.
+
+	@return The parameters of the notifier.
+
+	@see MNotifierBase2::Info
+    */	 
+	virtual TNotifierInfo RegisterL()=0;
+
+
+
+	/**
+	Gets the notifier parameters.
+
+    This is the same information as returned by RegisterL(), although
+    the returned values may be varied at run-time.
+	*/
+	virtual TNotifierInfo Info() const=0;
+
+
+
+	/**
+	Starts the notifier.
+
+    This is called as a result of a client-side call
+    to RNotifier::StartNotifier(), which the client uses to start a notifier
+    from which it does not expect a response.
+
+    The function is synchronous, but it should be implemented so that
+    it completes as soon as possible, allowing the notifier framework
+    to enforce its priority mechanism.
+
+    It is not possible to wait for a notifier to complete before returning
+    from this function unless the notifier is likely to finish implementing
+    its functionality immediately.
+
+	@param	aBuffer Data that can be passed from the client-side.
+	        The format and meaning of any data is implementation dependent.
+	        
+	@return A pointer descriptor representing data for the initial response
+
+	@see RNotifier::StartNotifier
+	*/ 
+	virtual TPtrC8 StartL(const TDesC8& aBuffer)=0;
+
+
+
+	/**
+	Starts the notifier.
+
+    This is called as a result of a client-side call to
+    the asynchronous function RNotifier::StartNotifierAndGetResponse().
+    This means that the client is waiting, asynchronously, for the notifier
+    to tell the client that it has finished its work.
+
+    It is important to return from this function as soon as possible,
+    
+    The implementation of a derived class must make sure that Complete() is
+    called on the RMessage2 object when the notifier is deactivated.
+
+    This function may be called multiple times if more than one client starts
+    the notifier.
+
+    @param aBuffer    Data that can be passed from the client-side. The format
+                      and meaning of any data is implementation dependent.
+    @param aReplySlot The offset within the message arguments for the reply.
+                      This message argument will refer to a modifiable
+                      descriptor, a TDes8 type, into which data
+                      can be returned. The format and meaning
+                      of any returned data is implementation dependent.
+    @param aMessage   Encapsulates a client request.
+    
+    @see RNotifier::StartNotifierAndGetResponse
+    */
+	virtual void StartL(const TDesC8& aBuffer, TInt aReplySlot, const RMessagePtr2& aMessage)=0;
+	
+	
+	
+	/**
+	Cancels an active notifier.
+
+    This is called as a result of a client-side call
+    to RNotifier::CancelNotifier().
+
+    An implementation should free any relevant resources, and complete
+    any outstanding messages, if relevant.
+    
+    @see RNotifier::CancelNotifier
+	*/ 
+	virtual void Cancel()=0;
+
+
+
+	/**
+	Updates a currently active notifier with new data.
+
+	This is called as a result of a client-side call
+	to RNotifier::UpdateNotifier().
+	
+	@param aBuffer Data that can be passed from the client-side.
+	               The format and meaning of any data is
+	               implementation dependent.
+	
+	@return A pointer descriptor representing data that may be returned.
+	        The format and meaning of any data is implementation dependent.
+
+	@see RNotifier::UpdateNotifier
+	*/ 
+	virtual TPtrC8 UpdateL(const TDesC8& aBuffer)=0;
+public:
+
+
+
+	/**
+	Sets the notifier manager.
+
+	@param aManager A pointer to the notifier manager.
+	*/
+	void SetManager(MNotifierManager* aManager);
+protected:
+	MNotifierManager* iManager;
+private:
+	TInt iNotBSpare;
+	};
+
+
+
+
+
+
+// Remaining classes are internal to the text window server
+
+
+
+class CNotifierManager;
+
+/**
+@internalComponent
+*/
+class CNotifierServer : public CServer2
+	{
+public:
+	static CNotifierServer* NewL();
+	~CNotifierServer();
+public: // from CServer2
+	CSession2* NewSessionL(const TVersion &aVersion,const RMessage2&) const;
+public:
+	CNotifierServer(TInt aPriority);
+	inline CNotifierManager* Manager() const;
+public:
+	void SetIsExiting();
+	TBool IsExiting() const;
+private:
+	void ConstructL();
+private:
+	CNotifierManager* iManager;
+	TBool iExiting;
+	};
+
+
+
+
+/**
+@internalComponent
+*/
+class CNotifierSession : public CSession2
+	{
+public:
+	CNotifierSession(const CNotifierServer& aServer);
+	~CNotifierSession();
+public: // from CSession2
+	void ServiceL(const RMessage2& aMessage);
+private:
+	enum TNotifierPanic
+		{
+		ENotifierPanicInconsistentDescriptorLengths=0,
+		ENotifierPanicPasswordWindow,
+		};
+private:
+	void DisplayAlertL(const RMessage2& aMessage);
+	void DisplayInfoMsgL(const RMessage2& aMessage);
+	void DoStartNotifierL(const RMessage2& aMessage);
+	void DoUpdateNotifierL(const RMessage2& aMessage);
+	void StartNotifierAndGetResponseL(const RMessage2& aMessage,TBool& aCleanupComplete);
+	void PanicClient(const RMessage2& aMessage,TNotifierPanic aCode);
+	static TInt InfoPrintThread(TAny* aMessage);
+	void RunPasswordWindowL(const RMessage2& aMessage);
+public:
+	static RSemaphore NotifierSemaphore;
+private:
+	const CNotifierServer* iServer;
+	TInt iClientId;
+	};
+
+
+
+
+class CQueueItem;
+class CChannelMonitor;
+class CActivityMonitor;
+class CNotifierQueue;
+
+/**
+@internalComponent
+*/
+class CNotifierManager : public CBase, public MNotifierManager
+	{
+public:
+	static CNotifierManager* NewL();
+	~CNotifierManager();
+	void RegisterL(RFs& aFs);
+	void NotifierStartL(TUid aNotifierUid,const TDesC8& aBuffer,TPtrC8* aResponse,TInt aClientId);
+	TInt NotifierUpdateL(TUid aNotifierUid,const TDesC8& aBuffer,TDes8* aResponse,TInt aClientId);
+	TInt NotifierCancel(TUid aNotifierUid);
+	void NotifierStartAndGetResponseL(TUid aNotifierUid,const TDesC8& aBuffer,TInt aReplySlot,
+										const RMessage2& aMessage,TInt aClientId,TBool& aCleanupComplete);
+	void HandleClientExit(TInt aClientId);
+	void NotifierStartAndGetResponseL(TUid aNotifierUid,TUid aChannelUid,const TDesC8& aBuffer,TInt aReplySlot,
+										const RMessage2& aMessage,TInt aClientId,TBool& aCleanupComplete);
+public: // from MNotifierManager
+	void StartNotifierL(TUid aNotifierUid,const TDesC8& aBuffer,TDes8& aResponse);
+	void CancelNotifier(TUid aNotifierUid);
+	void UpdateNotifierL(TUid aNotifierUid,const TDesC8& aBuffer,TDes8& aResponse);
+private:
+	void DoAddPlugInL(const TDesC& aPath,const TDesC& aFileName,const TUidType& aUidType);
+	CNotifierManager();
+	void ConstructL();
+	void StartFromQueueL(CQueueItem* aItem);
+private:
+	CArrayPtr<MNotifierBase2>* iObservedList;
+	CArrayFix<RLibrary>* iLibraries;
+	CChannelMonitor* iChannelMonitor;
+	CActivityMonitor* iActivityMonitor;
+	CNotifierQueue* iQueue;
+	};
+
+
+
+
+/**
+@internalComponent
+*/
+class TChannelActivity
+	{
+public:
+	inline TChannelActivity(TUid aChannel,TInt aHighestPriorityRunning);
+public:
+	TUid iChannel;
+	TInt iHighestPriorityRunning;
+	};
+
+
+
+	
+/**
+@internalComponent
+*/
+class CChannelMonitor : public CBase
+	{
+public:
+	static CChannelMonitor* NewL();
+	inline void AddNewChannelL(TUid aChannel);
+	TBool AlreadyHasChannel(TUid aChannel) const;
+	TInt ActivityLevel(TUid aChannel) const;
+	void UpdateChannel(TUid aChannel,TInt aLevel);
+private:
+	CChannelMonitor();
+private:
+	CArrayFixFlat<TChannelActivity> iMonitor;
+	};
+
+
+
+
+/**
+@internalComponent
+*/
+class CNotifierActivity : public CBase
+	{
+public:
+	static CNotifierActivity* NewLC(const MNotifierBase2::TNotifierInfo& aInfo,TInt aClientId);
+	~CNotifierActivity();
+	TInt Find(TInt aClientId) const;
+private:
+	CNotifierActivity(const MNotifierBase2::TNotifierInfo& aInfo);
+	void ConstructL(TInt aClientId);
+public:
+	const MNotifierBase2::TNotifierInfo iInfo;
+	CArrayFixFlat<TInt> iClientArray;
+	};
+
+
+
+
+/**
+@internalComponent
+*/
+class CActivityMonitor : public CBase
+	{
+public:
+	static CActivityMonitor* NewL();
+	~CActivityMonitor();
+	void AddL(const MNotifierBase2::TNotifierInfo& aInfo,TInt aClientId);
+	void Remove(TUid aNotifierUid,TInt aClientId);
+	void RemoveNotifier(TUid aNotifierUid,TUid aChannel);
+	void RemoveClient(TInt aClientId);
+	TBool IsNotifierActive(TUid aNotifierUid,TUid aChannel) const;
+	TBool IsChannelActive(TUid aChannel,TUid& aNotifier,MNotifierBase2::TNotifierPriority& aHighestPriority) const;
+	TBool IsClientPresent(TUid aNotifierUid,TUid aChannel,TInt aClientId) const;
+	TBool NotifierForClient(TUid& aNotifier,TInt aClientId) const;
+private:
+	CActivityMonitor();
+	TInt Find(TUid aNotifierUid) const;
+	TInt Find(TUid aNotifierUid,TUid aChannel) const;
+private:
+	CArrayPtrFlat<CNotifierActivity> iMonitor;
+	};
+
+
+
+
+/**
+@internalComponent
+*/
+class CQueueItem : public CBase
+	{
+public:
+	static CQueueItem* NewL(const MNotifierBase2::TNotifierInfo& aInfo,const TDesC8& aBuffer,TInt aReplySlot,
+										const RMessage2& aMessage,TInt aClientId); //Asynchronous
+	static CQueueItem* NewL(const MNotifierBase2::TNotifierInfo& aInfo,const TDesC8& aBuffer,
+										TInt aClientId); //synchronous
+	~CQueueItem();
+private:
+	CQueueItem(const MNotifierBase2::TNotifierInfo& aInfo);
+	void ConstructL(const TDesC8& aBuffer,TInt aClientId);
+	void ConstructL(const TDesC8& aBuffer,const RMessage2& aMessage,TInt aClientId,TInt aReplySlot);
+public:
+	const MNotifierBase2::TNotifierInfo iInfo;
+	HBufC8* iBuffer;
+	TBool iAsynchronous;
+	RMessage2 iMessage;  // IMPORTANT, we need to keep a full RMessage object until suport for V1 notifiers is removed
+	TInt iClientId;
+	TInt iReplySlot;
+	};
+
+
+
+
+/**
+@internalComponent
+*/
+class CNotifierQueue : public CBase
+	{
+public:
+	static CNotifierQueue* NewL();
+	inline void QueueItemL(CQueueItem* aItem);
+	CQueueItem* FetchItem(TUid aChannel);
+	TBool IsAlreadyQueued(TUid aNotifier,TUid aChannel) const;
+	void RemoveClient(TInt aClientId);
+	TInt GetHighestQueuePriority(TUid aChannel);
+private:
+	inline CNotifierQueue();
+private:
+	CArrayPtrFlat<CQueueItem> iQueue;
+	};
+
+inline TChannelActivity::TChannelActivity(TUid aChannel, TInt aHighestPriorityRunning)
+	:iChannel(aChannel),iHighestPriorityRunning(aHighestPriorityRunning)
+	{}
+
+inline void CChannelMonitor::AddNewChannelL(TUid aChannel)
+	{iMonitor.AppendL(TChannelActivity(aChannel,0));}
+
+inline CNotifierManager* CNotifierServer::Manager() const
+	{return iManager;}
+
+inline void CNotifierQueue::QueueItemL(CQueueItem* aItem)
+	{iQueue.AppendL(aItem);}
+inline CNotifierQueue::CNotifierQueue()
+	:iQueue(3)
+	{}
+
+#endif	// __TWINTNOTIFIER_H__