From d92de1c70977308c5d9a5c5be325f1b27be2c2f4 Mon Sep 17 00:00:00 2001 From: Ophestra Date: Tue, 25 Nov 2025 01:59:29 +0900 Subject: [PATCH] internal/pipewire: check for trailing garbage This is useful during development. Signed-off-by: Ophestra --- internal/pipewire/pod.go | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/internal/pipewire/pod.go b/internal/pipewire/pod.go index e81d81b..ff82c72 100644 --- a/internal/pipewire/pod.go +++ b/internal/pipewire/pod.go @@ -172,6 +172,17 @@ type UnmarshalSetError struct{ Type reflect.Type } func (u *UnmarshalSetError) Error() string { return "cannot set: " + u.Type.String() } +// A TrailingGarbageError describes extra bytes after decoding +// has completed during [Unmarshal]. +type TrailingGarbageError struct{ Data []byte } + +func (e *TrailingGarbageError) Error() string { + if len(e.Data) < 8 { + return "got " + strconv.Itoa(len(e.Data)) + " bytes of trailing garbage" + } + return "data has extra values starting with type " + strconv.Itoa(int(binary.NativeEndian.Uint32(e.Data[4:]))) +} + // unmarshalValue implements [Unmarshal] on [reflect.Value]. func unmarshalValue(data []byte, v reflect.Value, sizeP *Word) error { switch v.Kind() { @@ -201,6 +212,10 @@ func unmarshalValue(data []byte, v reflect.Value, sizeP *Word) error { // already bounds checked by the successful unmarshalValue call data = data[8+fieldWireSize+paddingSize:] } + + if len(data) != 0 { + return &TrailingGarbageError{data} + } return nil case reflect.Pointer: