-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathlogger.go
More file actions
64 lines (51 loc) · 1.58 KB
/
logger.go
File metadata and controls
64 lines (51 loc) · 1.58 KB
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
package log
type Logger struct {
Name string
Level Level
}
func NewLogger(category string) *Logger {
return &Logger{
category,
GetLevel(GetLevelForCategory(category), TRACE),
}
}
func (l *Logger) GetLevel() Level {
return GetLevel(GetLevelForCategory(l.Name), TRACE)
}
func (l *Logger) SetLevel(level Level) *Logger {
SetLevelForCategory(l.Name, level)
return l
}
func (l *Logger) Log(level Level, params ...interface{}) {
if IsLevelEnabled(l.GetLevel(), GetLevel(level, INFO)) && IsLevelEnabled(globalLogLevel, GetLevel(level, INFO)) {
l.log(level, params...)
}
}
func (l *Logger) log(level Level, params ...interface{}) {
event := NewLoggingEvent(l.Name, level, params)
// notify appenders, ugly.
appenders := GetAppendersForCategory(l.Name)
if appenders != nil {
for _, appender := range appenders {
appender.Log(event)
}
}
}
func (l *Logger) Trace(format string, params ...interface{}) {
l.Log(TRACE, append([]interface{}{ format }, params...)...)
}
func (l *Logger) Debug(format string, params ...interface{}) {
l.Log(DEBUG, append([]interface{}{ format }, params...)...)
}
func (l *Logger) Info(format string, params ...interface{}) {
l.Log(INFO, append([]interface{}{ format }, params...)...)
}
func (l *Logger) Warn(format string, params ...interface{}) {
l.Log(WARN, append([]interface{}{ format }, params...)...)
}
func (l *Logger) Error(format string, params ...interface{}) {
l.Log(ERROR, append([]interface{}{ format }, params...)...)
}
func (l *Logger) Fatal(format string, params ...interface{}) {
l.Log(FATAL, append([]interface{}{ format }, params...)...)
}