mirror of
https://gitlab.freedesktop.org/pulseaudio/pulseaudio.git
synced 2025-11-04 13:29:59 -05:00
source: move the streams to the default_source when the source unlink
When a source is unlinked, all streams of this source are moved to default_source, this action is implemented in the core rather than modules now. And after this change, the module-rescue-streams is not needed, but for backward compatibility, we keep it as a dummy module. Signed-off-by: Hui Wang <hui.wang@canonical.com>
This commit is contained in:
parent
976a366c9f
commit
5e0d5a8682
12 changed files with 35 additions and 267 deletions
|
|
@ -702,6 +702,9 @@ void pa_source_unlink(pa_source *s) {
|
|||
|
||||
pa_core_update_default_source(s->core);
|
||||
|
||||
if (linked)
|
||||
pa_source_move_streams_to_default_source(s->core, s, false);
|
||||
|
||||
if (s->card)
|
||||
pa_idxset_remove_by_data(s->card->sources, s, NULL);
|
||||
|
||||
|
|
@ -2993,7 +2996,7 @@ void pa_source_set_reference_volume_direct(pa_source *s, const pa_cvolume *volum
|
|||
pa_hook_fire(&s->core->hooks[PA_CORE_HOOK_SOURCE_VOLUME_CHANGED], s);
|
||||
}
|
||||
|
||||
void pa_source_move_streams_to_default_source(pa_core *core, pa_source *old_source) {
|
||||
void pa_source_move_streams_to_default_source(pa_core *core, pa_source *old_source, bool default_source_changed) {
|
||||
pa_source_output *o;
|
||||
uint32_t idx;
|
||||
bool old_source_is_unavailable = false;
|
||||
|
|
@ -3001,6 +3004,9 @@ void pa_source_move_streams_to_default_source(pa_core *core, pa_source *old_sour
|
|||
pa_assert(core);
|
||||
pa_assert(old_source);
|
||||
|
||||
if (core->state == PA_CORE_SHUTDOWN)
|
||||
return;
|
||||
|
||||
if (core->default_source == NULL || core->default_source->unlink_requested)
|
||||
return;
|
||||
|
||||
|
|
@ -3020,8 +3026,16 @@ void pa_source_move_streams_to_default_source(pa_core *core, pa_source *old_sour
|
|||
if (pa_safe_streq(old_source->name, o->preferred_source) && !old_source_is_unavailable)
|
||||
continue;
|
||||
|
||||
pa_log_info("The source output %u \"%s\" is moving to %s due to change of the default source.",
|
||||
o->index, pa_strnull(pa_proplist_gets(o->proplist, PA_PROP_APPLICATION_NAME)), core->default_source->name);
|
||||
if (!pa_source_output_may_move_to(o, core->default_source))
|
||||
continue;
|
||||
|
||||
if (default_source_changed)
|
||||
pa_log_info("The source output %u \"%s\" is moving to %s due to change of the default source.",
|
||||
o->index, pa_strnull(pa_proplist_gets(o->proplist, PA_PROP_APPLICATION_NAME)), core->default_source->name);
|
||||
else
|
||||
pa_log_info("The source output %u \"%s\" is moving to %s due to unlink of a source.",
|
||||
o->index, pa_strnull(pa_proplist_gets(o->proplist, PA_PROP_APPLICATION_NAME)), core->default_source->name);
|
||||
|
||||
pa_source_output_move_to(o, core->default_source, false);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue