|
|
- package logger
-
- import (
- "os"
-
- . "github.com/tendermint/tmlibs/common"
- "github.com/tendermint/log15"
- )
-
- var mainHandler log15.Handler
- var bypassHandler log15.Handler
-
- func init() {
- resetWithLogLevel("debug")
- }
-
- func SetLogLevel(logLevel string) {
- resetWithLogLevel(logLevel)
- }
-
- func resetWithLogLevel(logLevel string) {
- // main handler
- //handlers := []log15.Handler{}
- mainHandler = log15.LvlFilterHandler(
- getLevel(logLevel),
- log15.StreamHandler(os.Stdout, log15.TerminalFormat()),
- )
- //handlers = append(handlers, mainHandler)
-
- // bypass handler for not filtering on global logLevel.
- bypassHandler = log15.StreamHandler(os.Stdout, log15.TerminalFormat())
- //handlers = append(handlers, bypassHandler)
-
- // By setting handlers on the root, we handle events from all loggers.
- log15.Root().SetHandler(mainHandler)
- }
-
- // See go-wire/log for an example of usage.
- func MainHandler() log15.Handler {
- return mainHandler
- }
-
- func BypassHandler() log15.Handler {
- return bypassHandler
- }
-
- func New(ctx ...interface{}) log15.Logger {
- return NewMain(ctx...)
- }
-
- func NewMain(ctx ...interface{}) log15.Logger {
- return log15.Root().New(ctx...)
- }
-
- func NewBypass(ctx ...interface{}) log15.Logger {
- bypass := log15.New(ctx...)
- bypass.SetHandler(bypassHandler)
- return bypass
- }
-
- func getLevel(lvlString string) log15.Lvl {
- lvl, err := log15.LvlFromString(lvlString)
- if err != nil {
- Exit(Fmt("Invalid log level %v: %v", lvlString, err))
- }
- return lvl
- }
-
- //----------------------------------------
- // Exported from log15
-
- var LvlFilterHandler = log15.LvlFilterHandler
- var LvlDebug = log15.LvlDebug
- var LvlInfo = log15.LvlInfo
- var LvlNotice = log15.LvlNotice
- var LvlWarn = log15.LvlWarn
- var LvlError = log15.LvlError
|