File: Logger.cpp

package info (click to toggle)
xalan 1.10-4
  • links: PTS
  • area: main
  • in suites: squeeze
  • size: 16,600 kB
  • ctags: 14,764
  • sloc: cpp: 152,342; xml: 6,835; sh: 3,267; makefile: 868; ansic: 370
file content (84 lines) | stat: -rw-r--r-- 1,362 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
/*
 * Copyright 1999-2004 The Apache Software Foundation.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */



// Base header file.  Must be first.
#include <xalanc/Include/PlatformDefinitions.hpp>



#include <ctime>
#include <iomanip>



#include "Logger.hpp"



using namespace std;



Logger::Logger(ostream & stream) :
		m_stream(stream)
{	
	logText[eMessage] = "Message";
	logText[eWarning] = "Warning";
	logText[eError] = "Error";
}



ostream& 
Logger::message()
{
	return log(eMessage);
}



ostream& 
Logger::warning()
{
	return log(eWarning);
}



ostream& 
Logger::error()
{
	return log(eError);
}


ostream& 
Logger::log(eLogType logType)
{
	time_t theTime;
	time(&theTime);

	// Not thread safe
	char * timeStr = ctime(&theTime);
	timeStr[24] = '\0';

	m_stream << timeStr << setw(10) << logText[logType] << ": ";
	return m_stream;
}