summaryrefslogtreecommitdiff
path: root/vendor/codeberg.org/gruf/go-kv/v2/field_format.go
diff options
context:
space:
mode:
authorLibravatar kim <grufwub@gmail.com>2025-07-29 09:23:20 +0200
committerLibravatar tobi <kipvandenbos@noreply.codeberg.org>2025-07-29 09:23:20 +0200
commite3dfd8889315af38c4eef1eb4247dc07a51899c7 (patch)
tree5841d80475be7a7336ae968057f3d4ffdd2e3627 /vendor/codeberg.org/gruf/go-kv/v2/field_format.go
parent[chore] Only display report comment forwarding notice when reporting account ... (diff)
downloadgotosocial-e3dfd8889315af38c4eef1eb4247dc07a51899c7.tar.xz
[performance] bump codeberg.org/gruf/go-kv to v2 (#4341)
updates our codeberg.org/gruf/go-kv log key-value formatting library to latest version, which comes with some maaaaaaajor speed boosts in the form of: - very minimal reflect.Value{} usage - caching prepared formatting functions per type ~~still a work-in-progress until i make a release tag on the go-kv repository, which itself is waiting on published benchmark results in the README and finishing writing some code comments~~ benchmarks so far show this to be ~3x faster than the "fmt" stdlib package on average, when run across a wide variety (106 different types) of test cases, while still creating more visually friendly log output and actually recursing down nested struct ptrs Reviewed-on: https://codeberg.org/superseriousbusiness/gotosocial/pulls/4341 Co-authored-by: kim <grufwub@gmail.com> Co-committed-by: kim <grufwub@gmail.com>
Diffstat (limited to 'vendor/codeberg.org/gruf/go-kv/v2/field_format.go')
-rw-r--r--vendor/codeberg.org/gruf/go-kv/v2/field_format.go46
1 files changed, 46 insertions, 0 deletions
diff --git a/vendor/codeberg.org/gruf/go-kv/v2/field_format.go b/vendor/codeberg.org/gruf/go-kv/v2/field_format.go
new file mode 100644
index 000000000..8085d4d01
--- /dev/null
+++ b/vendor/codeberg.org/gruf/go-kv/v2/field_format.go
@@ -0,0 +1,46 @@
+//go:build kvformat
+// +build kvformat
+
+package kv
+
+import (
+ "codeberg.org/gruf/go-byteutil"
+ "codeberg.org/gruf/go-kv/v2/format"
+)
+
+var formatter format.Formatter
+
+var argsDefault = format.DefaultArgs()
+
+var argsVerbose = func() format.Args {
+ args := format.DefaultArgs()
+ args.SetWithType()
+ args.SetNoMethod()
+ return args
+}()
+
+// AppendFormat will append formatted format of Field to 'buf'. See .String() for details.
+func (f Field) AppendFormat(buf *byteutil.Buffer, vbose bool) {
+ var args format.Args
+ if vbose {
+ args = argsVerbose
+ } else {
+ args = argsDefault
+ }
+ AppendQuoteString(buf, f.K)
+ buf.WriteByte('=')
+ buf.B = formatter.Append(buf.B, f.V, args)
+}
+
+// Value returns the formatted value string of this Field.
+func (f Field) Value(vbose bool) string {
+ var args format.Args
+ if vbose {
+ args = argsVerbose
+ } else {
+ args = argsDefault
+ }
+ buf := make([]byte, 0, bufsize/2)
+ buf = formatter.Append(buf, f.V, args)
+ return byteutil.B2S(buf)
+}