mirror of
https://gitlab.freedesktop.org/pipewire/pipewire.git
synced 2025-11-04 13:30:12 -05:00
improve properties on objects
This commit is contained in:
parent
9c4e5f4e27
commit
6e0c279bc1
7 changed files with 56 additions and 10 deletions
|
|
@ -121,6 +121,13 @@ static void *create_object(void *_data,
|
||||||
|
|
||||||
pw_properties_setf(properties, PW_KEY_FACTORY_ID, "%d", d->this->global->id);
|
pw_properties_setf(properties, PW_KEY_FACTORY_ID, "%d", d->this->global->id);
|
||||||
|
|
||||||
|
client = resource ? pw_resource_get_client(resource): NULL;
|
||||||
|
|
||||||
|
if (client) {
|
||||||
|
pw_properties_setf(properties, PW_KEY_CLIENT_ID, "%d",
|
||||||
|
client->global->id);
|
||||||
|
}
|
||||||
|
|
||||||
slave = NULL;
|
slave = NULL;
|
||||||
str = pw_properties_get(properties, "adapt.slave.node");
|
str = pw_properties_get(properties, "adapt.slave.node");
|
||||||
if (str != NULL) {
|
if (str != NULL) {
|
||||||
|
|
@ -164,8 +171,6 @@ static void *create_object(void *_data,
|
||||||
|
|
||||||
pw_node_add_listener(adapter, &nd->adapter_listener, &node_events, nd);
|
pw_node_add_listener(adapter, &nd->adapter_listener, &node_events, nd);
|
||||||
|
|
||||||
client = resource ? pw_resource_get_client(resource): NULL;
|
|
||||||
|
|
||||||
pw_node_register(adapter, NULL);
|
pw_node_register(adapter, NULL);
|
||||||
|
|
||||||
if (client) {
|
if (client) {
|
||||||
|
|
|
||||||
|
|
@ -63,6 +63,8 @@ static void *create_object(void *_data,
|
||||||
struct pw_properties *properties,
|
struct pw_properties *properties,
|
||||||
uint32_t new_id)
|
uint32_t new_id)
|
||||||
{
|
{
|
||||||
|
struct factory_data *data = _data;
|
||||||
|
struct pw_factory *this = data->this;
|
||||||
void *result;
|
void *result;
|
||||||
struct pw_resource *device_resource;
|
struct pw_resource *device_resource;
|
||||||
struct pw_client *client = pw_resource_get_client(resource);
|
struct pw_client *client = pw_resource_get_client(resource);
|
||||||
|
|
@ -74,18 +76,33 @@ static void *create_object(void *_data,
|
||||||
goto error_resource;
|
goto error_resource;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (properties == NULL)
|
||||||
|
properties = pw_properties_new(NULL, NULL);
|
||||||
|
if (properties == NULL) {
|
||||||
|
res = -errno;
|
||||||
|
goto error_properties;
|
||||||
|
}
|
||||||
|
|
||||||
|
pw_properties_setf(properties, PW_KEY_FACTORY_ID, "%d",
|
||||||
|
pw_global_get_id(pw_factory_get_global(this)));
|
||||||
|
pw_properties_setf(properties, PW_KEY_CLIENT_ID, "%d",
|
||||||
|
pw_global_get_id(pw_client_get_global(client)));
|
||||||
|
|
||||||
result = pw_client_device_new(device_resource, properties);
|
result = pw_client_device_new(device_resource, properties);
|
||||||
if (result == NULL) {
|
if (result == NULL) {
|
||||||
res = -errno;
|
res = -errno;
|
||||||
goto error_device;
|
goto error_device;
|
||||||
}
|
}
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
|
|
||||||
error_resource:
|
error_resource:
|
||||||
pw_log_error("can't create resource: %s", spa_strerror(res));
|
pw_log_error("can't create resource: %s", spa_strerror(res));
|
||||||
pw_resource_error(resource, res, "can't create resource: %s", spa_strerror(res));
|
pw_resource_error(resource, res, "can't create resource: %s", spa_strerror(res));
|
||||||
goto error_exit;
|
goto error_exit;
|
||||||
|
error_properties:
|
||||||
|
pw_log_error("can't create properties: %s", spa_strerror(res));
|
||||||
|
pw_resource_error(resource, res, "can't create properties: %s", spa_strerror(res));
|
||||||
|
goto error_exit_free;
|
||||||
error_device:
|
error_device:
|
||||||
pw_log_error("can't create device: %s", spa_strerror(res));
|
pw_log_error("can't create device: %s", spa_strerror(res));
|
||||||
pw_resource_error(resource, res, "can't create device: %s", spa_strerror(res));
|
pw_resource_error(resource, res, "can't create device: %s", spa_strerror(res));
|
||||||
|
|
|
||||||
|
|
@ -85,6 +85,7 @@ static void *create_object(void *_data,
|
||||||
struct pw_device *device;
|
struct pw_device *device;
|
||||||
const char *factory_name;
|
const char *factory_name;
|
||||||
struct device_data *nd;
|
struct device_data *nd;
|
||||||
|
struct pw_client *client;
|
||||||
int res;
|
int res;
|
||||||
|
|
||||||
if (properties == NULL)
|
if (properties == NULL)
|
||||||
|
|
@ -94,6 +95,16 @@ static void *create_object(void *_data,
|
||||||
if (factory_name == NULL)
|
if (factory_name == NULL)
|
||||||
goto error_properties;
|
goto error_properties;
|
||||||
|
|
||||||
|
pw_properties_setf(properties, PW_KEY_FACTORY_ID, "%d",
|
||||||
|
pw_global_get_id(pw_factory_get_global(data->this)));
|
||||||
|
|
||||||
|
client = resource ? pw_resource_get_client(resource) : NULL;
|
||||||
|
|
||||||
|
if (client) {
|
||||||
|
pw_properties_setf(properties, PW_KEY_CLIENT_ID, "%d",
|
||||||
|
pw_global_get_id(pw_client_get_global(client)));
|
||||||
|
}
|
||||||
|
|
||||||
device = pw_spa_device_load(core,
|
device = pw_spa_device_load(core,
|
||||||
factory_name,
|
factory_name,
|
||||||
0,
|
0,
|
||||||
|
|
@ -110,12 +121,12 @@ static void *create_object(void *_data,
|
||||||
|
|
||||||
pw_device_add_listener(device, &nd->device_listener, &device_events, nd);
|
pw_device_add_listener(device, &nd->device_listener, &device_events, nd);
|
||||||
|
|
||||||
if (resource)
|
if (client) {
|
||||||
pw_global_bind(pw_device_get_global(device),
|
pw_global_bind(pw_device_get_global(device),
|
||||||
pw_resource_get_client(resource),
|
client,
|
||||||
PW_PERM_RWX,
|
PW_PERM_RWX, version,
|
||||||
version, new_id);
|
new_id);
|
||||||
|
}
|
||||||
return device;
|
return device;
|
||||||
|
|
||||||
error_properties:
|
error_properties:
|
||||||
|
|
|
||||||
|
|
@ -104,6 +104,7 @@ static void *create_object(void *_data,
|
||||||
const char *factory_name;
|
const char *factory_name;
|
||||||
struct node_data *nd;
|
struct node_data *nd;
|
||||||
int res;
|
int res;
|
||||||
|
struct pw_client *client;
|
||||||
|
|
||||||
if (properties == NULL)
|
if (properties == NULL)
|
||||||
goto error_properties;
|
goto error_properties;
|
||||||
|
|
@ -112,9 +113,16 @@ static void *create_object(void *_data,
|
||||||
if (factory_name == NULL)
|
if (factory_name == NULL)
|
||||||
goto error_properties;
|
goto error_properties;
|
||||||
|
|
||||||
|
client = resource ? pw_resource_get_client(resource) : NULL;
|
||||||
|
|
||||||
pw_properties_setf(properties, PW_KEY_FACTORY_ID, "%d",
|
pw_properties_setf(properties, PW_KEY_FACTORY_ID, "%d",
|
||||||
pw_global_get_id(pw_factory_get_global(data->this)));
|
pw_global_get_id(pw_factory_get_global(data->this)));
|
||||||
|
|
||||||
|
if (client) {
|
||||||
|
pw_properties_setf(properties, PW_KEY_CLIENT_ID, "%d",
|
||||||
|
pw_global_get_id(pw_client_get_global(client)));
|
||||||
|
}
|
||||||
|
|
||||||
node = pw_spa_node_load(core,
|
node = pw_spa_node_load(core,
|
||||||
factory_name,
|
factory_name,
|
||||||
PW_SPA_NODE_FLAG_ACTIVATE,
|
PW_SPA_NODE_FLAG_ACTIVATE,
|
||||||
|
|
@ -130,9 +138,8 @@ static void *create_object(void *_data,
|
||||||
|
|
||||||
pw_node_add_listener(node, &nd->node_listener, &node_events, nd);
|
pw_node_add_listener(node, &nd->node_listener, &node_events, nd);
|
||||||
|
|
||||||
if (resource) {
|
if (client) {
|
||||||
struct pw_resource *bound_resource;
|
struct pw_resource *bound_resource;
|
||||||
struct pw_client *client = pw_resource_get_client(resource);
|
|
||||||
|
|
||||||
res = pw_global_bind(pw_node_get_global(node),
|
res = pw_global_bind(pw_node_get_global(node),
|
||||||
client,
|
client,
|
||||||
|
|
|
||||||
|
|
@ -407,7 +407,9 @@ int pw_device_register(struct pw_device *device,
|
||||||
struct pw_core *core = device->core;
|
struct pw_core *core = device->core;
|
||||||
struct object_data *od;
|
struct object_data *od;
|
||||||
const char *keys[] = {
|
const char *keys[] = {
|
||||||
|
PW_KEY_OBJECT_PATH,
|
||||||
PW_KEY_MODULE_ID,
|
PW_KEY_MODULE_ID,
|
||||||
|
PW_KEY_FACTORY_ID,
|
||||||
PW_KEY_CLIENT_ID,
|
PW_KEY_CLIENT_ID,
|
||||||
PW_KEY_DEVICE_DESCRIPTION,
|
PW_KEY_DEVICE_DESCRIPTION,
|
||||||
PW_KEY_DEVICE_NAME,
|
PW_KEY_DEVICE_NAME,
|
||||||
|
|
|
||||||
|
|
@ -1207,6 +1207,8 @@ int pw_link_register(struct pw_link *link,
|
||||||
struct pw_core *core = link->core;
|
struct pw_core *core = link->core;
|
||||||
struct pw_node *output_node, *input_node;
|
struct pw_node *output_node, *input_node;
|
||||||
const char *keys[] = {
|
const char *keys[] = {
|
||||||
|
PW_KEY_OBJECT_PATH,
|
||||||
|
PW_KEY_MODULE_ID,
|
||||||
PW_KEY_FACTORY_ID,
|
PW_KEY_FACTORY_ID,
|
||||||
PW_KEY_CLIENT_ID,
|
PW_KEY_CLIENT_ID,
|
||||||
NULL
|
NULL
|
||||||
|
|
|
||||||
|
|
@ -550,6 +550,8 @@ int pw_node_register(struct pw_node *this,
|
||||||
struct pw_port *port;
|
struct pw_port *port;
|
||||||
const char *keys[] = {
|
const char *keys[] = {
|
||||||
PW_KEY_OBJECT_PATH,
|
PW_KEY_OBJECT_PATH,
|
||||||
|
PW_KEY_MODULE_ID,
|
||||||
|
PW_KEY_FACTORY_ID,
|
||||||
PW_KEY_CLIENT_ID,
|
PW_KEY_CLIENT_ID,
|
||||||
PW_KEY_DEVICE_ID,
|
PW_KEY_DEVICE_ID,
|
||||||
PW_KEY_NODE_DESCRIPTION,
|
PW_KEY_NODE_DESCRIPTION,
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue