Go to the documentation of this file.
   25 #ifndef PIPEWIRE_IMPL_CLIENT_H 
   26 #define PIPEWIRE_IMPL_CLIENT_H 
   32 #include <spa/utils/hook.h> 
   84 #define PW_VERSION_IMPL_CLIENT_EVENTS   0 
  116                         size_t user_data_size                   );
 
  157                             struct spa_hook *listener,
 
  
 
@ PW_MEMBLOCK_FLAG_READWRITE
Definition: mem.h:43
static uint32_t int int res
Definition: core.h:323
#define PW_VERSION_CLIENT
Definition: client.h:40
struct pw_resource * resource
Definition: impl-device.c:52
#define NAME
Definition: impl-client.c:31
static void * pw_map_lookup(struct pw_map *map, uint32_t id)
Find an item in the map.
Definition: map.h:169
SPA_EXPORT void pw_impl_client_set_busy(struct pw_impl_client *client, bool busy)
Mark the client busy.
Definition: impl-client.c:636
uint32_t id
unique id
Definition: mem.h:66
SPA_EXPORT struct pw_resource * pw_impl_client_get_core_resource(struct pw_impl_client *client)
Get the client core resource.
Definition: impl-client.c:437
#define pw_log_error(...)
SPA_EXPORT int pw_impl_client_update_properties(struct pw_impl_client *client, const struct spa_dict *dict)
Update client properties.
Definition: impl-client.c:539
#define PW_PERM_INVALID
Definition: permission.h:54
SPA_EXPORT struct pw_global * pw_impl_client_get_global(struct pw_impl_client *client)
Get the global associated with this client.
Definition: impl-client.c:449
SPA_EXPORT void pw_global_destroy(struct pw_global *global)
Destroy a global.
Definition: global.c:367
SPA_EXPORT struct pw_resource * pw_impl_client_find_resource(struct pw_impl_client *client, uint32_t id)
Get a resource with the given id.
Definition: impl-client.c:443
void pw_mempool_destroy(struct pw_mempool *pool)
Clear and destroy a pool.
Definition: mem.c:167
static void pw_map_init(struct pw_map *map, size_t size, size_t extend)
Initialize a map.
Definition: map.h:76
Definition: impl-core.c:37
#define PW_KEY_OBJECT_ID
a global object id
Definition: keys.h:70
SPA_EXPORT const struct pw_properties * pw_impl_client_get_properties(struct pw_impl_client *client)
Get the client properties.
Definition: impl-client.c:455
Manages protocols and their implementation.
struct pw_resource * pw_impl_client_find_resource(struct pw_impl_client *client, uint32_t id)
Get a resource with the given id.
Definition: impl-client.c:443
void(* resource_added)(void *data, struct pw_resource *resource)
emited when a new resource is added for client
Definition: impl-client.h:100
struct spa_hook resource_listener
Definition: impl-core.c:38
uint32_t flags
flags for the memory block on of enum pw_memblock_flags
Definition: mem.h:68
SPA_EXPORT struct pw_protocol * pw_impl_client_get_protocol(struct pw_impl_client *client)
Get the protocol used to create this client.
Definition: impl-client.c:431
Global events, use pw_global_add_listener.
Definition: global.h:65
PipeWire client object class.
#define PW_KEY_SEC_PID
Various keys related to the identity of a client process and its security.
Definition: keys.h:60
void pw_mempool_add_listener(struct pw_mempool *pool, struct spa_hook *listener, const struct pw_mempool_events *events, void *data)
Listen for events.
Definition: mem.c:186
SPA_EXPORT void * pw_impl_client_get_user_data(struct pw_impl_client *client)
Get the client user data.
Definition: impl-client.c:461
#define PW_KEY_MODULE_ID
module properties
Definition: keys.h:205
void pw_global_add_listener(struct pw_global *global, struct spa_hook *listener, const struct pw_global_events *events, void *data)
Add an event listener on the global.
Definition: global.c:252
static uint32_t int int const char int r
Definition: core.h:335
The events that a client can emit.
Definition: impl-client.h:83
A global object visible to remote clients.
a PipeWire permission
Definition: permission.h:56
struct spa_dict dict
dictionary of key/values
Definition: properties.h:46
struct pw_global * pw_impl_client_get_global(struct pw_impl_client *client)
Get the global associated with this client.
Definition: impl-client.c:449
#define PW_PERMISSION_INIT(id, p)
Definition: permission.h:61
static int pw_map_for_each(struct pw_map *map, int(*func)(void *item_data, void *data), void *data)
Iterate all map items.
Definition: map.h:188
An array object.
Definition: array.h:43
void * pw_impl_client_get_user_data(struct pw_impl_client *client)
Get the client user data.
Definition: impl-client.c:461
void pw_resource_error(struct pw_resource *resource, int res, const char *error)
Generate an error for a resource.
Definition: resource.c:256
struct pw_context * pw_impl_client_get_context(struct pw_impl_client *client)
Get the context used to create this client.
Definition: impl-client.c:425
SPA_EXPORT int pw_properties_setf(struct pw_properties *properties, const char *key, const char *format,...)
Set a property value by format.
Definition: properties.c:428
context events emited by the context object added with pw_context_add_listener
Definition: context.h:96
#define PW_KEY_SEC_UID
Client uid, set by protocol.
Definition: keys.h:61
SPA_EXPORT void pw_impl_client_destroy(struct pw_impl_client *client)
Destroy a client object.
Definition: impl-client.c:481
int fd
fd
Definition: mem.h:70
struct spa_hook object_listener
Definition: impl-core.c:39
void(* busy_changed)(void *data, bool busy)
emited when the client becomes busy processing an asynchronous message.
Definition: impl-client.h:108
#define PW_KEY_SEC_GID
client gid, set by protocol
Definition: keys.h:62
struct pw_global * pw_context_find_global(struct pw_context *context, uint32_t id)
Find a context global by id.
#define pw_log_debug(...)
uint32_t permissions
bitmask of above permissions
Definition: permission.h:58
#define PW_VERSION_RESOURCE_EVENTS
Definition: resource.h:65
#define PW_CLIENT_CHANGE_MASK_PROPS
Definition: client.h:49
int pw_impl_client_update_permissions(struct pw_impl_client *client, uint32_t n_permissions, const struct pw_permission *permissions)
Update the client permissions.
Definition: impl-client.c:566
The client information.
Definition: client.h:47
SPA_EXPORT int pw_properties_update(struct pw_properties *props, const struct spa_dict *dict)
Update properties.
Definition: properties.c:258
#define PW_KEY_SEC_LABEL
client security label, set by protocol
Definition: keys.h:63
#define PW_VERSION_MEMPOOL_EVENTS
Definition: mem.h:86
void * pw_resource_get_user_data(struct pw_resource *resource)
Get the user data for the resource, the size was given in pw_resource_new.
Definition: resource.c:160
const struct pw_properties * pw_impl_client_get_properties(struct pw_impl_client *client)
Get the client properties.
Definition: impl-client.c:455
SPA_EXPORT int pw_impl_client_register(struct pw_impl_client *client, struct pw_properties *properties)
Finish configuration and register a client.
Definition: impl-client.c:369
static void pw_map_clear(struct pw_map *map)
Clear a map.
Definition: map.h:87
void pw_impl_client_add_listener(struct pw_impl_client *client, struct spa_hook *listener, const struct pw_impl_client_events *events, void *data)
listen to events from this client
Definition: impl-client.c:513
int pw_global_add_resource(struct pw_global *global, struct pw_resource *resource)
Add a resource to a global.
Definition: global.c:227
void(* free)(void *data)
emited right before the client is freed
Definition: impl-client.h:91
struct pw_protocol * pw_impl_client_get_protocol(struct pw_impl_client *client)
Get the protocol used to create this client.
Definition: impl-client.c:431
const struct pw_client_info * pw_impl_client_get_info(struct pw_impl_client *client)
Get the client information.
Definition: impl-client.c:522
static void * pw_array_add(struct pw_array *arr, size_t size)
Add ref size bytes to arr.
Definition: array.h:127
#define pw_array_get_len(a, t)
Get the number of items of type t in array.
Definition: array.h:57
void(* initialized)(void *data)
the client is initialized
Definition: impl-client.h:94
int pw_global_update_permissions(struct pw_global *global, struct pw_impl_client *client, uint32_t old_permissions, uint32_t new_permissions)
Definition: global.c:311
int pw_impl_client_register(struct pw_impl_client *client, struct pw_properties *properties)
Finish configuration and register a client.
Definition: impl-client.c:369
void pw_resource_add_object_listener(struct pw_resource *resource, struct spa_hook *listener, const void *funcs, void *data)
Set the resource implementation.
Definition: resource.c:175
void pw_resource_destroy(struct pw_resource *resource)
Destroy a resource.
Definition: resource.c:265
#define PW_VERSION_GLOBAL_EVENTS
Definition: global.h:66
struct result_device_params_data data
Definition: impl-device.c:63
void pw_context_add_listener(struct pw_context *context, struct spa_hook *listener, const struct pw_context_events *events, void *data)
Add a new event listener to a context.
Client methods.
Definition: client.h:103
SPA_EXPORT struct pw_impl_client * pw_context_create_client(struct pw_impl_core *core, struct pw_protocol *protocol, struct pw_properties *properties, size_t user_data_size)
Make a new client object.
Definition: impl-client.c:279
#define pw_array_get_unchecked(a, idx, t)
Get the item with index idx and type t from array.
Definition: array.h:59
void(* info_changed)(void *data, const struct pw_client_info *info)
emited when the client info changed
Definition: impl-client.h:97
#define PW_VERSION_CLIENT_METHODS
Definition: client.h:104
#define PW_TYPE_INTERFACE_Client
Definition: client.h:38
struct pw_resource * pw_resource_new(struct pw_impl_client *client, uint32_t id, uint32_t permissions, const char *type, uint32_t version, size_t user_data_size)
Make a new resource for client.
Definition: resource.c:43
struct pw_mempool * pw_mempool_new(struct pw_properties *props)
Create a new memory pool.
Definition: mem.c:133
SPA_EXPORT struct pw_global * pw_global_new(struct pw_context *context, const char *type, uint32_t version, struct pw_properties *properties, pw_global_bind_func_t func, void *object)
Create a new global.
Definition: global.c:67
struct pw_control this
Definition: control.c:34
void(* resource_removed)(void *data, struct pw_resource *resource)
emited when a resource is removed
Definition: impl-client.h:103
uint32_t version
Definition: impl-client.h:85
SPA_EXPORT struct pw_properties * pw_properties_new(const char *key,...)
Make a new properties object.
Definition: properties.c:95
#define pw_array_check_index(a, idx, t)
Check if an item with index idx and type t exist in array.
Definition: array.h:61
#define PW_VERSION_CONTEXT_EVENTS
Definition: context.h:97
#define PW_ID_ANY
Definition: core.h:49
SPA_EXPORT const struct pw_client_info * pw_impl_client_get_info(struct pw_impl_client *client)
Get the client information.
Definition: impl-client.c:522
SPA_EXPORT int pw_global_register(struct pw_global *global)
register a global to the context registry
Definition: global.c:128
SPA_EXPORT struct pw_context * pw_impl_client_get_context(struct pw_impl_client *client)
Get the context used to create this client.
Definition: impl-client.c:425
SPA_EXPORT int pw_impl_client_update_permissions(struct pw_impl_client *client, uint32_t n_permissions, const struct pw_permission *permissions)
Update the client permissions.
Definition: impl-client.c:566
void(* destroy)(void *data)
emited when the client is destroyed
Definition: impl-client.h:88
uint32_t type
type of the fd, one of enum spa_data_type
Definition: mem.h:69
Resource events.
Definition: resource.h:64
void pw_resource_add_listener(struct pw_resource *resource, struct spa_hook *listener, const struct pw_resource_events *events, void *data)
Add an event listener.
Definition: resource.c:166
uint32_t version
Definition: resource.h:66
void pw_impl_client_set_busy(struct pw_impl_client *client, bool busy)
Mark the client busy.
Definition: impl-client.c:636
SPA_EXPORT void pw_impl_client_add_listener(struct pw_impl_client *client, struct spa_hook *listener, const struct pw_impl_client_events *events, void *data)
listen to events from this client
Definition: impl-client.c:513
struct pw_resource * pw_impl_client_get_core_resource(struct pw_impl_client *client)
Get the client core resource.
Definition: impl-client.c:437
SPA_EXPORT int pw_properties_update_keys(struct pw_properties *props, const struct spa_dict *dict, const char *keys[])
Copy multiple keys from one property to another.
Definition: properties.c:215
A collection of key/value pairs.
Definition: properties.h:45
SPA_EXPORT void pw_properties_free(struct pw_properties *properties)
Free a properties object.
Definition: properties.c:330
uint32_t id
id of object, PW_ID_ANY for default permission
Definition: permission.h:57
#define PW_KEY_PROTOCOL
The protocol key is usually set on a pw_client and contains a string describing the protocol used by ...
Definition: keys.h:54
static void pw_array_init(struct pw_array *arr, size_t extend)
Initialize the array with given extend.
Definition: array.h:85