os/persistentdata/loggingservices/eventlogger/LogServ/src/LogServPanic.cpp
author sl@SLION-WIN7.fritz.box
Fri, 15 Jun 2012 03:10:57 +0200
changeset 0 bde4ae8d615e
permissions -rw-r--r--
First public contribution.
sl@0
     1
// Copyright (c) 2002-2009 Nokia Corporation and/or its subsidiary(-ies).
sl@0
     2
// All rights reserved.
sl@0
     3
// This component and the accompanying materials are made available
sl@0
     4
// under the terms of "Eclipse Public License v1.0"
sl@0
     5
// which accompanies this distribution, and is available
sl@0
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
sl@0
     7
//
sl@0
     8
// Initial Contributors:
sl@0
     9
// Nokia Corporation - initial contribution.
sl@0
    10
//
sl@0
    11
// Contributors:
sl@0
    12
//
sl@0
    13
// Description:
sl@0
    14
//
sl@0
    15
sl@0
    16
#include "logservpanic.h"
sl@0
    17
#include "LogServSqlStrings.h"
sl@0
    18
sl@0
    19
//
sl@0
    20
// RMessage::Panic() also completes the message. This is:
sl@0
    21
// (a) important for efficient cleanup within the kernel
sl@0
    22
// (b) a problem if the message is completed a second time
sl@0
    23
//
sl@0
    24
void PanicClientL(const RMessage2& aMessage, TLogServPanic aPanic)
sl@0
    25
	{
sl@0
    26
	aMessage.Panic(KLogServ, aPanic);
sl@0
    27
	User::Leave(KLogPanicLeave);
sl@0
    28
	}
sl@0
    29
sl@0
    30
void PanicClient(const RMessage2& aMessage, TLogServPanic aPanic)
sl@0
    31
	{
sl@0
    32
	aMessage.Panic(KLogServ, aPanic);
sl@0
    33
	}
sl@0
    34
sl@0
    35
#pragma BullseyeCoverage off
sl@0
    36
sl@0
    37
void Panic(TLogServPanic aPanic)
sl@0
    38
	{
sl@0
    39
	User::Panic(KLogServ, aPanic);
sl@0
    40
	}
sl@0
    41
sl@0
    42
#pragma BullseyeCoverage on
sl@0
    43
sl@0
    44
#ifdef LOGGING_ENABLED
sl@0
    45
sl@0
    46
const TInt KLogEngLogBufferSize = 256;
sl@0
    47
sl@0
    48
void Log::New()
sl@0
    49
	{
sl@0
    50
	_LIT(KNewLogText, "===== NEW LOG =====");
sl@0
    51
	//
sl@0
    52
	RFileLogger logger;
sl@0
    53
	TInt ret=logger.Connect();
sl@0
    54
	if	(ret==KErrNone)
sl@0
    55
		{
sl@0
    56
		logger.CreateLog(KLogFolder, KLogFileName, EFileLoggingModeOverwrite);
sl@0
    57
		logger.Write(KNewLogText);
sl@0
    58
		}
sl@0
    59
	logger.Close();
sl@0
    60
	}
sl@0
    61
sl@0
    62
void Log::Write(const TDesC& aText)
sl@0
    63
	{
sl@0
    64
	PruneLogFile();
sl@0
    65
sl@0
    66
	RFileLogger logger;
sl@0
    67
	TInt ret=logger.Connect();
sl@0
    68
	if (ret==KErrNone)
sl@0
    69
		{
sl@0
    70
		logger.SetDateAndTime(EFalse,EFalse);
sl@0
    71
		logger.CreateLog(KLogFolder, KLogFileName,EFileLoggingModeAppend);
sl@0
    72
		TBuf<KLogEngLogBufferSize> buf;
sl@0
    73
		
sl@0
    74
		// The debug log uses hometime rather than UTC for its timestamps. This is
sl@0
    75
		// purely a debugging aid.
sl@0
    76
		TTime now;
sl@0
    77
		now.HomeTime();
sl@0
    78
		TDateTime dateTime;
sl@0
    79
		dateTime = now.DateTime();
sl@0
    80
		buf.Format(KTimeFormat,dateTime.Hour(),dateTime.Minute(),dateTime.Second(),dateTime.MicroSecond());
sl@0
    81
		buf.AppendFormat(KTextFormat,&aText);
sl@0
    82
sl@0
    83
		logger.Write(buf);
sl@0
    84
		}
sl@0
    85
sl@0
    86
	logger.Close();
sl@0
    87
	}
