GoToSocial/vendor/codeberg.org/gruf/go-kv
kim 51c156cca1
pull in latest go-kv, go-cache (#1530)
Signed-off-by: kim <grufwub@gmail.com>
2023-02-19 10:36:38 +01:00
..
format pull in latest go-kv, go-cache (#1530) 2023-02-19 10:36:38 +01:00
benchmark.png [chore] use our own logging implementation (#716) 2022-07-19 10:47:55 +02:00
field_fmt.go pull in latest go-kv, go-cache (#1530) 2023-02-19 10:36:38 +01:00
field_format.go pull in latest go-kv, go-cache (#1530) 2023-02-19 10:36:38 +01:00
field.go pull in latest go-kv, go-cache (#1530) 2023-02-19 10:36:38 +01:00
LICENSE [chore] use our own logging implementation (#716) 2022-07-19 10:47:55 +02:00
README.md [chore] use our own logging implementation (#716) 2022-07-19 10:47:55 +02:00
util.go pull in latest go-kv, go-cache (#1530) 2023-02-19 10:36:38 +01:00

go-kv

This library provides a key-value field structure kv.Field{} that plays well with the "fmt" package. It gives an easy means of appending key-value fields to log entries, in a manner that also happens to look nice! (it's not far removed from using a map[string]interface{}).

The formatting for these key-value fields is handled by the "fmt" package by default. If you set the kvformat build tag then it will use a custom formatting library found under format/. You can see the benchmarks for both below.

benchmarks

TODO: benchmarks comparing these to using fmt.Sprintf("%q=%+v", ...) yourself.