traceservices/commsdebugutility/SSVR/comsdbgmessages.cpp
author William Roberts <williamr@symbian.org>
Thu, 22 Jul 2010 16:49:09 +0100
branchGCC_SURGE
changeset 38 c4e342fcf0c8
parent 0 08ec8eefde2f
permissions -rw-r--r--
Catchup to latest Symbian^4

// Copyright (c) 2003-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:
// Implements the Flogger server side message processing
// 
//

/**
 @file
 @internalComponent
*/

#include "comsdbgmessages.h"
#include "comsdbgwriter.h"
#include "comsdbgaux.h"

void CTimeUpdateMessage::Invoke(MLogMessageProtocol& aProtocol)
	{
	TRAP_IGNORE(aProtocol.SetTimeL(iTime));
	//Ignore error. Worst case would mean time doesn't make it into log.
	}

CTimeUpdateMessage::CTimeUpdateMessage(const TTime& aTime)
: iTime(aTime)
{}

/////////////////////////////////////////////////////////////////////////

void CMediaUpdateMessage::Invoke(MLogMessageProtocol& aProtocol)
	{
	aProtocol.MediaUpdate(iLogMediaSetting,iForceFlushSetting, iLogPathSetting);
	}

CMediaUpdateMessage::CMediaUpdateMessage(MIniLoggingMediaQuery& aQuery)
	{
	aQuery.LogMediaSetting(iLogMediaSetting);
	// if force flush value not yet known, false will be returned.
	aQuery.FlushingOn(iForceFlushSetting);
	aQuery.LogPathSetting(iLogPathSetting);
	}

////////////////////////////////////////////////////////////////////////

CClearLogMessage::CClearLogMessage(const TFullName& aName)
: iThreadName(aName)
	{}

void CClearLogMessage::Invoke(MLogMessageProtocol& aProtocol)
	{
	aProtocol.ClearLog(iThreadName);
	}

////////////////////////////////////////////////////////////////////////

void CLogStringMessage::Invoke(MLogMessageProtocol& aProtocol)
	{
	aProtocol.LogString(*iLogString, iSubsystem, iComponent, iThreadId);
	}

CLogStringMessage::CLogStringMessage(HBufC8* aString, const TDesC8& aSubSystem, const TDesC8& aComponent, const TThreadId& aThreadId)
: iLogString(aString), iSubsystem(aSubSystem), iComponent(aComponent), iThreadId(aThreadId)
{}

CLogStringMessage::~CLogStringMessage()
	{
	delete iLogString;
	}

///////////////////////////////////////////////////////////////////////

void CLogBinaryString::Invoke(MLogMessageProtocol& aProtocol)
	{
	aProtocol.LogBinaryDump(*iBinaryString, iSubsystem, iComponent);
	}

CLogBinaryString::CLogBinaryString(HBufC8* aBinaryString, const TDesC8& aSubSystem, const TDesC8& aComponent)
: iBinaryString(aBinaryString), iSubsystem(aSubSystem), iComponent(aComponent)
	{}

CLogBinaryString::~CLogBinaryString()
	{
	delete iBinaryString;
	}

////////////////////////////////////////////////////////////

CLogCommentMessage* CLogCommentMessage::NewL(const TDesC8& aComment)
	{
	CLogCommentMessage* self = new(ELeave) CLogCommentMessage;
	CleanupStack::PushL(self);
	self->iComment = aComment.AllocL();
	CleanupStack::Pop(self);
	return self;
	}

void CLogCommentMessage::Invoke(MLogMessageProtocol& aProtocol)
	{
	aProtocol.LogComment(*iComment);
	}

CLogCommentMessage::~CLogCommentMessage()
	{
	delete iComment;
	}

CLogCommentMessage::CLogCommentMessage()
	{}

///////////////////////////////////////////////////////////////

void CShutDownMessage::Invoke(MLogMessageProtocol& aProtocol)
	{
	aProtocol.ShutDown();
	}