version 1.5, 2001/06/16 17:30:38
|
version 1.12, 2003/03/13 20:15:57
|
|
|
//%///////////////////////////////////////////////////////////////////////////// | //%///////////////////////////////////////////////////////////////////////////// |
// | // |
// Copyright (c) 2000, 2001 The Open group, BMC Software, Tivoli Systems, IBM |
// Copyright (c) 2000, 2001, 2002 BMC Software, Hewlett-Packard Company, IBM, |
|
// The Open Group, Tivoli Systems |
// | // |
// Permission is hereby granted, free of charge, to any person obtaining a copy | // Permission is hereby granted, free of charge, to any person obtaining a copy |
// of this software and associated documentation files (the "Software"), to | // of this software and associated documentation files (the "Software"), to |
|
|
// | // |
// Author: Mike Brasher (mbrasher@bmc.com) | // Author: Mike Brasher (mbrasher@bmc.com) |
// | // |
// Modified By: |
// Modified By: Dave Rosckes (rosckes@us.ibm.com) |
// | // |
//%///////////////////////////////////////////////////////////////////////////// | //%///////////////////////////////////////////////////////////////////////////// |
| |
|
|
| |
#include <Pegasus/Common/Config.h> | #include <Pegasus/Common/Config.h> |
#include <Pegasus/Common/Formatter.h> | #include <Pegasus/Common/Formatter.h> |
|
#include <Pegasus/Common/Linkage.h> |
| |
PEGASUS_NAMESPACE_BEGIN | PEGASUS_NAMESPACE_BEGIN |
| |
class LoggerRep; | class LoggerRep; |
| |
|
// REVIEW: is this still used? Are there other mechanisms? |
|
|
/** | /** |
| |
*/ | */ |
|
|
class PEGASUS_COMMON_LINKAGE Logger | class PEGASUS_COMMON_LINKAGE Logger |
{ | { |
public: | public: |
|
|
}; | }; |
enum { NUM_LOGS = 4 }; | enum { NUM_LOGS = 4 }; |
| |
/** Log file Level - Defines the level of severity of the |
/** Log file Level - Defines the loglevel of the |
log entry irrespective of which log file it goes into. This is | log entry irrespective of which log file it goes into. This is |
actually a bit mask as defined in logger.cpp. Thus, it serves both | actually a bit mask as defined in logger.cpp. Thus, it serves both |
as a level of indication of the seriousness and possibly as a mask | as a level of indication of the seriousness and possibly as a mask |
|
|
static const Uint32 SEVERE; | static const Uint32 SEVERE; |
static const Uint32 FATAL; | static const Uint32 FATAL; |
| |
|
|
/** put - Puts a message to the defined log file | /** put - Puts a message to the defined log file |
@param logFileType - Type of log file (Trace, etc.) | @param logFileType - Type of log file (Trace, etc.) |
@param systemId - ID of the system generating the log entry within | @param systemId - ID of the system generating the log entry within |
Pegasus. This is user defined but generally breaks down into major | Pegasus. This is user defined but generally breaks down into major |
Pegasus components. | Pegasus components. |
@param level Level of severity of the log entry. To be used both t0 |
@param level logLevel of the log entry. To be used both t0 |
mark the log entry and tested against a mask to determine if log | mark the log entry and tested against a mask to determine if log |
entry should be written. | entry should be written. |
@param formatString Format definition string for the Log. See the | @param formatString Format definition string for the Log. See the |
|
|
static void put( | static void put( |
LogFileType logFileType, | LogFileType logFileType, |
const String& systemId, | const String& systemId, |
Uint32 severity, |
Uint32 logLevel, |
|
const String& formatString, |
|
const Formatter::Arg& arg0 = Formatter::Arg(), |
|
const Formatter::Arg& arg1 = Formatter::Arg(), |
|
const Formatter::Arg& arg2 = Formatter::Arg(), |
|
const Formatter::Arg& arg3 = Formatter::Arg(), |
|
const Formatter::Arg& arg4 = Formatter::Arg(), |
|
const Formatter::Arg& arg5 = Formatter::Arg(), |
|
const Formatter::Arg& arg6 = Formatter::Arg(), |
|
const Formatter::Arg& arg7 = Formatter::Arg(), |
|
const Formatter::Arg& arg8 = Formatter::Arg(), |
|
const Formatter::Arg& arg9 = Formatter::Arg()); |
|
|
|
// _trace - puts a message to the define log. Should only be used |
|
// for trace type logs |
|
static void trace( |
|
LogFileType logFileType, |
|
const String& systemId, |
|
const Uint32 logComponent, |
const String& formatString, | const String& formatString, |
const Formatter::Arg& arg0 = Formatter::Arg(), | const Formatter::Arg& arg0 = Formatter::Arg(), |
const Formatter::Arg& arg1 = Formatter::Arg(), | const Formatter::Arg& arg1 = Formatter::Arg(), |
|
|
*/ | */ |
static void clean(const String& directory); | static void clean(const String& directory); |
| |
/** setSeverityMask |
/** setlogLevelMask |
*/ | */ |
static void setSeverityMask(const Uint32); |
static void setlogLevelMask(const String logLevelList); |
| |
/** setLogWriteControlMask | /** setLogWriteControlMask |
*/ | */ |
static void setLogWriteControlMask(const Uint32); | static void setLogWriteControlMask(const Uint32); |
| |
|
static Boolean isValidlogLevel(const String logLevel); |
private: | private: |
| |
|
|
static LoggerRep* _rep; | static LoggerRep* _rep; |
static String _homeDirectory; | static String _homeDirectory; |
static Uint32 _severityMask; | static Uint32 _severityMask; |
static Uint32 _writeControlMask; | static Uint32 _writeControlMask; |
|
|
|
static const char _SEPARATOR; |
|
static const Uint32 _NUM_LOGLEVEL; |
|
|
|
static const Boolean _SUCCESS; |
|
static const Boolean _FAILURE; |
|
static void _putInternal( |
|
LogFileType logFileType, |
|
const String& systemId, |
|
const Uint32 logComponent, |
|
Uint32 logLevel, |
|
const String& formatString, |
|
const Formatter::Arg& arg0 = Formatter::Arg(), |
|
const Formatter::Arg& arg1 = Formatter::Arg(), |
|
const Formatter::Arg& arg2 = Formatter::Arg(), |
|
const Formatter::Arg& arg3 = Formatter::Arg(), |
|
const Formatter::Arg& arg4 = Formatter::Arg(), |
|
const Formatter::Arg& arg5 = Formatter::Arg(), |
|
const Formatter::Arg& arg6 = Formatter::Arg(), |
|
const Formatter::Arg& arg7 = Formatter::Arg(), |
|
const Formatter::Arg& arg8 = Formatter::Arg(), |
|
const Formatter::Arg& arg9 = Formatter::Arg()); |
|
|
}; | }; |
| |
PEGASUS_NAMESPACE_END | PEGASUS_NAMESPACE_END |