1 Star 0 Fork 0

s-dy / yogurt

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
std.go 711 Bytes
一键复制 编辑 原始数据 按行查看 历史
s-dy 提交于 2022-10-14 18:30 . log, errors, app
package log
import (
"bytes"
"fmt"
"io"
"log"
"sync"
)
type stdLogger struct {
log *log.Logger
pool *sync.Pool
}
func NewStdLogger(w io.Writer) Logger {
return &stdLogger{
log: log.New(w, "", 0),
pool: &sync.Pool{New: func() any {
return new(bytes.Buffer)
}},
}
}
func (l *stdLogger) Log(level Level, keyvals ...any) error {
if len(keyvals) == 0 {
return nil
}
if (len(keyvals) & 1) == 1 {
keyvals = append(keyvals, "KEYVALS UNPAIRED")
}
buf := l.pool.Get().(*bytes.Buffer)
buf.WriteString(level.String())
for i := 0; i < len(keyvals); i += 2 {
fmt.Fprintf(buf, "%s=%v", keyvals[i], keyvals[i+1])
}
l.log.Output(4, buf.String())
buf.Reset()
l.pool.Put(buf)
return nil
}
1
https://gitee.com/sdynasty/yogurt.git
git@gitee.com:sdynasty/yogurt.git
sdynasty
yogurt
yogurt
01d4da0b550e

搜索帮助