summaryrefslogtreecommitdiff
path: root/vendor/codeberg.org/gruf/go-mangler/v2/map.go
diff options
context:
space:
mode:
authorLibravatar kim <grufwub@gmail.com>2025-08-21 16:41:50 +0200
committerLibravatar kim <gruf@noreply.codeberg.org>2025-08-21 16:41:50 +0200
commita79f83cbded3fb1165b338ce316dc9f2217467ff (patch)
tree4b4a2b7084aced51c0a691cee6352b4ecae90df8 /vendor/codeberg.org/gruf/go-mangler/v2/map.go
parent[chore] bump golangci-lint version in CI, disable var-naming package name che... (diff)
downloadgotosocial-a79f83cbded3fb1165b338ce316dc9f2217467ff.tar.xz
[chore] update dependencies (#4386)
- codeberg.org/gruf/go-bytesize v1.0.3 -> v1.0.4 - codeberg.org/gruf/go-kv/v2 v2.0.6 -> v2.0.7 - codeberg.org/gruf/go-mutexes v1.5.2 -> v1.5.3 - codeberg.org/gruf/go-structr v0.9.7 -> v0.9.8 - codeberg.org/gruf/go-ffmpreg v0.6.8 -> v0.6.9 - github.com/tomnomnom/linkheader HEAD@2018 -> HEAD@2025 all of the above codeberg.org/gruf updates are in preparation for Go1.25, except for bytesize, and also ffmpreg which is a rebuild with the latest version of ffmpeg (v5.1.7) Reviewed-on: https://codeberg.org/superseriousbusiness/gotosocial/pulls/4386 Co-authored-by: kim <grufwub@gmail.com> Co-committed-by: kim <grufwub@gmail.com>
Diffstat (limited to 'vendor/codeberg.org/gruf/go-mangler/v2/map.go')
-rw-r--r--vendor/codeberg.org/gruf/go-mangler/v2/map.go80
1 files changed, 80 insertions, 0 deletions
diff --git a/vendor/codeberg.org/gruf/go-mangler/v2/map.go b/vendor/codeberg.org/gruf/go-mangler/v2/map.go
new file mode 100644
index 000000000..986aca4b0
--- /dev/null
+++ b/vendor/codeberg.org/gruf/go-mangler/v2/map.go
@@ -0,0 +1,80 @@
+package mangler
+
+import (
+ "unsafe"
+
+ "codeberg.org/gruf/go-xunsafe"
+)
+
+// iterMapType returns a Mangler capable of iterating
+// and mangling the given map type currently in TypeIter{}.
+// note this will fetch sub-Manglers for key / value types.
+func iterMapType(t xunsafe.TypeIter) Mangler {
+
+ // Key / value types.
+ key := t.Type.Key()
+ elem := t.Type.Elem()
+
+ // Get nested k / v TypeIters with appropriate flags.
+ flagsKey := xunsafe.ReflectMapKeyFlags(key)
+ flagsVal := xunsafe.ReflectMapElemFlags(elem)
+ kt := t.Child(key, flagsKey)
+ vt := t.Child(elem, flagsVal)
+
+ // Get key mangler.
+ kfn := loadOrGet(kt)
+ if kfn == nil {
+ return nil
+ }
+
+ // Get value mangler.
+ vfn := loadOrGet(vt)
+ if vfn == nil {
+ return nil
+ }
+
+ // Final map type.
+ rtype := t.Type
+ flags := t.Flag
+
+ return func(buf []byte, ptr unsafe.Pointer) []byte {
+ if ptr == nil || *(*unsafe.Pointer)(ptr) == nil {
+ // Append nil indicator.
+ buf = append(buf, '0')
+ return buf
+ }
+
+ // Build reflect value, and then a map iterator.
+ v := xunsafe.BuildReflectValue(rtype, ptr, flags)
+ i := xunsafe.GetMapIter(v)
+
+ // Before len.
+ l := len(buf)
+
+ // Append not-nil flag.
+ buf = append(buf, '1')
+
+ for i.Next() {
+ // Pass to map key func.
+ ptr = xunsafe.Map_Key(i)
+ buf = kfn(buf, ptr)
+
+ // Add key seperator.
+ buf = append(buf, ':')
+
+ // Pass to map elem func.
+ ptr = xunsafe.Map_Elem(i)
+ buf = vfn(buf, ptr)
+
+ // Add comma seperator.
+ buf = append(buf, ',')
+ }
+
+ if len(buf) != l {
+ // Drop final comma.
+ buf = buf[:len(buf)-1]
+ }
+
+ return buf
+ }
+}