blocxx
Main Page
Namespaces
Classes
Files
File List
File Members
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
}
Generated by
1.8.2