如何使用 zap 打印准确的源代码行。我创建了一个存储变量(zap logger)的包。该全局变量将在该包中的函数内部调用。问题是它没有打印实际的调用者,而是调用记录器在记录器包内调用内部函数的位置。这是我的代码:
package log
import (
zap "go.uber.org/zap"
)
var logger *zap.Logger
func Init() {
logger,_ = zap.NewDevelopment()
}
func Info(msg interface{}) {
if v,ok := msg.(string); ok {
logger.Info(v) // when I called this function it always print the caller from this line, not the caller outside who actually called this function.
} else {
logger.Info(fmt.Sprintf("%v",msg))
}
}
为实际调用者打印源行值的解决方法是什么?