mirror of
https://gitlab.freedesktop.org/pulseaudio/pulseaudio.git
synced 2025-10-29 05:40:23 -04:00
allow setting properties for modules, too
This commit is contained in:
parent
fe703013ad
commit
b43a45d184
9 changed files with 61 additions and 9 deletions
8
PROTOCOL
8
PROTOCOL
|
|
@ -154,7 +154,6 @@ PA_COMMAND_SET_RECORD_STREAM_BUFFER_ATTR at the end:
|
||||||
|
|
||||||
early_requests (bool)
|
early_requests (bool)
|
||||||
|
|
||||||
|
|
||||||
### v15, implemented by >= 0.9.15
|
### v15, implemented by >= 0.9.15
|
||||||
|
|
||||||
PA_COMMAND_CREATE_PLAYBACK_STREAM
|
PA_COMMAND_CREATE_PLAYBACK_STREAM
|
||||||
|
|
@ -163,4 +162,9 @@ PA_COMMAND_CREATE_PLAYBACK_STREAM
|
||||||
|
|
||||||
PA_COMMAND_CREATE_PLAYBACK_STREAM, PA_COMMAND_CREATE_RECORD_STREAM:
|
PA_COMMAND_CREATE_PLAYBACK_STREAM, PA_COMMAND_CREATE_RECORD_STREAM:
|
||||||
|
|
||||||
bool dont_inhibit_auto_suspend ate the end
|
bool dont_inhibit_auto_suspend at the end
|
||||||
|
|
||||||
|
PA_COMMAND_GET_MODULE_INFO_LIST
|
||||||
|
|
||||||
|
remove bool auto_unload
|
||||||
|
add proplist at the end
|
||||||
|
|
|
||||||
|
|
@ -480,13 +480,16 @@ static void context_get_module_info_callback(pa_pdispatch *pd, uint32_t command,
|
||||||
while (!pa_tagstruct_eof(t)) {
|
while (!pa_tagstruct_eof(t)) {
|
||||||
pa_module_info i;
|
pa_module_info i;
|
||||||
pa_bool_t auto_unload = FALSE;
|
pa_bool_t auto_unload = FALSE;
|
||||||
|
|
||||||
memset(&i, 0, sizeof(i));
|
memset(&i, 0, sizeof(i));
|
||||||
|
i.proplist = pa_proplist_new();
|
||||||
|
|
||||||
if (pa_tagstruct_getu32(t, &i.index) < 0 ||
|
if (pa_tagstruct_getu32(t, &i.index) < 0 ||
|
||||||
pa_tagstruct_gets(t, &i.name) < 0 ||
|
pa_tagstruct_gets(t, &i.name) < 0 ||
|
||||||
pa_tagstruct_gets(t, &i.argument) < 0 ||
|
pa_tagstruct_gets(t, &i.argument) < 0 ||
|
||||||
pa_tagstruct_getu32(t, &i.n_used) < 0 ||
|
pa_tagstruct_getu32(t, &i.n_used) < 0 ||
|
||||||
pa_tagstruct_get_boolean(t, &auto_unload) < 0) {
|
(o->context->version < 15 && pa_tagstruct_get_boolean(t, &auto_unload) < 0) ||
|
||||||
|
(o->context->version >= 15 && pa_tagstruct_get_proplist(t, i.proplist) < 0)) {
|
||||||
pa_context_fail(o->context, PA_ERR_PROTOCOL);
|
pa_context_fail(o->context, PA_ERR_PROTOCOL);
|
||||||
goto finish;
|
goto finish;
|
||||||
}
|
}
|
||||||
|
|
@ -497,6 +500,8 @@ static void context_get_module_info_callback(pa_pdispatch *pd, uint32_t command,
|
||||||
pa_module_info_cb_t cb = (pa_module_info_cb_t) o->callback;
|
pa_module_info_cb_t cb = (pa_module_info_cb_t) o->callback;
|
||||||
cb(o->context, &i, 0, o->userdata);
|
cb(o->context, &i, 0, o->userdata);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pa_proplist_free(i.proplist);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -333,6 +333,7 @@ typedef struct pa_module_info {
|
||||||
/** \cond fulldocs */
|
/** \cond fulldocs */
|
||||||
int auto_unload; /**< \deprecated Non-zero if this is an autoloaded module */
|
int auto_unload; /**< \deprecated Non-zero if this is an autoloaded module */
|
||||||
/** \endcond */
|
/** \endcond */
|
||||||
|
pa_proplist *proplist; /**< Property list \since 0.9.15 */
|
||||||
} pa_module_info;
|
} pa_module_info;
|
||||||
|
|
||||||
/** Callback prototype for pa_context_get_module_info() and firends*/
|
/** Callback prototype for pa_context_get_module_info() and firends*/
|
||||||
|
|
|
||||||
|
|
@ -128,6 +128,10 @@ PA_C_DECL_BEGIN
|
||||||
#define PA_PROP_DEVICE_BUFFERING_FRAGMENT_SIZE "device.buffering.fragment_size"
|
#define PA_PROP_DEVICE_BUFFERING_FRAGMENT_SIZE "device.buffering.fragment_size"
|
||||||
#define PA_PROP_DEVICE_PROFILE_NAME "device.profile.name"
|
#define PA_PROP_DEVICE_PROFILE_NAME "device.profile.name"
|
||||||
#define PA_PROP_DEVICE_PROFILE_DESCRIPTION "device.profile.description"
|
#define PA_PROP_DEVICE_PROFILE_DESCRIPTION "device.profile.description"
|
||||||
|
#define PA_PROP_MODULE_AUTHOR "module.author"
|
||||||
|
#define PA_PROP_MODULE_DESCRIPTION "module.description"
|
||||||
|
#define PA_PROP_MODULE_USAGE "module.usage"
|
||||||
|
#define PA_PROP_MODULE_VERSION "module.version"
|
||||||
|
|
||||||
/** A property list object. Basically a dictionary with UTF-8 strings
|
/** A property list object. Basically a dictionary with UTF-8 strings
|
||||||
* as keys and arbitrary data as values. \since 0.9.11 */
|
* as keys and arbitrary data as values. \since 0.9.11 */
|
||||||
|
|
|
||||||
|
|
@ -51,6 +51,7 @@
|
||||||
#include <pulsecore/shared.h>
|
#include <pulsecore/shared.h>
|
||||||
#include <pulsecore/core-util.h>
|
#include <pulsecore/core-util.h>
|
||||||
#include <pulsecore/core-error.h>
|
#include <pulsecore/core-error.h>
|
||||||
|
#include <pulsecore/modinfo.h>
|
||||||
|
|
||||||
#include "cli-command.h"
|
#include "cli-command.h"
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -54,6 +54,8 @@ char *pa_module_list_to_string(pa_core *c) {
|
||||||
pa_strbuf_printf(s, "%u module(s) loaded.\n", pa_idxset_size(c->modules));
|
pa_strbuf_printf(s, "%u module(s) loaded.\n", pa_idxset_size(c->modules));
|
||||||
|
|
||||||
for (m = pa_idxset_first(c->modules, &idx); m; m = pa_idxset_next(c->modules, &idx)) {
|
for (m = pa_idxset_first(c->modules, &idx); m; m = pa_idxset_next(c->modules, &idx)) {
|
||||||
|
char *t;
|
||||||
|
|
||||||
pa_strbuf_printf(s, " index: %u\n"
|
pa_strbuf_printf(s, " index: %u\n"
|
||||||
"\tname: <%s>\n"
|
"\tname: <%s>\n"
|
||||||
"\targument: <%s>\n"
|
"\targument: <%s>\n"
|
||||||
|
|
@ -64,6 +66,10 @@ char *pa_module_list_to_string(pa_core *c) {
|
||||||
pa_strempty(m->argument),
|
pa_strempty(m->argument),
|
||||||
pa_module_get_n_used(m),
|
pa_module_get_n_used(m),
|
||||||
pa_yes_no(m->load_once));
|
pa_yes_no(m->load_once));
|
||||||
|
|
||||||
|
t = pa_proplist_to_string_sep(m->proplist, "\n\t\t");
|
||||||
|
pa_strbuf_printf(s, "\tproperties:\n\t\t%s\n", t);
|
||||||
|
pa_xfree(t);
|
||||||
}
|
}
|
||||||
|
|
||||||
return pa_strbuf_tostring_free(s);
|
return pa_strbuf_tostring_free(s);
|
||||||
|
|
|
||||||
|
|
@ -33,12 +33,14 @@
|
||||||
|
|
||||||
#include <pulse/timeval.h>
|
#include <pulse/timeval.h>
|
||||||
#include <pulse/xmalloc.h>
|
#include <pulse/xmalloc.h>
|
||||||
|
#include <pulse/proplist.h>
|
||||||
|
|
||||||
#include <pulsecore/core-subscribe.h>
|
#include <pulsecore/core-subscribe.h>
|
||||||
#include <pulsecore/log.h>
|
#include <pulsecore/log.h>
|
||||||
#include <pulsecore/core-util.h>
|
#include <pulsecore/core-util.h>
|
||||||
#include <pulsecore/macro.h>
|
#include <pulsecore/macro.h>
|
||||||
#include <pulsecore/ltdl-helper.h>
|
#include <pulsecore/ltdl-helper.h>
|
||||||
|
#include <pulsecore/modinfo.h>
|
||||||
|
|
||||||
#include "module.h"
|
#include "module.h"
|
||||||
|
|
||||||
|
|
@ -50,6 +52,7 @@
|
||||||
pa_module* pa_module_load(pa_core *c, const char *name, const char *argument) {
|
pa_module* pa_module_load(pa_core *c, const char *name, const char *argument) {
|
||||||
pa_module *m = NULL;
|
pa_module *m = NULL;
|
||||||
pa_bool_t (*load_once)(void);
|
pa_bool_t (*load_once)(void);
|
||||||
|
pa_modinfo *mi;
|
||||||
|
|
||||||
pa_assert(c);
|
pa_assert(c);
|
||||||
pa_assert(name);
|
pa_assert(name);
|
||||||
|
|
@ -61,6 +64,7 @@ pa_module* pa_module_load(pa_core *c, const char *name, const char *argument) {
|
||||||
m->name = pa_xstrdup(name);
|
m->name = pa_xstrdup(name);
|
||||||
m->argument = pa_xstrdup(argument);
|
m->argument = pa_xstrdup(argument);
|
||||||
m->load_once = FALSE;
|
m->load_once = FALSE;
|
||||||
|
m->proplist = pa_proplist_new();
|
||||||
|
|
||||||
if (!(m->dl = lt_dlopenext(name))) {
|
if (!(m->dl = lt_dlopenext(name))) {
|
||||||
pa_log("Failed to open module \"%s\": %s", name, lt_dlerror());
|
pa_log("Failed to open module \"%s\": %s", name, lt_dlerror());
|
||||||
|
|
@ -111,11 +115,28 @@ pa_module* pa_module_load(pa_core *c, const char *name, const char *argument) {
|
||||||
|
|
||||||
pa_subscription_post(c, PA_SUBSCRIPTION_EVENT_MODULE|PA_SUBSCRIPTION_EVENT_NEW, m->index);
|
pa_subscription_post(c, PA_SUBSCRIPTION_EVENT_MODULE|PA_SUBSCRIPTION_EVENT_NEW, m->index);
|
||||||
|
|
||||||
|
if ((mi = pa_modinfo_get_by_handle(m->dl, name))) {
|
||||||
|
|
||||||
|
if (mi->author && !pa_proplist_contains(m->proplist, PA_PROP_MODULE_AUTHOR))
|
||||||
|
pa_proplist_sets(m->proplist, PA_PROP_MODULE_AUTHOR, mi->author);
|
||||||
|
|
||||||
|
if (mi->description && !pa_proplist_contains(m->proplist, PA_PROP_MODULE_DESCRIPTION))
|
||||||
|
pa_proplist_sets(m->proplist, PA_PROP_MODULE_DESCRIPTION, mi->description);
|
||||||
|
|
||||||
|
if (mi->version && !pa_proplist_contains(m->proplist, PA_PROP_MODULE_VERSION))
|
||||||
|
pa_proplist_sets(m->proplist, PA_PROP_MODULE_VERSION, mi->version);
|
||||||
|
|
||||||
|
pa_modinfo_free(mi);
|
||||||
|
}
|
||||||
|
|
||||||
return m;
|
return m;
|
||||||
|
|
||||||
fail:
|
fail:
|
||||||
|
|
||||||
if (m) {
|
if (m) {
|
||||||
|
if (m->proplist)
|
||||||
|
pa_proplist_free(m->proplist);
|
||||||
|
|
||||||
pa_xfree(m->argument);
|
pa_xfree(m->argument);
|
||||||
pa_xfree(m->name);
|
pa_xfree(m->name);
|
||||||
|
|
||||||
|
|
@ -137,6 +158,9 @@ static void pa_module_free(pa_module *m) {
|
||||||
if (m->done)
|
if (m->done)
|
||||||
m->done(m);
|
m->done(m);
|
||||||
|
|
||||||
|
if (m->proplist)
|
||||||
|
pa_proplist_free(m->proplist);
|
||||||
|
|
||||||
lt_dlclose(m->dl);
|
lt_dlclose(m->dl);
|
||||||
|
|
||||||
pa_log_info("Unloaded \"%s\" (index: #%u).", m->name, m->index);
|
pa_log_info("Unloaded \"%s\" (index: #%u).", m->name, m->index);
|
||||||
|
|
|
||||||
|
|
@ -27,8 +27,9 @@
|
||||||
|
|
||||||
typedef struct pa_module pa_module;
|
typedef struct pa_module pa_module;
|
||||||
|
|
||||||
|
#include <pulse/proplist.h>
|
||||||
|
|
||||||
#include <pulsecore/core.h>
|
#include <pulsecore/core.h>
|
||||||
#include <pulsecore/modinfo.h>
|
|
||||||
|
|
||||||
struct pa_module {
|
struct pa_module {
|
||||||
pa_core *core;
|
pa_core *core;
|
||||||
|
|
@ -45,6 +46,8 @@ struct pa_module {
|
||||||
|
|
||||||
pa_bool_t load_once:1;
|
pa_bool_t load_once:1;
|
||||||
pa_bool_t unload_requested:1;
|
pa_bool_t unload_requested:1;
|
||||||
|
|
||||||
|
pa_proplist *proplist;
|
||||||
};
|
};
|
||||||
|
|
||||||
pa_module* pa_module_load(pa_core *c, const char *name, const char*argument);
|
pa_module* pa_module_load(pa_core *c, const char *name, const char*argument);
|
||||||
|
|
|
||||||
|
|
@ -2728,10 +2728,9 @@ static void client_fill_tagstruct(pa_native_connection *c, pa_tagstruct *t, pa_c
|
||||||
|
|
||||||
if (c->version >= 13)
|
if (c->version >= 13)
|
||||||
pa_tagstruct_put_proplist(t, client->proplist);
|
pa_tagstruct_put_proplist(t, client->proplist);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void module_fill_tagstruct(pa_tagstruct *t, pa_module *module) {
|
static void module_fill_tagstruct(pa_native_connection *c, pa_tagstruct *t, pa_module *module) {
|
||||||
pa_assert(t);
|
pa_assert(t);
|
||||||
pa_assert(module);
|
pa_assert(module);
|
||||||
|
|
||||||
|
|
@ -2739,7 +2738,12 @@ static void module_fill_tagstruct(pa_tagstruct *t, pa_module *module) {
|
||||||
pa_tagstruct_puts(t, module->name);
|
pa_tagstruct_puts(t, module->name);
|
||||||
pa_tagstruct_puts(t, module->argument);
|
pa_tagstruct_puts(t, module->argument);
|
||||||
pa_tagstruct_putu32(t, (uint32_t) pa_module_get_n_used(module));
|
pa_tagstruct_putu32(t, (uint32_t) pa_module_get_n_used(module));
|
||||||
|
|
||||||
|
if (c->version < 15)
|
||||||
pa_tagstruct_put_boolean(t, FALSE); /* autoload is obsolete */
|
pa_tagstruct_put_boolean(t, FALSE); /* autoload is obsolete */
|
||||||
|
|
||||||
|
if (c->version >= 15)
|
||||||
|
pa_tagstruct_put_proplist(t, module->proplist);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void sink_input_fill_tagstruct(pa_native_connection *c, pa_tagstruct *t, pa_sink_input *s) {
|
static void sink_input_fill_tagstruct(pa_native_connection *c, pa_tagstruct *t, pa_sink_input *s) {
|
||||||
|
|
@ -2891,7 +2895,7 @@ static void command_get_info(pa_pdispatch *pd, uint32_t command, uint32_t tag, p
|
||||||
else if (client)
|
else if (client)
|
||||||
client_fill_tagstruct(c, reply, client);
|
client_fill_tagstruct(c, reply, client);
|
||||||
else if (module)
|
else if (module)
|
||||||
module_fill_tagstruct(reply, module);
|
module_fill_tagstruct(c, reply, module);
|
||||||
else if (si)
|
else if (si)
|
||||||
sink_input_fill_tagstruct(c, reply, si);
|
sink_input_fill_tagstruct(c, reply, si);
|
||||||
else if (so)
|
else if (so)
|
||||||
|
|
@ -2946,7 +2950,7 @@ static void command_get_info_list(pa_pdispatch *pd, uint32_t command, uint32_t t
|
||||||
else if (command == PA_COMMAND_GET_CLIENT_INFO_LIST)
|
else if (command == PA_COMMAND_GET_CLIENT_INFO_LIST)
|
||||||
client_fill_tagstruct(c, reply, p);
|
client_fill_tagstruct(c, reply, p);
|
||||||
else if (command == PA_COMMAND_GET_MODULE_INFO_LIST)
|
else if (command == PA_COMMAND_GET_MODULE_INFO_LIST)
|
||||||
module_fill_tagstruct(reply, p);
|
module_fill_tagstruct(c, reply, p);
|
||||||
else if (command == PA_COMMAND_GET_SINK_INPUT_INFO_LIST)
|
else if (command == PA_COMMAND_GET_SINK_INPUT_INFO_LIST)
|
||||||
sink_input_fill_tagstruct(c, reply, p);
|
sink_input_fill_tagstruct(c, reply, p);
|
||||||
else if (command == PA_COMMAND_GET_SOURCE_OUTPUT_INFO_LIST)
|
else if (command == PA_COMMAND_GET_SOURCE_OUTPUT_INFO_LIST)
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue