windowing/windowserver/debuglog/DEBLOGFL.CPP
author jakl.martin@cell-telecom.com
Mon, 06 Dec 2010 18:07:30 +0100
branchNewGraphicsArchitecture
changeset 218 99b3451c560e
parent 0 5d03bc08d59c
child 160 969102054596
permissions -rw-r--r--
Fix for Bug 3890

// Copyright (c) 1995-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:
// code for the F32 derived class 
// 
//

#include "../SERVER/w32cmd.h"
#include "DEBLOGFL.H"

#define __FORCE_ASCII yes

#define DEFAULT_LOG_FILE_NAME _L("C:\\private\\10003b20\\WSERV.LOG")

/*#if defined(__WINS__)
#pragma data_seg(".E32_UID")
__WINS_UID(0, KWservLoggingDllUidValue, 0)
#pragma data_seg()
#endif*/


EXPORT_C CDebugLogBase *CreateDebugLog(TBool aIsFirst, TDesC &aParams)
	{
	CDebugLogFile *device=new(ELeave) CDebugLogFile();
	CDebugLog *log=NULL;
	TRAPD(err,log=new(ELeave) CDebugLog(device));
	if (err!=KErrNone)
		{
		delete device;
		User::Leave(err);
		}
	TRAP(err,log->ConstructL(aIsFirst, aParams));
	if (err!=KErrNone)
		{
		delete log;
		User::Leave(err);
		}
	return(log);
	}

CDebugLogFile::CDebugLogFile()
	{
	__DECLARE_NAME(_S("CDebugLogFile"));
	}

CDebugLogFile::~CDebugLogFile()
	{
	iFile.Close();
	iFs.Close();
	}

void CDebugLogFile::ConstructL(TBool aIsFirst, TDesC &aParams)
	{
	TPtrC defaultFileName(DEFAULT_LOG_FILE_NAME);
	TDesC *fileName=&aParams;
	if (aParams.Length()==0)
		fileName=&defaultFileName;
	User::LeaveIfError(iFs.Connect());
	//_LIT(KLog1,"Connected To File Server");
	//RDebug::Print(KLog1);
	iFs.MkDirAll(*fileName);
	if (aIsFirst)
		{
		User::LeaveIfError(iFile.Replace(iFs,*fileName,EFileStreamText|EFileWrite|EFileShareReadersOrWriters));
		//_LIT(KLog2,"Replaced File 1");
		//RDebug::Print(KLog2);
#if !defined(__FORCE_ASCII)
		TUint16 feffInt=0xFEFF;
		User::LeaveIfError(iFile.Write(TPtrC8((TUint8 *)&feffInt,2)));
#endif
		}
	else
		{
		TInt err=iFile.Open(iFs,*fileName,EFileStreamText|EFileWrite|EFileShareReadersOrWriters);
		//_LIT(KLog3,"Done ReOpen");
		//RDebug::Print(KLog3);
		if (err==KErrNone)
			{
			TInt seekpos;
			User::LeaveIfError(iFile.Seek(ESeekEnd,seekpos));
			}
		else
			User::LeaveIfError(iFile.Replace(iFs,*fileName,EFileStreamText|EFileWrite|EFileShareReadersOrWriters));
		}
	iEol16=TPtrC16((TUint16 *)_S("\r\n"));
	iEol.Set((TUint8 *)iEol16.Ptr(),iEol16.Size());
	iEol8=TPtrC8((TUint8 *)"\r\n");
	}

void CDebugLogFile::WriteToLogL(const TDesC &aDes, const TDesC &aDes2)
	{
#if defined(__FORCE_ASCII)
	TBuf8<128> des1;
	TBuf8<160> des2;
	des1.Copy(aDes);
	des2.Copy(aDes2);
	WriteToLog8L(des1,des2);
#else
	User::LeaveIfError(iFile.Write(TPtrC8((TUint8 *)aDes.Ptr(),aDes.Size())));
	User::LeaveIfError(iFile.Write(iEol));
	User::LeaveIfError(iFile.Write(TPtrC8((TUint8 *)aDes2.Ptr(),aDes2.Size())));
	iFile.Flush();		//Ignore Error
#endif
	}

void CDebugLogFile::WriteToLog8L(const TDesC8 &aDes, const TDesC8 &aDes2)
	{
	User::LeaveIfError(iFile.Write(aDes));
	User::LeaveIfError(iFile.Write(iEol8));
	User::LeaveIfError(iFile.Write(aDes2));
	iFile.Flush();		//Ignore Error
	}