mmfenh/advancedaudiocontroller/tsrc/advancedaudiocontrollertestmodule/ActiveScheduledTestModule/src/OutputPrinter.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Wed, 14 Apr 2010 16:29:54 +0300
branchRCL_3
changeset 8 03a293c97d5c
parent 0 71ca22bcf22a
permissions -rw-r--r--
Revision: 201013 Kit: 201015

/*
* Copyright (c) 2007 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:  Active Scheduler Test Module
*
*/

// INCLUDE FILES
#include "OutputPrinter.h"
#include <StifTestModule.h>
#include "TestModuleConstants.h"

// EXTERNAL DATA STRUCTURES
// None

// EXTERNAL FUNCTION PROTOTYPES
// None

// CONSTANTS
// None

// MACROS
// None

// LOCAL CONSTANTS AND MACROS
// None

// MODULE DATA STRUCTURES
// None

// LOCAL FUNCTION PROTOTYPES
// None

// FORWARD DECLARATIONS
// None

// ==================== LOCAL FUNCTIONS =======================================
// None


/*-------------------------------------------------------------------------------

    DESCRIPTION

    This module contains the implementation of OutputPrinter class
	member functions.

-------------------------------------------------------------------------------*/

// ================= MEMBER FUNCTIONS =========================================

COutputPrinter::COutputPrinter(CTestModuleBase *aTestModule, CStifLogger *aLogger, const TDesC &aConsoleTraceDescription, const TDesC &aTracePrefix, TInt aPrintPriority)
: iPrintPriority(aPrintPriority), iConsoleTrace(aConsoleTraceDescription), iRDebugTracePrefix(aTracePrefix), iOutLogger(aLogger), iTestModule(aTestModule)
{}

/*	Sets the CStifLogger object to output data to
	Returns the previos object used.
	Note that COutputPrinter does not own the CStifLogger object and thus does not delete it
*/
CStifLogger *COutputPrinter::SetLogger(CStifLogger *aNewLogger)
	{
	CStifLogger *oldLogger = iOutLogger;
	iOutLogger = aNewLogger;
	return oldLogger;
	}

CTestModuleBase *COutputPrinter::SetTestModule(CTestModuleBase *aNewTestModule)
	{
	CTestModuleBase *oldTestModule = iTestModule;
	iTestModule = aNewTestModule;
	return oldTestModule;
	}

void COutputPrinter::Echo(const TDesC &aMessage)
	{
	//TestModuleIf().Printf(iPrintPriority, iConsoleTrace, aMessage);
	if (iTestModule)
		{
		iTestModule->TestModuleIf().Printf(iPrintPriority, iConsoleTrace, aMessage);
		}
	if (iOutLogger)
		{
		iOutLogger->Log(aMessage);
		}
	#ifdef _DEBUG
	TBuf<KMaxMessageLength> debugMessage;
	debugMessage = iRDebugTracePrefix;
	//debugMessage+= KDefaultTextSeparator;
	debugMessage+= aMessage;
	RDebug::Print(debugMessage);
	#endif
	}

void COutputPrinter::Echo(const TDesC &aFormat, const TDesC &aMessage)
	{
	TBuf<KMaxMessageLength> message;
	message.Format(aFormat, &aMessage);
	Echo(message);
	}

template<class T> void COutputPrinter::Echo(const TDesC &aFormat, T aMessage)
	{
	TBuf<KMaxMessageLength> message;
	message.Format(aFormat, aMessage);
	Echo(message);
	}

void COutputPrinter::Printf(TRefByValue<const TDesC> aLogInfo, ...)
	{
    VA_LIST list;
    VA_START( list, aLogInfo );
	TBuf<KMaxMessageLength> logInfo;
    //// Create overflow handler. If the log information size is over the
    //// KMaxLogData rest of the information will cut.
    //TDesOverflowHandler overFlowHandler( this, 1 );

    // Parse parameters
    logInfo.AppendFormatList( aLogInfo, list);
	Echo(logInfo);
	}