networkprotocolmodules/networkpmutils/supldevlogger/inc/supldevlogger.h
author hgs
Tue, 13 Jul 2010 12:25:28 +0100
changeset 48 81c9bee26a45
permissions -rw-r--r--
201025_02
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
48
81c9bee26a45 201025_02
hgs
parents:
diff changeset
     1
// Copyright (c) 2008-2009 Nokia Corporation and/or its subsidiary(-ies).
81c9bee26a45 201025_02
hgs
parents:
diff changeset
     2
// All rights reserved.
81c9bee26a45 201025_02
hgs
parents:
diff changeset
     3
// This component and the accompanying materials are made available
81c9bee26a45 201025_02
hgs
parents:
diff changeset
     4
// under the terms of "Eclipse Public License v1.0"
81c9bee26a45 201025_02
hgs
parents:
diff changeset
     5
// which accompanies this distribution, and is available
81c9bee26a45 201025_02
hgs
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
81c9bee26a45 201025_02
hgs
parents:
diff changeset
     7
//
81c9bee26a45 201025_02
hgs
parents:
diff changeset
     8
// Initial Contributors:
81c9bee26a45 201025_02
hgs
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    10
//
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    11
// Contributors:
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    12
//
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    13
// Description:
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    14
//
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    15
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    16
/**
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    17
 @file
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    18
 @internalTechnology
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    19
 
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    20
*/
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    21
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    22
#ifndef SUPL_DEV_LOGGER_H
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    23
#define SUPL_DEV_LOGGER_H
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    24
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    25
//************************************************************************************************************
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    26
#include <e32base.h>
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    27
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    28
// Literals used
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    29
_LIT(KSuplDevLogger, "SuplDevLogger");
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    30
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    31
//-------------------------------------------------------------------------------	
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    32
/** Enum for log txt priority
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    33
Priorities 0 - 2 are for logging component internal events.
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    34
Priority 3 is for logging major component events that may have a major influence on other components.
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    35
Priorities 4 - 5 are currently unassigned (TBD)
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    36
Priorities 6 - 7 are for logging internal API
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    37
Priorities 8 - 9 are for logging public API
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    38
@internalTechnology
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    39
@deprecated
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    40
*/
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    41
enum TSuplLogPriority
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    42
	{
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    43
	/** The lowest priority. Use for hex dump and other low priority information. */
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    44
	ELogP0 = 0,
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    45
	/** Use for method enter/exit logging. */
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    46
	ELogP1 = 1,
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    47
	/** Use for low priority, component internal event and data logging. */
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    48
	ELogP2 = 2,
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    49
	/** Use for important component events like timeouts, warnings and errors. */
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    50
	ELogP3 = 3,
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    51
	/** TBD (May temporarily contain old values that should be P7)*/
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    52
	ELogP4 = 4,
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    53
	/** TBD (May temporarily contain old entries that should be P9)*/
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    54
	ELogP5 = 5,
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    55
	/** Use for Internal API */
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    56
	ELogP6 = 6,	//Minor Values
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    57
	ELogP7 = 7,	//Major Values
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    58
	/** The highest priority. Use only for really major user, network or hardware events and Published API
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    59
	values. For example:
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    60
	   - MTLR/X3P/Self locate request/response/cancel
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    61
	   - location update from GPS 
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    62
	   - change in configuration
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    63
	   - privacy response from user
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    64
	   - Sequence Diagram log entries*/
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    65
	ELogP8 = 8,	//Minor Values
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    66
	ELogP9 = 9	//Major Values
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    67
	};
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    68
	
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    69
/** Log entry type.
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    70
@internalTechnology
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    71
@deprecated
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    72
*/
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    73
enum TSuplLogType
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    74
	{
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    75
	ELogNormal  = 0,
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    76
	ELogWarning = 1,
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    77
	ELogError 	= 2
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    78
	};
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    79
	
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    80
//-------------------------------------------------------------------------------	
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    81
/** Logger for development and debug purpose
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    82
The log format will be
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    83
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    84
Time | ProcessName | Process Id | Log Priority | StackPointer | Log text
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    85
08:51:00.997500 | File Name | Process Id | Log Text Priority | StackPointer | Any Log text
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    86
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    87
note the maximum buffer size limitation KLogBufferSize=150
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    88
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    89
[File Name] see RProcess::FileName()
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    90
[Process Id]see RProcess::Id() 
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    91
[Log Text Priority]  - [P0]- [P9]
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    92
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    93
@internalTechnology
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    94
@deprecated
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    95
*/
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    96
class SuplDevLogger
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    97
	{
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    98
public:
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    99
	IMPORT_C static void OverWrite(const TDesC8& aFmt);
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   100
	IMPORT_C static void OverWrite(const TDesC16& aFmt);
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   101
	
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   102
	IMPORT_C static void Write(TSuplLogType aType, TSuplLogPriority aPrior, TRefByValue<const TDesC16> aFmt, ...);
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   103
	IMPORT_C static void Write(TSuplLogType aType, TSuplLogPriority aPrior, TRefByValue<const TDesC8> aFmt, ...);
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   104
	
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   105
	IMPORT_C static void HexDump(TSuplLogPriority aPrior, const TUint8 *aPtr, TInt aLen);
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   106
	
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   107
	IMPORT_C static void GetMessageProcessName(const RMessage2& aMessage, TFileName& aName);
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   108
private:
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   109
	static void CreateLogTxt(TSuplLogType aType, TSuplLogPriority aPrior, TInt* aStackPtr, TDes16& aBuf);
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   110
	static void CreateLogTxt(TSuplLogType aType, TSuplLogPriority aPrior, TInt* aStackPtr, TDes8& aBuf);
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   111
	}; 
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   112
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   113
#endif //SUPL_DEV_LOGGER_H