sl@0
    88
sl@0
    89
void Log::WriteFormat(TRefByValue<const TDesC> aFmt,...)
sl@0
    90
	{
sl@0
    91
    VA_LIST list;
sl@0
    92
    VA_START(list,aFmt);
sl@0
    93
sl@0
    94
	PruneLogFile();
sl@0
    95
sl@0
    96
	TBuf<2*KLogEngLogBufferSize> buf;
sl@0
    97
	buf.SetMax();
sl@0
    98
	buf.FillZ();
sl@0
    99
	
sl@0
   100
	// The debug log uses hometime rather than UTC for its timestamps. This is
sl@0
   101
	// purely a debugging aid.
sl@0
   102
	TTime now;
sl@0
   103
	now.HomeTime();
sl@0
   104
	TDateTime dateTime;
sl@0
   105
	dateTime = now.DateTime();
sl@0
   106
	buf.Format(KTimeFormat,dateTime.Hour(),dateTime.Minute(),dateTime.Second(),dateTime.MicroSecond());
sl@0
   107
	buf.AppendFormatList(aFmt, list );
sl@0
   108
sl@0
   109
	RFileLogger logger;
sl@0
   110
	TInt ret=logger.Connect();
sl@0
   111
	if (ret==KErrNone)
sl@0
   112
		{
sl@0
   113
		logger.SetDateAndTime(EFalse,EFalse);
sl@0
   114
		logger.CreateLog(KLogFolder, KLogFileName,EFileLoggingModeAppend);
sl@0
   115
		logger.Write(buf);
sl@0
   116
		}
sl@0
   117
sl@0
   118
	logger.Close();
sl@0
   119
sl@0
   120
	}
sl@0
   121
sl@0
   122
void Log::PruneLogFile()
sl@0
   123
	{
sl@0
   124
	const TInt KMaxLogSize = 1024 * 500;
sl@0
   125
	//
sl@0
   126
	_LIT(KBaseFolder, "_:\\Logs\\");
sl@0
   127
	TFileName fileName(KBaseFolder);
sl@0
   128
	fileName[0] = 'A' + static_cast<TInt>(RFs::GetSystemDrive());
sl@0
   129
	fileName.Append(KLogFolder);
sl@0
   130
	fileName.Append(KPathDelimiter);
sl@0
   131
	fileName.Append(KLogFileName);
sl@0
   132
	//
sl@0
   133
	RFs fsSession;
sl@0
   134
	if	(fsSession.Connect() == KErrNone)
sl@0
   135
		{
sl@0
   136
		TEntry entry;
sl@0
   137
		if	(fsSession.Entry(fileName, entry) == KErrNone)
sl@0
   138
			{
sl@0
   139
			// Check size and delete if its too big
sl@0
   140
			if	(entry.iSize >= KMaxLogSize)
sl@0
   141
				{
sl@0
   142
				TInt fileDeleteErr=fsSession.Delete(fileName);
sl@0
   143
				// If a debug build - record error
sl@0
   144
				#ifdef _DEBUG
sl@0
   145
				if (fileDeleteErr != KErrNone)
sl@0
   146
					{
sl@0
   147
					RDebug::Print(_L("Log::PruneLogFile - Failed to delete file. Error = %d"), fileDeleteErr);
sl@0
   148
					}
sl@0
   149
				#else
sl@0
   150
					(void)fileDeleteErr;
sl@0
   151
				#endif
sl@0
   152
				}
sl@0
   153
			}
sl@0
   154
		}
sl@0
   155
	fsSession.Close();
sl@0
   156
	}
sl@0
   157
sl@0
   158
#endif