gotosocial/vendor/codeberg.org/gruf/go-logger
kim 635ad2a42f
Update codeberg.org/gruf libraries and fix go-store issue (#347)
* update codeberg.org/gruf/ libraries

Signed-off-by: kim <grufwub@gmail.com>

* another update

Signed-off-by: kim <grufwub@gmail.com>
2021-12-20 10:35:32 +01:00
..
clock.go Update codeberg.org/gruf libraries and fix go-store issue (#347) 2021-12-20 10:35:32 +01:00
default.go Upstep Go dependencies (#340) 2021-12-12 15:47:51 +01:00
entry.go Upstep Go dependencies (#340) 2021-12-12 15:47:51 +01:00
format_text.go Update codeberg.org/gruf libraries and fix go-store issue (#347) 2021-12-20 10:35:32 +01:00
format.go Upstep Go dependencies (#340) 2021-12-12 15:47:51 +01:00
hook.go update dependencies (#296) 2021-11-13 12:29:08 +01:00
level.go Upstep Go dependencies (#340) 2021-12-12 15:47:51 +01:00
LICENSE update dependencies (#296) 2021-11-13 12:29:08 +01:00
logger.go Upstep Go dependencies (#340) 2021-12-12 15:47:51 +01:00
README.md Update codeberg.org/gruf libraries and fix go-store issue (#347) 2021-12-20 10:35:32 +01:00
writer.go Update dependencies (#333) 2021-11-27 15:26:58 +01:00

Fast levelled logging package with customizable formatting.

Supports logging in 2 modes:

  • no locks, fastest possible logging, no guarantees for io.Writer thread safety
  • mutex locks during writes, still far faster than standard library logger

Running without locks isn't likely to cause you any issues*, but if it does, you can wrap your io.Writer using AddSafety() when instantiating your new Logger. Even when running the benchmarks, this library has no printing issues without locks, so in most cases you'll be fine, but the safety is there if you need it.

*most logging libraries advertising high speeds are likely not performing mutex locks, which is why with this library you have the option to opt-in/out of them.

Note there are 2 uses of the unsafe package:

  • safer interface nil value checks, uses similar logic to reflect package to check if the value in the internal fat pointer is nil
  • casting a byte slice to string to allow sharing of similar byte and string methods, performs same logic as strings.Builder{}.String()