diff options
author | Péter Szilágyi <peterke@gmail.com> | 2017-02-21 00:05:15 +0800 |
---|---|---|
committer | Péter Szilágyi <peterke@gmail.com> | 2017-02-23 18:00:03 +0800 |
commit | b9d48b4a9300b948362787b90cf3fb7ae77636b4 (patch) | |
tree | 9ed9d16374bd6c7f2cadd0a193e16fc5bc5c9ee3 /log/logger.go | |
parent | ec7f81f4bc11c6f8203ec1d3055c9a09a244ff43 (diff) | |
download | go-tangerine-b9d48b4a9300b948362787b90cf3fb7ae77636b4.tar go-tangerine-b9d48b4a9300b948362787b90cf3fb7ae77636b4.tar.gz go-tangerine-b9d48b4a9300b948362787b90cf3fb7ae77636b4.tar.bz2 go-tangerine-b9d48b4a9300b948362787b90cf3fb7ae77636b4.tar.lz go-tangerine-b9d48b4a9300b948362787b90cf3fb7ae77636b4.tar.xz go-tangerine-b9d48b4a9300b948362787b90cf3fb7ae77636b4.tar.zst go-tangerine-b9d48b4a9300b948362787b90cf3fb7ae77636b4.zip |
log: add support for trace level, exit on critical
Diffstat (limited to 'log/logger.go')
-rw-r--r-- | log/logger.go | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/log/logger.go b/log/logger.go index a9d42b8da..a7f7d9df7 100644 --- a/log/logger.go +++ b/log/logger.go @@ -2,6 +2,7 @@ package log import ( "fmt" + "os" "time" "github.com/go-stack/stack" @@ -20,11 +21,14 @@ const ( LvlWarn LvlInfo LvlDebug + LvlTrace ) // Returns the name of a Lvl func (l Lvl) String() string { switch l { + case LvlTrace: + return "trce" case LvlDebug: return "dbug" case LvlInfo: @@ -44,6 +48,8 @@ func (l Lvl) String() string { // Useful for parsing command line args and configuration files. func LvlFromString(lvlString string) (Lvl, error) { switch lvlString { + case "trace", "trce": + return LvlTrace, nil case "debug", "dbug": return LvlDebug, nil case "info": @@ -87,6 +93,7 @@ type Logger interface { SetHandler(h Handler) // Log a message at the given level with context key/value pairs + Trace(msg string, ctx ...interface{}) Debug(msg string, ctx ...interface{}) Info(msg string, ctx ...interface{}) Warn(msg string, ctx ...interface{}) @@ -128,6 +135,10 @@ func newContext(prefix []interface{}, suffix []interface{}) []interface{} { return newCtx } +func (l *logger) Trace(msg string, ctx ...interface{}) { + l.write(msg, LvlTrace, ctx) +} + func (l *logger) Debug(msg string, ctx ...interface{}) { l.write(msg, LvlDebug, ctx) } @@ -146,6 +157,7 @@ func (l *logger) Error(msg string, ctx ...interface{}) { func (l *logger) Crit(msg string, ctx ...interface{}) { l.write(msg, LvlCrit, ctx) + os.Exit(1) } func (l *logger) GetHandler() Handler { |