# Packages
No description provided by the author
# README
logutils
This package is a fork of github.com/hashicorp/logutils.
logutils is a Go package that augments the standard library "log" package to make logging a bit more modern, without fragmenting the Go ecosystem with new logging packages.
The simplest thing that could possibly work
Presumably your application already uses the default log
package. To switch, you'll want your code to look like the following:
package main
import (
"log"
"os"
"github.com/fujiwara/logutils"
)
func main() {
filter := &logutils.LevelFilter{
Levels: []logutils.LogLevel{"DEBUG", "WARN", "ERROR"},
MinLevel: logutils.LogLevel("WARN"),
Writer: os.Stderr,
}
log.SetOutput(filter)
log.Print("[DEBUG] Debugging") // this will not print
log.Print("[WARN] Warning") // this will
log.Print("[ERROR] Erring") // and so will this
log.Print("Message I haven't updated") // and so will this
}
This logs to standard error exactly like go's standard logger. Any log messages you haven't converted to have a level will continue to print as before.
Color logging
package main
import (
"log"
"os"
"github.com/fujiwara/logutils"
"github.com/fatih/color"
)
func main() {
filter := &logutils.LevelFilter{
Levels: []logutils.LogLevel{"DEBUG", "WARN", "ERROR"},
ModifierFuncs: []logutils.ModifierFunc{
nil, // default
logutils.Color(color.FgYellow),
logutils.Color(color.FgRed, color.BgBlack),
},
MinLevel: logutils.LogLevel("WARN"),
Writer: os.Stderr,
}
log.SetOutput(filter)
log.Print("[DEBUG] Debugging") // this will not print
log.Print("[WARN] Warning") // this will print as yellow font
log.Print("[ERROR] Erring") // this will print as red font and black background
log.Print("Message I haven't updated") // this will print as default font(no color)
}