|
|
// Copyright 2019, Chef. All rights reserved.
|
|
|
// https://github.com/q191201771/naza
|
|
|
//
|
|
|
// Use of this source code is governed by a MIT-style license
|
|
|
// that can be found in the License file.
|
|
|
//
|
|
|
// Author: Chef (191201771@qq.com)
|
|
|
|
|
|
package nazalog
|
|
|
|
|
|
import (
|
|
|
"fmt"
|
|
|
|
|
|
"github.com/q191201771/naza/pkg/fake"
|
|
|
)
|
|
|
|
|
|
var global Logger
|
|
|
|
|
|
func Outputf(level Level, calldepth int, format string, v ...interface{}) {
|
|
|
global.Out(level, 3, fmt.Sprintf(format, v...))
|
|
|
}
|
|
|
|
|
|
func Debugf(format string, v ...interface{}) {
|
|
|
global.Out(LevelDebug, 3, fmt.Sprintf(format, v...))
|
|
|
}
|
|
|
|
|
|
func Infof(format string, v ...interface{}) {
|
|
|
global.Out(LevelInfo, 3, fmt.Sprintf(format, v...))
|
|
|
}
|
|
|
|
|
|
func Warnf(format string, v ...interface{}) {
|
|
|
global.Out(LevelWarn, 3, fmt.Sprintf(format, v...))
|
|
|
}
|
|
|
|
|
|
func Errorf(format string, v ...interface{}) {
|
|
|
global.Out(LevelError, 3, fmt.Sprintf(format, v...))
|
|
|
}
|
|
|
|
|
|
func Fatalf(format string, v ...interface{}) {
|
|
|
global.Out(LevelFatal, 3, fmt.Sprintf(format, v...))
|
|
|
fake.Exit(1)
|
|
|
}
|
|
|
|
|
|
func Panicf(format string, v ...interface{}) {
|
|
|
global.Out(LevelPanic, 3, fmt.Sprintf(format, v...))
|
|
|
}
|
|
|
|
|
|
func Output(level Level, calldepth int, v ...interface{}) {
|
|
|
global.Out(level, 3, fmt.Sprint(v...))
|
|
|
}
|
|
|
|
|
|
func Debug(v ...interface{}) {
|
|
|
global.Out(LevelDebug, 3, fmt.Sprint(v...))
|
|
|
}
|
|
|
|
|
|
func Info(v ...interface{}) {
|
|
|
global.Out(LevelInfo, 3, fmt.Sprint(v...))
|
|
|
}
|
|
|
|
|
|
func Warn(v ...interface{}) {
|
|
|
global.Out(LevelWarn, 3, fmt.Sprint(v...))
|
|
|
}
|
|
|
|
|
|
func Error(v ...interface{}) {
|
|
|
global.Out(LevelError, 3, fmt.Sprint(v...))
|
|
|
}
|
|
|
|
|
|
func Fatal(v ...interface{}) {
|
|
|
global.Out(LevelFatal, 3, fmt.Sprint(v...))
|
|
|
fake.Exit(1)
|
|
|
}
|
|
|
|
|
|
func Panic(v ...interface{}) {
|
|
|
global.Out(LevelPanic, 3, fmt.Sprint(v...))
|
|
|
}
|
|
|
|
|
|
func FatalIfErrorNotNil(err error) {
|
|
|
if err != nil {
|
|
|
global.Out(LevelError, 3, fmt.Sprintf("fatal since error not nil. err=%+v", err))
|
|
|
fake.Exit(1)
|
|
|
}
|
|
|
}
|
|
|
|
|
|
func PanicIfErrorNotNil(err error) {
|
|
|
if err != nil {
|
|
|
global.Out(LevelPanic, 3, fmt.Sprintf("fatal since error not nil. err=%+v", err))
|
|
|
panic(err)
|
|
|
}
|
|
|
}
|
|
|
|
|
|
func Out(level Level, calldepth int, s string) {
|
|
|
global.Out(level, calldepth, s)
|
|
|
}
|
|
|
|
|
|
// 这里不加锁保护,如果要调用Init函数初始化全局的Logger,那么由调用方保证调用Init函数时不会并发调用全局Logger的其他方法
|
|
|
func Init(modOptions ...ModOption) error {
|
|
|
var err error
|
|
|
global, err = New(modOptions...)
|
|
|
return err
|
|
|
}
|
|
|
|
|
|
func init() {
|
|
|
_ = Init()
|
|
|
}
|