diff --git a/internal/pipewire/pod.go b/internal/pipewire/pod.go index 793a102..e2e8b37 100644 --- a/internal/pipewire/pod.go +++ b/internal/pipewire/pod.go @@ -143,6 +143,11 @@ func marshalValueAppendRaw(data []byte, v reflect.Value) ([]byte, error) { data = binary.NativeEndian.AppendUint32(data, Word(v.Int())) return data, nil + case reflect.Int64: + data = binary.NativeEndian.AppendUint32(data, SPA_TYPE_Long) + data = binary.NativeEndian.AppendUint64(data, uint64(v.Int())) + return data, nil + case reflect.Struct: data = binary.NativeEndian.AppendUint32(data, SPA_TYPE_Struct) var err error @@ -270,6 +275,14 @@ func unmarshalValue(data []byte, v reflect.Value, wireSizeP *Word) error { v.SetInt(int64(binary.NativeEndian.Uint32(data))) return nil + case reflect.Int64: + *wireSizeP = 8 + if err := unmarshalCheckTypeBounds(&data, SPA_TYPE_Long, wireSizeP); err != nil { + return err + } + v.SetInt(int64(binary.NativeEndian.Uint64(data))) + return nil + case reflect.Struct: *wireSizeP = 0 if err := unmarshalCheckTypeBounds(&data, SPA_TYPE_Struct, wireSizeP); err != nil {