blocxx
src
blocxx
ScopeLogger.cpp
Go to the documentation of this file.
1
/*******************************************************************************
2
* Copyright (C) 2005, Quest Software, Inc. All rights reserved.
3
* Copyright (C) 2006, Novell, Inc. All rights reserved.
4
*
5
* Redistribution and use in source and binary forms, with or without
6
* modification, are permitted provided that the following conditions are met:
7
*
8
* * Redistributions of source code must retain the above copyright notice,
9
* this list of conditions and the following disclaimer.
10
* * Redistributions in binary form must reproduce the above copyright
11
* notice, this list of conditions and the following disclaimer in the
12
* documentation and/or other materials provided with the distribution.
13
* * Neither the name of
14
* Quest Software, Inc.,
15
* nor Novell, Inc.,
16
* nor the names of its contributors or employees may be used to
17
* endorse or promote products derived from this software without
18
* specific prior written permission.
19
*
20
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
21
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
24
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
25
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
26
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
27
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
28
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
29
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30
* POSSIBILITY OF SUCH DAMAGE.
31
*******************************************************************************/
32
33
37
#include "
blocxx/ScopeLogger.hpp
"
38
namespace
BLOCXX_NAMESPACE
39
{
40
ScopeLogger::ScopeLogger
(
const
String
& entrance,
const
String
& exit,
const
Logger
& lgr)
41
: enterMessage(entrance)
42
, exitMessage(exit)
43
, logger(lgr)
44
, formatter()
45
{
46
logger
.
logDebug
(
enterMessage
);
47
}
48
49
ScopeLogger::ScopeLogger
(
const
String
& entrance,
const
String
& exit,
const
String
& component,
const
LogAppenderRef
& appender)
50
: enterMessage(entrance)
51
, exitMessage(exit)
52
, logger(component, appender)
53
, formatter()
54
{
55
logger
.
logDebug
(
enterMessage
);
56
}
57
58
ScopeLogger::ScopeLogger
(
const
String
& entrance,
const
String
& exit,
const
Reference<DelayedFormat>
& format,
const
Logger
& lgr)
59
: enterMessage(entrance)
60
, exitMessage(exit)
61
, logger(lgr)
62
, formatter(format)
63
{
64
if
(
formatter
)
65
{
66
logger
.
logDebug
(
enterMessage
+
formatter
->
format
());
67
}
68
else
69
{
70
logger
.
logDebug
(
enterMessage
);
71
}
72
}
73
74
ScopeLogger::ScopeLogger
(
const
String
& entrance,
const
String
& exit,
const
Reference<DelayedFormat>
& format,
const
String
& component,
const
LogAppenderRef
& appender)
75
: enterMessage(entrance)
76
, exitMessage(exit)
77
, logger(component, appender)
78
, formatter(format)
79
{
80
if
(
formatter
)
81
{
82
logger
.
logDebug
(
enterMessage
+
formatter
->
format
());
83
}
84
else
85
{
86
logger
.
logDebug
(
enterMessage
);
87
}
88
}
89
90
ScopeLogger::~ScopeLogger
()
91
{
92
// We can't allow this to throw.
93
try
94
{
95
if
(
formatter
)
96
{
97
logger
.
logDebug
(
exitMessage
+
formatter
->
format
());
98
}
99
else
100
{
101
logger
.
logDebug
(
exitMessage
);
102
}
103
}
104
catch
(...)
105
{
106
}
107
}
108
109
}
ScopeLogger.hpp
BLOCXX_NAMESPACE::IntrusiveReference< LogAppender >
BLOCXX_NAMESPACE::Logger
Logging interface.
Definition
Logger.hpp:87
BLOCXX_NAMESPACE::Logger::logDebug
void logDebug(const String &message, const char *filename=0, int fileline=-1, const char *methodname=0) const
If getLogLevel() >= E_DEBUG_LEVEL, Log debug info.
Definition
Logger.cpp:166
BLOCXX_NAMESPACE::Reference
Definition
Reference.hpp:57
BLOCXX_NAMESPACE::ScopeLogger::~ScopeLogger
virtual ~ScopeLogger()
Definition
ScopeLogger.cpp:90
BLOCXX_NAMESPACE::ScopeLogger::enterMessage
String enterMessage
Definition
ScopeLogger.hpp:104
BLOCXX_NAMESPACE::ScopeLogger::logger
Logger logger
Definition
ScopeLogger.hpp:106
BLOCXX_NAMESPACE::ScopeLogger::exitMessage
String exitMessage
Definition
ScopeLogger.hpp:105
BLOCXX_NAMESPACE::ScopeLogger::formatter
Reference< DelayedFormat > formatter
Definition
ScopeLogger.hpp:108
BLOCXX_NAMESPACE::ScopeLogger::ScopeLogger
ScopeLogger(const String &entrance, const String &exit, const Logger &lgr)
Definition
ScopeLogger.cpp:40
BLOCXX_NAMESPACE::String
This String class is an abstract data type that represents as NULL terminated string of characters.
Definition
String.hpp:67
BLOCXX_NAMESPACE::String::format
int format(const char *fmt,...)
Format this string according to the given format and variable argument list (printf style)
Definition
String.cpp:369
BLOCXX_NAMESPACE
Taken from RFC 1321.
Definition
AppenderLogger.cpp:48
Generated by
1.12.0