plugins/consoles/tefcons/tefcons.cpp
author Tom Sutcliffe <thomas.sutcliffe@accenture.com>
Tue, 07 Dec 2010 17:29:09 +0000
changeset 90 ceac7084e2e5
parent 83 706c7a69e448
permissions -rw-r--r--
Implemented RObjectIx-based memoryaccess APIs. Upshot is that objinfo now works again on platforms that define FSHELL_NO_DOBJECTIX_SUPPORT.

// tefcons.cpp
// 
// Copyright (c) 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
//

#include <e32std.h>
#include <e32cons.h>
#include <e32keys.h>
#include <test/testexecutelogger.h>
#include <fshell/consoleextensions.h>

NONSHARABLE_CLASS(CTefConsole) : public CConsoleBase
	{
public:
	CTefConsole();
	virtual ~CTefConsole();
	virtual TInt Create(const TDesC &aTitle,TSize aSize);
	virtual void Read(TRequestStatus &aStatus);
	virtual void ReadCancel();
	virtual void Write(const TDesC &aDes);
	virtual TPoint CursorPos() const;
	virtual void SetCursorPosAbs(const TPoint &aPoint);
	virtual void SetCursorPosRel(const TPoint &aPoint);
	virtual void SetCursorHeight(TInt aPercentage);
	virtual void SetTitle(const TDesC &aTitle);
	virtual void ClearScreen();
	virtual void ClearToEndOfLine();
	virtual TSize ScreenSize() const;
	virtual TKeyCode KeyCode() const;
	virtual TUint KeyModifiers() const;
	virtual TInt Extension_(TUint aExtensionId, TAny*& a0, TAny* a1);

	void WriteStdErr(const TDesC &aDes);

private:
	CTestExecuteLogger* iLogger;
	};

CTefConsole::CTefConsole()
	{
	}

_LIT(KDefaultLog, "c:\\logs\\testexecute\\fshell.htm");

TInt CTefConsole::Create(const TDesC& aTitle, TSize /*aSize*/)
	{
	iLogger = new CTestExecuteLogger();
	if (!iLogger) return KErrNoMemory;
	TInt logMode = TLoggerOptions(ELogHTMLOnly);
	TInt logLevel = RFileFlogger::TLogSeverity(ESevrAll);
	iLogger->SetLoggerOptions(logMode);
	TInt err = iLogger->Connect();
	if (err) return err;
	TPtrC logFilePath(KDefaultLog);
	if (aTitle.Left(5) == _L("name="))
		{
		logFilePath.Set(aTitle.Mid(5));
		}
	err = iLogger->HtmlLogger().CreateLog(logFilePath, RTestExecuteLogServ::ELogModeAppend);
	if (err) return err;
	iLogger->HtmlLogger().SetLogLevel(TLogSeverity(logLevel));

	iLogger->HtmlLogger().Write(_L("<pre>\r\n")); // horrible horrible tef logging - the client is responsible for writing markup!
	return KErrNone;
	}


CTefConsole::~CTefConsole()
	{
	if (iLogger)
		{
		iLogger->HtmlLogger().Write(_L("</pre>\r\n")); // horrible horrible tef logging - the client is responsible for writing markup!
		iLogger->Close();
		delete iLogger;
		}
	}

void CTefConsole::Read(TRequestStatus &aStatus)
	{
	TRequestStatus *pS=(&aStatus);
	User::RequestComplete(pS, KErrNotSupported);
	}

void CTefConsole::ReadCancel()
	{
	}

void CTefConsole::Write(const TDesC& aDes)
	{
	//TODO sort out the file and line
	//iLogger->LogExtra(((TText8*)__FILE__), __LINE__, ESevrInfo, aDes);
	iLogger->HtmlLogger().Write(aDes);
	}

void CTefConsole::WriteStdErr(const TDesC &aDes)
	{
	//iLogger->LogExtra(((TText8*)__FILE__), __LINE__, ESevrErr, aDes);
	iLogger->HtmlLogger().Write(aDes);
	}

TPoint CTefConsole::CursorPos() const
	{
	return TPoint(0,0);
	}

void CTefConsole::SetCursorPosAbs(const TPoint& /*aPoint*/)
	{
	}

void CTefConsole::SetCursorPosRel(const TPoint& /*aPoint*/)
	{
	}

void CTefConsole::SetCursorHeight(TInt /*aPercentage*/)
	{
	}

void CTefConsole::SetTitle(const TDesC& /*aTitle*/)
	{
	}

void CTefConsole::ClearScreen()
	{
	}

void CTefConsole::ClearToEndOfLine()
	{
	}

TSize CTefConsole::ScreenSize() const
	{
	return TSize(10,10);
	}

TKeyCode CTefConsole::KeyCode() const
	{
	return EKeyNull;
	}

TUint CTefConsole::KeyModifiers() const
	{
	return 0;
	}

extern "C" EXPORT_C TAny *NewConsole()
	{
	return(new CTefConsole);
	}

TInt CTefConsole::Extension_(TUint aExtensionId, TAny*& a0, TAny* a1)
	{
	if (aExtensionId == ConsoleStdErr::KWriteStdErrConsoleExtension)
		{
		TDesC* des = (TDesC*)a1;
		WriteStdErr(*des);
		return KErrNone;
		}
	else if (aExtensionId == ConsoleSize::KConsoleSizeReportedCorrectlyExtension)
		{
		return KErrNone;
		}
	else
		{
		return CConsoleBase::Extension_(aExtensionId, a0, a1);
		}
	
	}