Implemented RObjectIx-based memoryaccess APIs.
Upshot is that objinfo now works again on platforms that define FSHELL_NO_DOBJECTIX_SUPPORT.
// server.h
// 
// Copyright (c) 2006 - 2010 Accenture. All rights reserved.
// This component and the accompanying materials are made available
// under the terms of the "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:
// Accenture - Initial contribution
//
#ifndef __SERVER_H__
#define __SERVER_H__
#ifdef EKA2
#define RMsg RMessage2
#else
#define RMsg RMessage
#endif
#include <e32base.h>
#include <f32file.h>
#include <e32hashtab.h>
#include "iocli.h"
#include "clientserver.h"
#include "log.h"
#include "config.h"
enum TIoPanicReason
	{
	EPanicBadDescriptor = 0,
	EPanicBadHandle = 1,
	EPanicUnknownOpcode = 2,
	EPanicReadAlreadyPending = 3,
	EPanicReadKeyAlreadyPending = 4,
	EPanicReadWhenNotAttached = 5,
	EPanicWriteAlreadyPending = 6,
	EPanicWriteWhenNotAttached = 7,
	EPanicReadKeyWhenNotAttached = 8,
	EPanicCursorPosWhenNotAttached = 9,
	EPanicSetCursorPosAbsWhenNotAttached = 10,
	EPanicSetCursorPosRelWhenNotAttached = 11,
	EPanicSetCursorHeightWhenNotAttached = 12,
	EPanicSetTitleWhenNotAttached = 13,
	EPanicClearScreenWhenNotAttached = 14,
	EPanicClearToEndOfLineWhenNotAttached = 15,
	EPanicScreenSizeWhenNotAttached = 16,
	EPanicInvalidPipeId = 17,
	EPanicSetConsoleModeWhenNotAttached = 18,
	EPanicNotAnEndPoint = 19,
	EPanicNotAPipe = 20,
	EPanicNotAConsole = 21,
	EPanicNotAReadWriteObject = 22,
	EPanicNotAReadObject = 23,
	EPanicNotAWriteObject = 24,
	EPanicNotAPersistentConsole = 25,
	EPanicNotAValidContainerType = 26,
	EPanicFindNextWithNoFindFirst = 27,
	EPanicOpenFoundWithNoFind = 28,
	EPanicSetTitleAlreadyPending = 29,
	EPanicCursorPosAlreadyPending = 30,
	EPanicSetCursorPosAlreadyPending = 31,
	EPanicSetCursorHeightAlreadyPending = 32,
	EPanicClearScreenAlreadyPending = 33,
	EPanicClearToEndOfLineAlreadyPending = 34, 
	EPanicScreenSizeAlreadyPending = 35,
	EPanicSetReadModeAlreadyPending = 36,
	EPanicCannotReadFromUnderlyingConsole = 37,
	EPanicSetAttributesWhenNotAttached = 38,
	EPanicSetAttributesAlreadyPending = 39,
	EPanicSetModeAlreadyPending = 40
	};
void PanicClient(const RMsg& aMessage, TIoPanicReason aReason);
class CIoObject;
class CIoLog;
class CIoPipe;
class CIoConsole;
class CIoFile;
class CIoNull;
class CIoPersistentConsole;
class CIoReadWriteObject;
class CIoReadObject;
class CIoWriteObject;
class MIoWriteEndPoint;
class CShutdownTimer : public CTimer
	{
	enum {KShutdownDelay = 0x2000000};
public:
	CShutdownTimer();
	void ConstructL();
	void Start();
private:
	void RunL();
	};
#ifdef EKA2
class CIoServer : public CServer2
#else
class CIoServer : public CServer
#endif
	{
public:
#ifdef EKA2
	static CServer2* NewLC();
#else
	static CServer* NewLC();
#endif
	~CIoServer();
	void AddSession();
	void DropSession();
	CIoPipe& CreatePipeLC();
	CIoConsole& CreateConsoleLC(const TDesC& aImplementation, const TDesC& aTitle, TSize aSize, MIoWriteEndPoint* aUnderlyingConsole, TUint aOptions);
	CIoFile& CreateFileLC(const TDesC& aName, RIoFile::TMode aMode);
	CIoNull& CreateNullLC();
	CIoPersistentConsole& CreatePersistentConsoleLC(const TDesC& aName, const TDesC& aTitle, const RMsg& aMessage);
	CIoReadObject& CreateReadObjLC();
	CIoWriteObject& CreateWriteObjLC();
	CIoReadObject* NextReadObj(TThreadId aOwningThread) const;
	CIoWriteObject* NextWriteObj(TThreadId aOwningThread) const;
	CIoReadObject* LastOpenedReadObj(TThreadId aOwningThread) const;
	CIoWriteObject* LastOpenedWriteObj(TThreadId aOwningThread) const;
	CIoPersistentConsole& FindPersistentConsoleL(const TDesC& aName);
	CIoObject* FindObjectByName(RIoHandle::TType aType, TInt& aFindHandle, const TDesC& aMatch, TName& aName) const;
	CIoObject& OpenObjectLC(TInt aFindHandle);
	const TIoConfig& Config();
	void PersistentConsoleAddL(const TDesC16& aName, const CIoPersistentConsole& aCons);
	void PersistentConsoleRemove(const TDesC16& aName, const CIoPersistentConsole& aCons);
private:
	CIoServer();
	void ConstructL();
#ifdef EKA2
	virtual CSession2* NewSessionL(const TVersion& aVersion, const RMessage2& aMessage) const;
#else
	virtual CSharableSession* NewSessionL(const TVersion& aVersion) const;
#endif
	TInt RunError(TInt aError);
	CIoReadWriteObject* DoFindObj(RIoHandle::TType aType, TThreadId aOwningThread, TBool aNext) const;
private:
	RFs iFs;
	TInt iSessionCount;
	CShutdownTimer iShutdownTimer;
	CObjectConIx* iIoObjectContainerIndex; 
	CObjectCon* iIoObjectContainer;
	TUint iNextReadObjId;
	TUint iNextWriteObjId;
	TIoConfig iConfig;
	RPtrHashMap<TDesC16, CIoPersistentConsole> iPersistentConsoleNames;
#ifdef IOSRV_LOGGING
	CIoLog* iLog;
#endif
	};
	
TInt DesLengthL(const RMsg& aMessage, TInt aParam);
TInt MaxDesLengthL(const RMsg& aMessage, TInt aParam);
void MessageReadL(const RMsg& aMessage, TInt aParam, TDes8& aDes);
void MessageReadL(const RMsg& aMessage, TInt aParam, TDes8& aDes, TInt aOffset);
void MessageReadL(const RMsg& aMessage, TInt aParam, TDes16& aDes);
void MessageReadL(const RMsg& aMessage, TInt aParam, TDes16& aDes, TInt aOffset);
void MessageWriteL(const RMsg& aMessage, TInt aParam, const TDesC8& aDes);
void MessageWriteL(const RMsg& aMessage, TInt aParam, const TDesC16& aDes);
TInt MessageWrite(const RMsg& aMessage, TInt aParam, const TDesC8& aDes);
TInt MessageWrite(const RMsg& aMessage, TInt aParam, const TDesC16& aDes);
TBool MessagePending(const RMsg& aMessage);
TThreadId ClientThreadIdL(const RMsg& aMessage);
TFullName ClientNameL(const RMsg& aMessage);
void Complete(const RMsg& aMessage, TInt aError);
void CompleteIfPending(const RMsg& aMessage, TInt aError);
#endif // __SERVER_H__