forked from cloudfoundry/gorouter
-
Notifications
You must be signed in to change notification settings - Fork 0
/
log_level.go
70 lines (53 loc) · 1.16 KB
/
log_level.go
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
package gosteno
import (
"encoding/json"
"fmt"
)
type LogLevel struct {
Name string
Priority int
}
var (
LOG_OFF = defineLogLevel("off", 0)
LOG_FATAL = defineLogLevel("fatal", 1)
LOG_ERROR = defineLogLevel("error", 5)
LOG_WARN = defineLogLevel("warn", 10)
LOG_INFO = defineLogLevel("info", 15)
LOG_DEBUG = defineLogLevel("debug", 16)
LOG_DEBUG1 = defineLogLevel("debug1", 17)
LOG_DEBUG2 = defineLogLevel("debug2", 18)
LOG_ALL = defineLogLevel("all", 30)
)
var levels = make(map[string]LogLevel)
func defineLogLevel(n string, p int) LogLevel {
x := LogLevel{Name: n, Priority: p}
levels[n] = x
return x
}
func GetLogLevel(name string) (LogLevel, error) {
var x LogLevel
if x, ok := levels[name]; ok {
return x, nil
}
err := fmt.Errorf("Undefined log level: %s", name)
return x, err
}
func (x LogLevel) MarshalJSON() ([]byte, error) {
return json.Marshal(x.Name)
}
func (x *LogLevel) UnmarshalJSON(data []byte) error {
var n string
err := json.Unmarshal(data, &n)
if err != nil {
return err
}
y, err := GetLogLevel(n)
if err != nil {
return err
}
*x = y
return nil
}
func (l LogLevel) String() string {
return l.Name
}