store the default sink/source in proper pa_sink*/pa_source* pointers instead of a string

This commit is contained in:
Lennart Poettering 2009-01-28 01:46:27 +01:00
parent fc3ff11418
commit a5401a50a6
11 changed files with 133 additions and 103 deletions

View file

@ -971,11 +971,6 @@ int main(int argc, char *argv[]) {
goto finish; goto finish;
} }
if (c->default_sink_name && !pa_namereg_get(c, c->default_sink_name, PA_NAMEREG_SINK) && conf->fail) {
pa_log_error(_("Default sink name (%s) does not exist in name register."), c->default_sink_name);
goto finish;
}
#ifdef HAVE_FORK #ifdef HAVE_FORK
if (daemon_pipe[1] >= 0) { if (daemon_pipe[1] >= 0) {
int ok = 0; int ok = 0;

View file

@ -57,10 +57,11 @@ static void load(struct userdata *u) {
/* We never overwrite manually configured settings */ /* We never overwrite manually configured settings */
if (u->core->default_sink_name) if (u->core->default_sink)
pa_log_info("Manually configured default sink, not overwriting."); pa_log_info("Manually configured default sink, not overwriting.");
else if ((f = fopen(u->sink_filename, "r"))) { else if ((f = fopen(u->sink_filename, "r"))) {
char ln[256] = ""; char ln[256] = "";
pa_sink *s;
fgets(ln, sizeof(ln)-1, f); fgets(ln, sizeof(ln)-1, f);
pa_strip_nl(ln); pa_strip_nl(ln);
@ -68,8 +69,8 @@ static void load(struct userdata *u) {
if (!ln[0]) if (!ln[0])
pa_log_info("No previous default sink setting, ignoring."); pa_log_info("No previous default sink setting, ignoring.");
else if (pa_namereg_get(u->core, ln, PA_NAMEREG_SINK)) { else if ((s = pa_namereg_get(u->core, ln, PA_NAMEREG_SINK))) {
pa_namereg_set_default(u->core, ln, PA_NAMEREG_SINK); pa_namereg_set_default_sink(u->core, s);
pa_log_info("Restored default sink '%s'.", ln); pa_log_info("Restored default sink '%s'.", ln);
} else } else
pa_log_info("Saved default sink '%s' not existant, not restoring default sink setting.", ln); pa_log_info("Saved default sink '%s' not existant, not restoring default sink setting.", ln);
@ -77,10 +78,11 @@ static void load(struct userdata *u) {
} else if (errno != ENOENT) } else if (errno != ENOENT)
pa_log("Failed to load default sink: %s", pa_cstrerror(errno)); pa_log("Failed to load default sink: %s", pa_cstrerror(errno));
if (u->core->default_source_name) if (u->core->default_source)
pa_log_info("Manually configured default source, not overwriting."); pa_log_info("Manually configured default source, not overwriting.");
else if ((f = fopen(u->source_filename, "r"))) { else if ((f = fopen(u->source_filename, "r"))) {
char ln[256] = ""; char ln[256] = "";
pa_source *s;
fgets(ln, sizeof(ln)-1, f); fgets(ln, sizeof(ln)-1, f);
pa_strip_nl(ln); pa_strip_nl(ln);
@ -88,8 +90,8 @@ static void load(struct userdata *u) {
if (!ln[0]) if (!ln[0])
pa_log_info("No previous default source setting, ignoring."); pa_log_info("No previous default source setting, ignoring.");
else if (pa_namereg_get(u->core, ln, PA_NAMEREG_SOURCE)) { else if ((s = pa_namereg_get(u->core, ln, PA_NAMEREG_SOURCE))) {
pa_namereg_set_default(u->core, ln, PA_NAMEREG_SOURCE); pa_namereg_set_default_source(u->core, s);
pa_log_info("Restored default source '%s'.", ln); pa_log_info("Restored default source '%s'.", ln);
} else } else
pa_log_info("Saved default source '%s' not existant, not restoring default source setting.", ln); pa_log_info("Saved default source '%s' not existant, not restoring default source setting.", ln);
@ -106,8 +108,8 @@ static void save(struct userdata *u) {
if (u->sink_filename) { if (u->sink_filename) {
if ((f = fopen(u->sink_filename, "w"))) { if ((f = fopen(u->sink_filename, "w"))) {
const char *n = pa_namereg_get_default_sink_name(u->core); pa_sink *s = pa_namereg_get_default_sink(u->core);
fprintf(f, "%s\n", pa_strempty(n)); fprintf(f, "%s\n", s ? s->name : "");
fclose(f); fclose(f);
} else } else
pa_log("Failed to save default sink: %s", pa_cstrerror(errno)); pa_log("Failed to save default sink: %s", pa_cstrerror(errno));
@ -115,8 +117,8 @@ static void save(struct userdata *u) {
if (u->source_filename) { if (u->source_filename) {
if ((f = fopen(u->source_filename, "w"))) { if ((f = fopen(u->source_filename, "w"))) {
const char *n = pa_namereg_get_default_source_name(u->core); pa_source *s = pa_namereg_get_default_source(u->core);
fprintf(f, "%s\n", pa_strempty(n)); fprintf(f, "%s\n", s ? s->name : "");
fclose(f); fclose(f);
} else } else
pa_log("Failed to save default source: %s", pa_cstrerror(errno)); pa_log("Failed to save default source: %s", pa_cstrerror(errno));

View file

@ -324,7 +324,8 @@ static int pa_cli_command_stat(pa_core *c, pa_tokenizer *t, pa_strbuf *buf, pa_b
char s[256]; char s[256];
const pa_mempool_stat *stat; const pa_mempool_stat *stat;
unsigned k; unsigned k;
const char *def_sink, *def_source; pa_sink *def_sink;
pa_source *def_source;
static const char* const type_table[PA_MEMBLOCK_TYPE_MAX] = { static const char* const type_table[PA_MEMBLOCK_TYPE_MAX] = {
[PA_MEMBLOCK_POOL] = "POOL", [PA_MEMBLOCK_POOL] = "POOL",
@ -364,12 +365,12 @@ static int pa_cli_command_stat(pa_core *c, pa_tokenizer *t, pa_strbuf *buf, pa_b
pa_strbuf_printf(buf, "Default sample spec: %s\n", pa_strbuf_printf(buf, "Default sample spec: %s\n",
pa_sample_spec_snprint(s, sizeof(s), &c->default_sample_spec)); pa_sample_spec_snprint(s, sizeof(s), &c->default_sample_spec));
def_sink = pa_namereg_get_default_sink_name(c); def_sink = pa_namereg_get_default_sink(c);
def_source = pa_namereg_get_default_source_name(c); def_source = pa_namereg_get_default_source(c);
pa_strbuf_printf(buf, "Default sink name: %s\n" pa_strbuf_printf(buf, "Default sink name: %s\n"
"Default source name: %s\n", "Default source name: %s\n",
def_sink ? def_sink : "none", def_sink ? def_sink->name : "none",
def_source ? def_source : "none"); def_source ? def_source->name : "none");
for (k = 0; k < PA_MEMBLOCK_TYPE_MAX; k++) for (k = 0; k < PA_MEMBLOCK_TYPE_MAX; k++)
pa_strbuf_printf(buf, pa_strbuf_printf(buf,
@ -858,6 +859,7 @@ static int pa_cli_command_sink_input_mute(pa_core *c, pa_tokenizer *t, pa_strbuf
static int pa_cli_command_sink_default(pa_core *c, pa_tokenizer *t, pa_strbuf *buf, pa_bool_t *fail) { static int pa_cli_command_sink_default(pa_core *c, pa_tokenizer *t, pa_strbuf *buf, pa_bool_t *fail) {
const char *n; const char *n;
pa_sink *s;
pa_core_assert_ref(c); pa_core_assert_ref(c);
pa_assert(t); pa_assert(t);
@ -869,12 +871,17 @@ static int pa_cli_command_sink_default(pa_core *c, pa_tokenizer *t, pa_strbuf *b
return -1; return -1;
} }
pa_namereg_set_default(c, n, PA_NAMEREG_SINK); if ((s = pa_namereg_get(c, n, PA_NAMEREG_SINK)))
pa_namereg_set_default_sink(c, s);
else
pa_strbuf_printf(buf, "Sink %s does not exist.\n", n);
return 0; return 0;
} }
static int pa_cli_command_source_default(pa_core *c, pa_tokenizer *t, pa_strbuf *buf, pa_bool_t *fail) { static int pa_cli_command_source_default(pa_core *c, pa_tokenizer *t, pa_strbuf *buf, pa_bool_t *fail) {
const char *n; const char *n;
pa_source *s;
pa_core_assert_ref(c); pa_core_assert_ref(c);
pa_assert(t); pa_assert(t);
@ -886,7 +893,10 @@ static int pa_cli_command_source_default(pa_core *c, pa_tokenizer *t, pa_strbuf
return -1; return -1;
} }
pa_namereg_set_default(c, n, PA_NAMEREG_SOURCE); if ((s = pa_namereg_get(c, n, PA_NAMEREG_SOURCE)))
pa_namereg_set_default_source(c, s);
else
pa_strbuf_printf(buf, "Source %s does not exist.\n", n);
return 0; return 0;
} }
@ -1451,7 +1461,6 @@ static int pa_cli_command_dump(pa_core *c, pa_tokenizer *t, pa_strbuf *buf, pa_b
pa_source *source; pa_source *source;
pa_card *card; pa_card *card;
int nl; int nl;
const char *p;
uint32_t idx; uint32_t idx;
char txt[256]; char txt[256];
time_t now; time_t now;
@ -1518,20 +1527,20 @@ static int pa_cli_command_dump(pa_core *c, pa_tokenizer *t, pa_strbuf *buf, pa_b
nl = 0; nl = 0;
if ((p = pa_namereg_get_default_sink_name(c))) { if ((sink = pa_namereg_get_default_sink(c))) {
if (!nl) { if (!nl) {
pa_strbuf_puts(buf, "\n"); pa_strbuf_puts(buf, "\n");
nl = 1; nl = 1;
} }
pa_strbuf_printf(buf, "set-default-sink %s\n", p); pa_strbuf_printf(buf, "set-default-sink %s\n", sink->name);
} }
if ((p = pa_namereg_get_default_source_name(c))) { if ((source = pa_namereg_get_default_source(c))) {
if (!nl) { if (!nl) {
pa_strbuf_puts(buf, "\n"); pa_strbuf_puts(buf, "\n");
nl = 1; nl = 1;
} }
pa_strbuf_printf(buf, "set-default-source %s\n", p); pa_strbuf_printf(buf, "set-default-source %s\n", source->name);
} }
pa_strbuf_puts(buf, "\n### EOF\n"); pa_strbuf_puts(buf, "\n### EOF\n");

View file

@ -248,7 +248,7 @@ char *pa_sink_list_to_string(pa_core *c) {
"\tchannel map: %s%s%s\n" "\tchannel map: %s%s%s\n"
"\tused by: %u\n" "\tused by: %u\n"
"\tlinked by: %u\n", "\tlinked by: %u\n",
c->default_sink_name && !strcmp(sink->name, c->default_sink_name) ? '*' : ' ', sink == c->default_sink ? '*' : ' ',
sink->index, sink->index,
sink->name, sink->name,
sink->driver, sink->driver,
@ -339,7 +339,7 @@ char *pa_source_list_to_string(pa_core *c) {
"\tchannel map: %s%s%s\n" "\tchannel map: %s%s%s\n"
"\tused by: %u\n" "\tused by: %u\n"
"\tlinked by: %u\n", "\tlinked by: %u\n",
c->default_source_name && !strcmp(source->name, c->default_source_name) ? '*' : ' ', c->default_source == source ? '*' : ' ',
source->index, source->index,
source->name, source->name,
source->driver, source->driver,

View file

@ -99,7 +99,8 @@ pa_core* pa_core_new(pa_mainloop_api *m, pa_bool_t shared, size_t shm_size) {
c->sink_inputs = pa_idxset_new(NULL, NULL); c->sink_inputs = pa_idxset_new(NULL, NULL);
c->cards = pa_idxset_new(NULL, NULL); c->cards = pa_idxset_new(NULL, NULL);
c->default_source_name = c->default_sink_name = NULL; c->default_source = NULL;
c->default_sink = NULL;
c->modules = NULL; c->modules = NULL;
c->namereg = NULL; c->namereg = NULL;
@ -191,8 +192,8 @@ static void core_free(pa_object *o) {
if (c->exit_event) if (c->exit_event)
c->mainloop->time_free(c->exit_event); c->mainloop->time_free(c->exit_event);
pa_xfree(c->default_source_name); pa_assert(!c->default_source);
pa_xfree(c->default_sink_name); pa_assert(!c->default_sink);
pa_silence_cache_done(&c->silence_cache); pa_silence_cache_done(&c->silence_cache);
pa_mempool_free(c->mempool); pa_mempool_free(c->mempool);

View file

@ -25,6 +25,8 @@
#include <pulse/mainloop-api.h> #include <pulse/mainloop-api.h>
#include <pulse/sample.h> #include <pulse/sample.h>
typedef struct pa_core pa_core;
#include <pulsecore/idxset.h> #include <pulsecore/idxset.h>
#include <pulsecore/hashmap.h> #include <pulsecore/hashmap.h>
#include <pulsecore/memblock.h> #include <pulsecore/memblock.h>
@ -34,9 +36,8 @@
#include <pulsecore/hook-list.h> #include <pulsecore/hook-list.h>
#include <pulsecore/asyncmsgq.h> #include <pulsecore/asyncmsgq.h>
#include <pulsecore/sample-util.h> #include <pulsecore/sample-util.h>
#include <pulsecore/sink.h>
typedef struct pa_core pa_core; #include <pulsecore/source.h>
#include <pulsecore/core-subscribe.h> #include <pulsecore/core-subscribe.h>
#include <pulsecore/sink-input.h> #include <pulsecore/sink-input.h>
#include <pulsecore/msgobject.h> #include <pulsecore/msgobject.h>
@ -112,7 +113,8 @@ struct pa_core {
pa_hashmap *namereg, *shared; pa_hashmap *namereg, *shared;
/* The name of the default sink/source */ /* The name of the default sink/source */
char *default_source_name, *default_sink_name; pa_source *default_source;
pa_sink *default_sink;
pa_sample_spec default_sample_spec; pa_sample_spec default_sample_spec;
unsigned default_n_fragments, default_fragment_size_msec; unsigned default_n_fragments, default_fragment_size_msec;

View file

@ -173,6 +173,11 @@ void pa_namereg_unregister(pa_core *c, const char *name) {
pa_assert_se(e = pa_hashmap_remove(c->namereg, name)); pa_assert_se(e = pa_hashmap_remove(c->namereg, name));
if (c->default_sink == e->data)
pa_namereg_set_default_sink(c, NULL);
else if (c->default_source == e->data)
pa_namereg_set_default_source(c, NULL);
pa_xfree(e->name); pa_xfree(e->name);
pa_xfree(e); pa_xfree(e);
} }
@ -182,32 +187,27 @@ void* pa_namereg_get(pa_core *c, const char *name, pa_namereg_type_t type) {
uint32_t idx; uint32_t idx;
pa_assert(c); pa_assert(c);
if (!name) { if (type == PA_NAMEREG_SOURCE && (!name || pa_streq(name, "@DEFAULT_SOURCE@"))) {
pa_source *s;
if (type == PA_NAMEREG_SOURCE) if ((s = pa_namereg_get_default_source(c)))
name = pa_namereg_get_default_source_name(c); return s;
else if (type == PA_NAMEREG_SINK)
name = pa_namereg_get_default_sink_name(c);
} else if (strcmp(name, "@DEFAULT_SINK@") == 0) { } else if (type == PA_NAMEREG_SINK && (!name || pa_streq(name, "@DEFAULT_SINK@"))) {
if (type == PA_NAMEREG_SINK) pa_sink *s;
name = pa_namereg_get_default_sink_name(c);
} else if (strcmp(name, "@DEFAULT_SOURCE@") == 0) { if ((s = pa_namereg_get_default_sink(c)))
if (type == PA_NAMEREG_SOURCE) return s;
name = pa_namereg_get_default_source_name(c);
} else if (strcmp(name, "@DEFAULT_MONITOR@") == 0) { } else if (type == PA_NAMEREG_SOURCE && name && pa_streq(name, "@DEFAULT_MONITOR@")) {
if (type == PA_NAMEREG_SOURCE) { pa_sink *s;
pa_sink *k;
if ((k = pa_namereg_get(c, NULL, PA_NAMEREG_SINK))) if ((s = pa_namereg_get(c, NULL, PA_NAMEREG_SINK)))
return k->monitor_source; return s->monitor_source;
}
} else if (*name == '@')
name = NULL;
if (!name) }
if (*name == '@' || !name || !pa_namereg_is_valid_name(name))
return NULL; return NULL;
if (c->namereg && (e = pa_hashmap_get(c->namereg, name))) if (c->namereg && (e = pa_hashmap_get(c->namereg, name)))
@ -229,62 +229,57 @@ void* pa_namereg_get(pa_core *c, const char *name, pa_namereg_type_t type) {
return NULL; return NULL;
} }
int pa_namereg_set_default(pa_core*c, const char *name, pa_namereg_type_t type) { pa_sink* pa_namereg_set_default_sink(pa_core*c, pa_sink *s) {
char **s;
pa_assert(c); pa_assert(c);
pa_assert(type == PA_NAMEREG_SINK || type == PA_NAMEREG_SOURCE);
s = type == PA_NAMEREG_SINK ? &c->default_sink_name : &c->default_source_name; if (c->default_sink != s) {
c->default_sink = s;
pa_subscription_post(c, PA_SUBSCRIPTION_EVENT_SERVER|PA_SUBSCRIPTION_EVENT_CHANGE, PA_INVALID_INDEX);
}
if (!name && !*s) return s;
return 0;
if (name && *s && !strcmp(name, *s))
return 0;
if (!pa_namereg_is_valid_name(name))
return -1;
pa_xfree(*s);
*s = pa_xstrdup(name);
pa_subscription_post(c, PA_SUBSCRIPTION_EVENT_SERVER|PA_SUBSCRIPTION_EVENT_CHANGE, PA_INVALID_INDEX);
return 0;
} }
const char *pa_namereg_get_default_sink_name(pa_core *c) { pa_source* pa_namereg_set_default_source(pa_core*c, pa_source *s) {
pa_assert(c);
if (c->default_source != s) {
c->default_source = s;
pa_subscription_post(c, PA_SUBSCRIPTION_EVENT_SERVER|PA_SUBSCRIPTION_EVENT_CHANGE, PA_INVALID_INDEX);
}
return s;
}
pa_sink *pa_namereg_get_default_sink(pa_core *c) {
pa_sink *s; pa_sink *s;
pa_assert(c); pa_assert(c);
if (c->default_sink_name) if (c->default_sink)
return c->default_sink_name; return c->default_sink;
if ((s = pa_idxset_first(c->sinks, NULL))) if ((s = pa_idxset_first(c->sinks, NULL)))
pa_namereg_set_default(c, s->name, PA_NAMEREG_SINK); return pa_namereg_set_default_sink(c, s);
return c->default_sink_name; return NULL;
} }
const char *pa_namereg_get_default_source_name(pa_core *c) { pa_source *pa_namereg_get_default_source(pa_core *c) {
pa_source *s; pa_source *s;
uint32_t idx; uint32_t idx;
pa_assert(c); pa_assert(c);
if (c->default_source_name) if (c->default_source)
return c->default_source_name; return c->default_source;
for (s = pa_idxset_first(c->sources, &idx); s; s = pa_idxset_next(c->sources, &idx)) for (s = PA_SOURCE(pa_idxset_first(c->sources, &idx)); s; s = PA_SOURCE(pa_idxset_next(c->sources, &idx)))
if (!s->monitor_of) { if (!s->monitor_of)
pa_namereg_set_default(c, s->name, PA_NAMEREG_SOURCE); return pa_namereg_set_default_source(c, s);
break;
}
if (!c->default_source_name) if ((s = pa_idxset_first(c->sources, NULL)))
if ((s = pa_idxset_first(c->sources, NULL))) return pa_namereg_set_default_source(c, s);
pa_namereg_set_default(c, s->name, PA_NAMEREG_SOURCE);
return c->default_source_name; return NULL;
} }

View file

@ -39,10 +39,12 @@ void pa_namereg_free(pa_core *c);
const char *pa_namereg_register(pa_core *c, const char *name, pa_namereg_type_t type, void *data, pa_bool_t fail); const char *pa_namereg_register(pa_core *c, const char *name, pa_namereg_type_t type, void *data, pa_bool_t fail);
void pa_namereg_unregister(pa_core *c, const char *name); void pa_namereg_unregister(pa_core *c, const char *name);
void* pa_namereg_get(pa_core *c, const char *name, pa_namereg_type_t type); void* pa_namereg_get(pa_core *c, const char *name, pa_namereg_type_t type);
int pa_namereg_set_default(pa_core*c, const char *name, pa_namereg_type_t type);
const char *pa_namereg_get_default_sink_name(pa_core *c); pa_sink* pa_namereg_set_default_sink(pa_core*c, pa_sink *s);
const char *pa_namereg_get_default_source_name(pa_core *c); pa_source* pa_namereg_set_default_source(pa_core*c, pa_source *s);
pa_sink *pa_namereg_get_default_sink(pa_core *c);
pa_source *pa_namereg_get_default_source(pa_core *c);
pa_bool_t pa_namereg_is_valid_name(const char *name); pa_bool_t pa_namereg_is_valid_name(const char *name);
char* pa_namereg_make_valid_name(const char *name); char* pa_namereg_make_valid_name(const char *name);

View file

@ -156,6 +156,8 @@ static void line_callback(pa_ioline *line, const char *s, void *userdata) {
if (!strcmp(c->url, URL_ROOT)) { if (!strcmp(c->url, URL_ROOT)) {
char txt[256]; char txt[256];
pa_sink *def_sink;
pa_source *def_source;
http_response(c, 200, "OK", "text/html"); http_response(c, 200, "OK", "text/html");
pa_ioline_puts(c->line, pa_ioline_puts(c->line,
@ -173,8 +175,12 @@ static void line_callback(pa_ioline *line, const char *s, void *userdata) {
PRINTF_FIELD("User Name:", pa_get_user_name(txt, sizeof(txt))); PRINTF_FIELD("User Name:", pa_get_user_name(txt, sizeof(txt)));
PRINTF_FIELD("Host name:", pa_get_host_name(txt, sizeof(txt))); PRINTF_FIELD("Host name:", pa_get_host_name(txt, sizeof(txt)));
PRINTF_FIELD("Default Sample Specification:", pa_sample_spec_snprint(txt, sizeof(txt), &c->protocol->core->default_sample_spec)); PRINTF_FIELD("Default Sample Specification:", pa_sample_spec_snprint(txt, sizeof(txt), &c->protocol->core->default_sample_spec));
PRINTF_FIELD("Default Sink:", pa_namereg_get_default_sink_name(c->protocol->core));
PRINTF_FIELD("Default Source:", pa_namereg_get_default_source_name(c->protocol->core)); def_sink = pa_namereg_get_default_sink(c->protocol->core);
def_source = pa_namereg_get_default_source(c->protocol->core);
PRINTF_FIELD("Default Sink:", def_sink ? def_sink->name : "n/a");
PRINTF_FIELD("Default Source:", def_source ? def_source->name : "n/a");
pa_ioline_puts(c->line, "</table>"); pa_ioline_puts(c->line, "</table>");

View file

@ -3031,7 +3031,8 @@ static void command_get_server_info(pa_pdispatch *pd, uint32_t command, uint32_t
pa_native_connection *c = PA_NATIVE_CONNECTION(userdata); pa_native_connection *c = PA_NATIVE_CONNECTION(userdata);
pa_tagstruct *reply; pa_tagstruct *reply;
char txt[256]; char txt[256];
const char *n; pa_sink *def_sink;
pa_source *def_source;
pa_sample_spec fixed_ss; pa_sample_spec fixed_ss;
pa_native_connection_assert_ref(c); pa_native_connection_assert_ref(c);
@ -3053,10 +3054,10 @@ static void command_get_server_info(pa_pdispatch *pd, uint32_t command, uint32_t
fixup_sample_spec(c, &fixed_ss, &c->protocol->core->default_sample_spec); fixup_sample_spec(c, &fixed_ss, &c->protocol->core->default_sample_spec);
pa_tagstruct_put_sample_spec(reply, &fixed_ss); pa_tagstruct_put_sample_spec(reply, &fixed_ss);
n = pa_namereg_get_default_sink_name(c->protocol->core); def_sink = pa_namereg_get_default_sink(c->protocol->core);
pa_tagstruct_puts(reply, n); pa_tagstruct_puts(reply, def_sink ? def_sink->name : NULL);
n = pa_namereg_get_default_source_name(c->protocol->core); def_source = pa_namereg_get_default_source(c->protocol->core);
pa_tagstruct_puts(reply, n); pa_tagstruct_puts(reply, def_source ? def_source->name : NULL);
pa_tagstruct_putu32(reply, c->protocol->core->cookie); pa_tagstruct_putu32(reply, c->protocol->core->cookie);
@ -3671,7 +3672,23 @@ static void command_set_default_sink_or_source(pa_pdispatch *pd, uint32_t comman
CHECK_VALIDITY(c->pstream, c->authorized, tag, PA_ERR_ACCESS); CHECK_VALIDITY(c->pstream, c->authorized, tag, PA_ERR_ACCESS);
CHECK_VALIDITY(c->pstream, !s || pa_namereg_is_valid_name(s), tag, PA_ERR_INVALID); CHECK_VALIDITY(c->pstream, !s || pa_namereg_is_valid_name(s), tag, PA_ERR_INVALID);
pa_namereg_set_default(c->protocol->core, s, command == PA_COMMAND_SET_DEFAULT_SOURCE ? PA_NAMEREG_SOURCE : PA_NAMEREG_SINK); if (command == PA_COMMAND_SET_DEFAULT_SOURCE) {
pa_source *source;
source = pa_namereg_get(c->protocol->core, s, PA_NAMEREG_SOURCE);
CHECK_VALIDITY(c->pstream, source, tag, PA_ERR_NOENTITY);
pa_namereg_set_default_source(c->protocol->core, source);
} else {
pa_sink *sink;
pa_assert(command == PA_COMMAND_SET_DEFAULT_SINK);
sink = pa_namereg_get(c->protocol->core, s, PA_NAMEREG_SINK);
CHECK_VALIDITY(c->pstream, sink, tag, PA_ERR_NOENTITY);
pa_namereg_set_default_sink(c->protocol->core, sink);
}
pa_pstream_send_simple_ack(c->pstream, tag); pa_pstream_send_simple_ack(c->pstream, tag);
} }

View file

@ -32,6 +32,7 @@ typedef struct pa_source_output pa_source_output;
#include <pulsecore/resampler.h> #include <pulsecore/resampler.h>
#include <pulsecore/module.h> #include <pulsecore/module.h>
#include <pulsecore/client.h> #include <pulsecore/client.h>
#include <pulsecore/sink-input.h>
typedef enum pa_source_output_state { typedef enum pa_source_output_state {
PA_SOURCE_OUTPUT_INIT, PA_SOURCE_OUTPUT_INIT,