Product Promotion
0x5a.live
for different kinds of informations and explorations.
GitHub - jfcg/yell: :ledger: Yet another minimalist logging library
:ledger: Yet another minimalist logging library. Contribute to jfcg/yell development by creating an account on GitHub.
Visit SiteGitHub - jfcg/yell: :ledger: Yet another minimalist logging library
:ledger: Yet another minimalist logging library. Contribute to jfcg/yell development by creating an account on GitHub.
Powered by 0x5a.live 💗
yell
yell is yet another minimalist logging library. It comes with:
- four severity levels (info, warn, error, fatal)
- simple API
io.Writer
&sync.Locker
support- package-specific loggers
- customizations (severity names, time format, local or UTC time)
- easy, granular request location (file.go:line) logging
- semantic versioning
Example
mypkg.go:
package mypkg
import (
"os"
"github.com/jfcg/yell"
)
// log to stdout with warn or higher severity (for example).
var Logger = yell.New(": mypkg:", os.Stdout, yell.Swarn)
// Info tries to log message list with info severity
func Info(msg ...interface{}) error {
return Logger.Log(yell.Sinfo, msg...)
}
// Warn tries to log message list with warn severity
func Warn(msg ...interface{}) error {
return Logger.Log(yell.Swarn, msg...)
}
// Error tries to log message list with error severity
func Error(msg ...interface{}) (err error) {
err = Logger.Log(yell.Serror, msg...)
// extra stuff for error severity
return
}
// Fatal tries to log message list with fatal severity and panics
func Fatal(msg ...interface{}) (err error) {
err = Logger.Log(yell.Sfatal, msg...)
pm := Logger.Name() + yell.Sname[yell.Sfatal]
if err != nil {
pm += err.Error()
}
// probably panic or os.Exit(1) in a fatal situation
panic(pm)
}
myApp.go:
package main
import (
"fmt"
"mypkg"
"github.com/jfcg/yell"
)
func log() {
defer func() {
fmt.Println("recovering:", recover())
}()
// uses mypkg.Logger. yell records calling line in file.go:line format
mypkg.Info("some info:", 1, "more")
// uses yell.Default Logger, minimum severity is warning by default
yell.Warn("some warning:", "few details")
// record log() caller instead of this line
mypkg.Error(yell.Caller(1), "bad error", 3.5, "data")
// Fatal() logs & panicks
yell.Fatal("fatal mistake", 2, "hard to recover")
}
func main() {
// minimum severity for mypkg.Logger is warning, so ignored
mypkg.Info("some info:", 3, "more")
// set min severity level to info
mypkg.Logger.SetLevel(yell.Sinfo)
log()
// yell library uses local time by default, to get coordinated universal time
yell.UTC = true
log()
// change time format
yell.TimeFormat = yell.TimeFormat[:19]
log()
// customized severity names (increasing severity)
yell.Sname = [...]string{"信息:", "警告:", "错误:", "致命的:"}
yell.UTC = false
log()
// disable logging for yell.Default
yell.Default.SetLevel(yell.Snolog)
log()
}
output:
2021-03-28 21:48:53.591948: mypkg:info: myApp.go:15: some info: 1 more
2021-03-28 21:48:53.592051: myApp:warn: myApp.go:18: some warning: few details
2021-03-28 21:48:53.592063: mypkg:error: myApp.go:33: bad error 3.5 data
2021-03-28 21:48:53.592082: myApp:fatal: myApp.go:24: fatal mistake 2 hard to recover
recovering: myApp:fatal:
2021-03-28 18:48:53.592100: mypkg:info: myApp.go:15: some info: 1 more
2021-03-28 18:48:53.592110: myApp:warn: myApp.go:18: some warning: few details
2021-03-28 18:48:53.592118: mypkg:error: myApp.go:37: bad error 3.5 data
2021-03-28 18:48:53.592126: myApp:fatal: myApp.go:24: fatal mistake 2 hard to recover
recovering: myApp:fatal:
2021-03-28 18:48:53: mypkg:info: myApp.go:15: some info: 1 more
2021-03-28 18:48:53: myApp:warn: myApp.go:18: some warning: few details
2021-03-28 18:48:53: mypkg:error: myApp.go:41: bad error 3.5 data
2021-03-28 18:48:53: myApp:fatal: myApp.go:24: fatal mistake 2 hard to recover
recovering: myApp:fatal:
2021-03-28 21:48:53: mypkg:信息: myApp.go:15: some info: 1 more
2021-03-28 21:48:53: myApp:警告: myApp.go:18: some warning: few details
2021-03-28 21:48:53: mypkg:错误: myApp.go:46: bad error 3.5 data
2021-03-28 21:48:53: myApp:致命的: myApp.go:24: fatal mistake 2 hard to recover
recovering: myApp:致命的:
2021-03-28 21:48:53: mypkg:信息: myApp.go:15: some info: 1 more
2021-03-28 21:48:53: mypkg:错误: myApp.go:50: bad error 3.5 data
recovering: myApp:致命的:
Support
If you use yell and like it, please support via:
- BTC:
bc1qr8m7n0w3xes6ckmau02s47a23e84umujej822e
- ETH:
0x3a844321042D8f7c5BB2f7AB17e20273CA6277f6
GoLang Resources
are all listed below.
GitHub - GuilhermeCaruso/anko: :crystal_ball: Simple application watcher
resource
~/github.com
resource
GitHub - jidicula/go-fuzz-action: GitHub Action for Go 1.18 fuzz testing
resource
~/github.com
resource
GitHub - tucnak/climax: Climax is an alternative CLI with the human face
resource
~/github.com
resource
GitHub - lawrencewoodman/roveralls: A Go recursive coverage testing tool
resource
~/github.com
resource
GitHub - nakagami/firebirdsql: Firebird RDBMS sql driver for Go (golang)
resource
~/github.com
resource
GitHub - liweiyi88/onedump: Effortlessly database dump with one command.
resource
~/github.com
resource
GitHub - beefsack/go-astar: Go implementation of the A* search algorithm
resource
~/github.com
resource
GitHub - lxn/walk: A Windows GUI toolkit for the Go Programming Language
resource
~/github.com
resource
GitHub - mongodb/mongo-go-driver: The Official Golang driver for MongoDB
resource
~/github.com
resource
GitHub - mozillazg/go-unidecode: ASCII transliterations of Unicode text.
resource
~/github.com
resource
GitHub - bolknote/go-gd: Go bingings for GD (http://www.boutell.com/gd/)
resource
~/github.com
resource
GitHub - mosajjal/dnsmonster: Passive DNS Capture and Monitoring Toolkit
resource
~/github.com
resource
GitHub - haxpax/gosms: :mailbox_closed: Your own local SMS gateway in Go
resource
~/github.com
resource
GitHub - wajox/gobase: This is a simple skeleton for golang applications
resource
~/github.com
resource
GitHub - VividCortex/gohistogram: Streaming approximate histograms in Go
resource
~/github.com
resource
GitHub - malaschitz/randomForest: Random Forest implementation in golang
resource
~/github.com
resource
GitHub - google/gopacket: Provides packet processing capabilities for Go
resource
~/github.com
resource
GitHub - khezen/evoli: Genetic Algorithm and Particle Swarm Optimization
resource
~/github.com
resource
GitHub - didip/tollbooth: Simple middleware to rate-limit HTTP requests.
resource
~/github.com
resource
GitHub - mustafaakin/gongular: A different approach to Go web frameworks
resource
~/github.com
resource
GitHub - songgao/colorgo: Colorize (highlight) `go build` command output
resource
~/github.com
resource
Made with ❤️
to provide different kinds of informations and resources.