windowing/windowserver/nonnga/SERVER/Direct.H
author Faisal Memon <faisal.memon@nokia.com>
Fri, 16 Jul 2010 18:54:03 +0100
branchEGL_MERGE
changeset 119 5f371025658c
parent 0 5d03bc08d59c
permissions -rw-r--r--
Chop out the code that handles "additional _E32Dll entry point after last ordinal position". I can't agree with that as how the DLL is supposed to work, and gives errors for me. Maybe the scripts to re-generate the jump tables have not been tried recently so its not a problem that's been hit by others.

// Copyright (c) 2000-2009 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:
// Definition of Direct Screen Access class
// 
//

#ifndef __DIRECT_H__
#define __DIRECT_H__

#include <e32std.h>
#include <e32base.h>
#include <w32std.h>
#include "w32cmd.h"
#include "OBJECT.H"
#include "CLIENT.H"
#include <e32msgqueue.h>

class CWsClientWindow;
class CWsDirectScreenAccess;
class CDsaMsgQueue;

NONSHARABLE_CLASS(CWsAbortDirect) : public CActive
	{
public:
	CWsAbortDirect(CWsDirectScreenAccess* aDirect,CDsaMsgQueue* aParent);
	~CWsAbortDirect();
	void Started();
	void Complete(TInt aReason);
private:
	//Pure virtual function from CActive
	void RunL();
	void DoCancel();
private:
	CWsDirectScreenAccess* iDirect;
	CDsaMsgQueue* iParent;
	};

NONSHARABLE_CLASS(CDsaMsgQueue) : public CBase
{
	public:
		static CDsaMsgQueue* NewL(CWsDirectScreenAccess* aDirect);
		~CDsaMsgQueue();
		TInt CreateSendQueue();
		TInt CreateRecQueue();
		RMsgQueueBase* SendQueue();
		RMsgQueueBase* RecQueue();
		void Cancel();
		void Complete();
		void CompleteAbort();
		void Started();
		TInt Send(TInt aData);
		TInt ReceiveData();
		TRequestStatus& Status()
		{
			return iAborted->iStatus;
		}
		
	private:
		CDsaMsgQueue();
		void ConstructL(CWsDirectScreenAccess* aDirect);
	private:
		RMsgQueueBase iSendQueue;
		RMsgQueueBase iRecQueue;
		CWsAbortDirect* iAborted;
	};

class CWsDirectScreenAccess : public CWsScreenObject
	{
public:
	enum TStatus
		{
		EDirectStatusTimeNotCreated,
		EDirectStatusNone,
		EDirectStatusInitialising,
		EDirectStatusRunning,
		EDirectStatusCompleted,
		EDirectStatusCanceling,
		EDirectStatusAbortedWindow,
		EDirectStatusAbortedGlobal,
		EDirectStatusAborted=EDirectStatusAbortedWindow,
		};		
public:
	static CWsDirectScreenAccess* NewL(CWsClient* aOwner);
	~CWsDirectScreenAccess();
	void Request(TInt handle);
	void GetRegion(TInt aNumRects);
	void Cancel();
	void Aborted();
	void AbortNow();
	TInt GetSendQueue();
	TInt GetRecQueue();
	void SignalAbort(RDirectScreenAccess::TTerminationReasons aReason);
	inline TRequestStatus& AbortStatus() {return iMsgQueue->Status();}
	void CancelAbortObject();
	void Abort();
	//Pure virtual function from CWsObject
	void CommandL(TInt aOpcode, const TAny* aCmdData);
	inline TBool IsVisible() const;
	TBool IsAbortRequired(const TRegion& aTopVisibleRegion) const;
	inline RWsRegion& VisibleRegion();
	inline CWsClientWindow* ClientWindow() const;
public:
	TSglQueLink iLink;
	TSglQueLink iMultipleDSALink;
	TSglQueLink iAbortLink; // Used to build a list of DSA objects that need to be aborted on a specific window
private:
	inline CWsDirectScreenAccess(CWsClient* aOwner): CWsScreenObject(aOwner,WS_HANDLE_DIRECT, aOwner->Screen()) {}
	void ConstructL();
	void Initiate();
	void Terminate1();
	void Terminate2();
	void CorrectScreen();
#if defined(_DEBUG)
	TBool OnQueue();
#endif
private:
	CWsClientWindow* iWin;
	RWsRegion iVisible;
	CDsaMsgQueue* iMsgQueue;
	TStatus iStatus;
	RDirectScreenAccess::TTerminationReasons iAbortReason;
public:
	TBool IsSyncTimeoutPending() const;
	inline RRegion& RegionUnderSync();
public:
	class CDSARegionSyncTimer : public CTimer
		{
		
		public:
			enum TConsts
				{
				KRegionSyncTimeoutMicrosec = 100000 // 0.1 sec
				};
		
		public:
			static CDSARegionSyncTimer* NewL(CWsDirectScreenAccess& aDSA);
		
		private:
			void RunL();
			CDSARegionSyncTimer(CWsDirectScreenAccess& aDSA);
		
		private:
			CWsDirectScreenAccess&	iDSA;
		};

private:
	void	DeleteRegionSyncWatchcat();
	void	CancelFrozenRegion();
	void 	RegionSyncTimeout();
	
private:
	CDSARegionSyncTimer*	iRegionSync;
	RRegion		iFrozenRegion;
	
	friend class CWsDirectScreenAccess::CDSARegionSyncTimer;
	};

inline TBool CWsDirectScreenAccess::IsVisible() const
	{
	return !iVisible.IsEmpty();
	}

inline CWsClientWindow* CWsDirectScreenAccess::ClientWindow() const
	{
	return iWin;
	}

inline RRegion& CWsDirectScreenAccess::RegionUnderSync() 
	{
	return iFrozenRegion;
	}
#endif