1
0
mirror of https://github.com/go-kratos/kratos.git synced 2025-01-10 00:29:01 +02:00
kratos/log/log.go

51 lines
947 B
Go
Raw Normal View History

2021-02-17 11:14:47 +02:00
package log
import "os"
2021-02-17 11:14:47 +02:00
var (
// DefaultLogger is default logger.
DefaultLogger Logger = NewStdLogger(os.Stderr)
2021-02-17 11:14:47 +02:00
)
// Logger is a logger interface.
type Logger interface {
Print(pairs ...interface{})
}
type logger struct {
log Logger
pairs []interface{}
}
func (l *logger) Print(pairs ...interface{}) {
l.log.Print(append(pairs, l.pairs...)...)
}
// With with logger kv pairs.
func With(log Logger, pairs ...interface{}) Logger {
if len(pairs) == 0 {
return log
}
return &logger{log: log, pairs: pairs}
}
// Debug returns a debug logger.
func Debug(log Logger) Logger {
return With(log, LevelKey, LevelDebug)
}
// Info returns a info logger.
func Info(log Logger) Logger {
return With(log, LevelKey, LevelInfo)
}
// Warn return a warn logger.
func Warn(log Logger) Logger {
return With(log, LevelKey, LevelWarn)
}
// Error returns a error logger.
func Error(log Logger) Logger {
return With(log, LevelKey, LevelError)
}