All checks were successful
Test / Create distribution (push) Successful in 36s
Test / Sandbox (push) Successful in 2m35s
Test / Sandbox (race detector) (push) Successful in 4m45s
Test / Hakurei (push) Successful in 5m0s
Test / Hpkg (push) Successful in 5m7s
Test / Hakurei (race detector) (push) Successful in 6m37s
Test / Flake checks (push) Successful in 1m34s
This consumes the entire sample, is validated to send identical messages and correctly handle received messages. Signed-off-by: Ophestra <cat@gensokyo.uk>
119 lines
3.4 KiB
Go
119 lines
3.4 KiB
Go
package pipewire
|
|
|
|
/* pipewire/client.h */
|
|
|
|
const (
|
|
PW_TYPE_INTERFACE_Client = PW_TYPE_INFO_INTERFACE_BASE + "Client"
|
|
PW_CLIENT_PERM_MASK = PW_PERM_RWXM
|
|
PW_VERSION_CLIENT = 3
|
|
|
|
PW_ID_CLIENT = 1
|
|
)
|
|
|
|
const (
|
|
PW_CLIENT_CHANGE_MASK_PROPS = 1 << iota
|
|
|
|
PW_CLIENT_CHANGE_MASK_ALL = 1<<iota - 1
|
|
)
|
|
|
|
const (
|
|
PW_CLIENT_EVENT_INFO = iota
|
|
PW_CLIENT_EVENT_PERMISSIONS
|
|
PW_CLIENT_EVENT_NUM
|
|
|
|
PW_VERSION_CLIENT_EVENTS = 0
|
|
)
|
|
|
|
const (
|
|
PW_CLIENT_METHOD_ADD_LISTENER = iota
|
|
PW_CLIENT_METHOD_ERROR
|
|
PW_CLIENT_METHOD_UPDATE_PROPERTIES
|
|
PW_CLIENT_METHOD_GET_PERMISSIONS
|
|
PW_CLIENT_METHOD_UPDATE_PERMISSIONS
|
|
PW_CLIENT_METHOD_NUM
|
|
|
|
PW_VERSION_CLIENT_METHODS = 0
|
|
)
|
|
|
|
// The ClientInfo event provides client information updates.
|
|
// This is emitted when binding to a client or when the client info is updated later.
|
|
type ClientInfo struct {
|
|
// The global id of the client.
|
|
ID Int `json:"id"`
|
|
// The changes emitted by this event.
|
|
ChangeMask Long `json:"change_mask"`
|
|
// Properties of this object, valid when change_mask has PW_CLIENT_CHANGE_MASK_PROPS.
|
|
Properties *SPADict `json:"props"`
|
|
}
|
|
|
|
// Size satisfies [KnownSize] with a value computed at runtime.
|
|
func (c *ClientInfo) Size() Word {
|
|
return SizePrefix +
|
|
Size(SizeInt) +
|
|
Size(SizeLong) +
|
|
c.Properties.Size()
|
|
}
|
|
|
|
// MarshalBinary satisfies [encoding.BinaryMarshaler] via [Marshal].
|
|
func (c *ClientInfo) MarshalBinary() ([]byte, error) { return Marshal(c) }
|
|
|
|
// UnmarshalBinary satisfies [encoding.BinaryUnmarshaler] via [Unmarshal].
|
|
func (c *ClientInfo) UnmarshalBinary(data []byte) error { return Unmarshal(data, c) }
|
|
|
|
// ClientUpdateProperties is used to update the properties of a client.
|
|
type ClientUpdateProperties struct {
|
|
// Properties to update on the client.
|
|
Properties *SPADict `json:"props"`
|
|
}
|
|
|
|
// Size satisfies [KnownSize] with a value computed at runtime.
|
|
func (c *ClientUpdateProperties) Size() Word { return SizePrefix + c.Properties.Size() }
|
|
|
|
// MarshalBinary satisfies [encoding.BinaryMarshaler] via [Marshal].
|
|
func (c *ClientUpdateProperties) MarshalBinary() ([]byte, error) { return Marshal(c) }
|
|
|
|
// UnmarshalBinary satisfies [encoding.BinaryUnmarshaler] via [Unmarshal].
|
|
func (c *ClientUpdateProperties) UnmarshalBinary(data []byte) error { return Unmarshal(data, c) }
|
|
|
|
// clientUpdateProperties queues a [ClientUpdateProperties] message for the PipeWire server.
|
|
// This method should not be called directly, the New function queues this message.
|
|
func (ctx *Context) clientUpdateProperties(props SPADict) error {
|
|
return ctx.writeMessage(
|
|
PW_ID_CLIENT,
|
|
PW_CLIENT_METHOD_UPDATE_PROPERTIES,
|
|
&ClientUpdateProperties{&props},
|
|
)
|
|
}
|
|
|
|
// Client holds state of [PW_TYPE_INTERFACE_Client].
|
|
type Client struct {
|
|
// Additional information from the server, populated or updated during [Context.Roundtrip].
|
|
Info *ClientInfo `json:"info"`
|
|
|
|
// Populated by [CoreBoundProps] events targeting [Client].
|
|
Properties SPADict `json:"props"`
|
|
}
|
|
|
|
func (client *Client) consume(opcode byte, files []int, unmarshal func(v any) error) error {
|
|
if err := closeReceivedFiles(files...); err != nil {
|
|
return err
|
|
}
|
|
|
|
switch opcode {
|
|
case PW_CLIENT_EVENT_INFO:
|
|
return unmarshal(&client.Info)
|
|
|
|
default:
|
|
return &UnsupportedOpcodeError{opcode, client.String()}
|
|
}
|
|
}
|
|
|
|
func (client *Client) setBoundProps(event *CoreBoundProps) error {
|
|
if event.Properties != nil {
|
|
client.Properties = *event.Properties
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (client *Client) String() string { return PW_TYPE_INTERFACE_Registry }
|