email/mail/UtilsSrc/Maillog.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Thu, 17 Dec 2009 08:44:11 +0200
changeset 0 72b543305e3a
permissions -rw-r--r--
Revision: 200949 Kit: 200951

/*
* Copyright (c) 2002 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: 
*     Class offers static utility functions for EMail.
*     
*
*/


// INCLUDE FILES

#include "MailLog.h"

#ifdef MAIL_ENABLE_LOGGING
#include <flogger.h>
#include <e32svr.h>
#include <f32file.h>

/// Folder where the log resides
_LIT( KLogFolder, "EMail" );

/// The name of the log file
_LIT( KLogFileName, "EMail.txt" );

/// The format in which the time is formatted in log
_LIT( KLogTimeFormat, "%02d,%06d ;");

/// The length of the string produced by KLogTimeFormat
const TInt KLogTimeFormatLength = 16;

/// How many characters a log line can contain
const TInt KLogLineLength = 256;

#endif // MAIL_ENABLE_LOGGING       

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

#ifdef MAIL_ENABLE_LOGGING
// ---------------------------------------------------------
// LogHeap() 
//
// ---------------------------------------------------------
void MailLog::LogHandleSize( RFile aFile )
    {       
    _LIT(KLOGHEAP, "MsgMail handle size: %d");
    TInt size(0);
    aFile.Size( size );
    Log(KLOGHEAP, size);    
    }
    

// ---------------------------------------------------------
// LogHeap() 
//
// ---------------------------------------------------------
void MailLog::LogHeap()
    {
    _LIT(KLOGHEAP, "MsgMail heap used: %d @ %d");
    TInt maxHeapSize(0);
    TInt usedHeap = User::Heap().AllocSize(maxHeapSize);
    Log(KLOGHEAP, usedHeap, maxHeapSize);    
    }

// ---------------------------------------------------------
// Log() 
//
// ---------------------------------------------------------
void MailLog::Log( TRefByValue<const TDesC> aText, ... )
    {
    VA_LIST args;
    VA_START( args, aText );

    TBuf<KLogLineLength> buf;
    buf.FormatList( aText, args );

#ifdef MAIL_LOG_TO_FILE
	RFileLogger logger;
	TInt ret = logger.Connect();
	if (ret==KErrNone)
		{
		logger.SetDateAndTime( EFalse,EFalse );
		logger.CreateLog( KLogFolder, KLogFileName, EFileLoggingModeAppend );		
		TBuf<KLogTimeFormatLength> timeStamp;
		TTime now;
		now.HomeTime();
		TDateTime dateTime;
		dateTime = now.DateTime();
		timeStamp.Format( KLogTimeFormat, 
            dateTime.Second(), dateTime.MicroSecond() );
		buf.Insert( 0, timeStamp );

		logger.Write(buf);
		}

	logger.Close();

#else
    RDebug::Print( buf );
#endif // MAIL_LOG_TO_FILE

    VA_END( args );
    }

#endif // MAIL_ENABLE_LOGGING

// End of file