-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathlevel.go
64 lines (53 loc) · 1.41 KB
/
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
package log
import (
"errors"
"strconv"
)
// Level 日志级别
type Level uint8
// 所有日志级别常量,级别越高,日志越重要,级别越低,日志越详细
const (
Lall Level = iota // 等同于 Larace
Ltrace
Ldebug // 默认日志级别,方便开发
Linfo
Lwarn
Lerror
Lpanic // panic 打印错误栈,但是可以 recover
Lfatal // fatal 表明严重错误,程序直接退出,慎用
// 提供这个级别日志,方便在无论何种情况下,都打印必要信息,比如服务启动信息
Lprint
Lstack // 打印堆栈信息
)
// Labels 每个级别对应的标签
var Labels = [...]string{"all", "trace", "debug", "info", "warn", "error", "panic", "fatal", "print", "stack"}
// String 返回日志标签
func (v Level) String() string {
return Labels[v]
}
// ValueOfLevel 字符串转换成 Level, "debug" => Ldebug
func ValueOfLevel(vstr string) (v Level, err error) {
for i, label := range Labels {
if vstr == label {
return Level(i), nil
}
}
return Linfo, errors.New("level " + vstr + " not exist")
}
// MarshalJSON 便于 JSON 解析
func (v *Level) MarshalJSON() ([]byte, error) {
return []byte(strconv.Quote(v.String())), nil
}
// UnmarshalJSON 便于 JSON 解析
func (v *Level) UnmarshalJSON(b []byte) error {
vstr, err := strconv.Unquote(string(b))
if err != nil {
return err
}
x, err := ValueOfLevel(vstr)
if err != nil {
return err
}
*v = x
return nil
}