Commit e364643f authored by Rémi Denis-Courmont's avatar Rémi Denis-Courmont

PulseAudio: keep context callback active at all times

This keeps track of available output devices. Again, without core
support yet, this is not yet useful in any way.
parent 76303c26
...@@ -104,7 +104,7 @@ static void context_cb(pa_context *ctx, pa_subscription_event_type_t type, ...@@ -104,7 +104,7 @@ static void context_cb(pa_context *ctx, pa_subscription_event_type_t type,
break; break;
case PA_SUBSCRIPTION_EVENT_SINK_INPUT: case PA_SUBSCRIPTION_EVENT_SINK_INPUT:
if (idx != pa_stream_get_index(sys->stream)) if (sys->stream == NULL || idx != pa_stream_get_index(sys->stream))
break; /* only interested in our sink input */ break; /* only interested in our sink input */
/* Gee... PA will not provide the infos directly in the event. */ /* Gee... PA will not provide the infos directly in the event. */
...@@ -718,7 +718,6 @@ static void Stop(audio_output_t *); ...@@ -718,7 +718,6 @@ static void Stop(audio_output_t *);
static int Start(audio_output_t *aout, audio_sample_format_t *restrict fmt) static int Start(audio_output_t *aout, audio_sample_format_t *restrict fmt)
{ {
aout_sys_t *sys = aout->sys; aout_sys_t *sys = aout->sys;
pa_operation *op;
/* Sample format specification */ /* Sample format specification */
struct pa_sample_spec ss; struct pa_sample_spec ss;
...@@ -957,25 +956,8 @@ static int Start(audio_output_t *aout, audio_sample_format_t *restrict fmt) ...@@ -957,25 +956,8 @@ static int Start(audio_output_t *aout, audio_sample_format_t *restrict fmt)
} }
#endif #endif
stream_buffer_attr_cb(s, aout); stream_buffer_attr_cb(s, aout);
var_Create(aout, "audio-device", VLC_VAR_INTEGER|VLC_VAR_HASCHOICE);
var_Change(aout, "audio-device", VLC_VAR_SETTEXT,
&(vlc_value_t){ .psz_string = (char *)_("Audio device") },
NULL);
var_AddCallback (aout, "audio-device", StreamMove, s); var_AddCallback (aout, "audio-device", StreamMove, s);
op = pa_context_get_sink_info_list(sys->context, sink_list_cb, aout);
/* We may need to wait for completion... once LibVLC supports this */
if (op != NULL)
pa_operation_unref(op);
stream_moved_cb(s, aout); stream_moved_cb(s, aout);
/* Context events */
const pa_subscription_mask_t mask = PA_SUBSCRIPTION_MASK_SINK
| PA_SUBSCRIPTION_MASK_SINK_INPUT;
pa_context_set_subscribe_callback(sys->context, context_cb, aout);
op = pa_context_subscribe(sys->context, mask, NULL, NULL);
if (likely(op != NULL))
pa_operation_unref(op);
pa_threaded_mainloop_unlock(sys->mainloop); pa_threaded_mainloop_unlock(sys->mainloop);
return VLC_SUCCESS; return VLC_SUCCESS;
...@@ -996,7 +978,6 @@ static void Stop(audio_output_t *aout) ...@@ -996,7 +978,6 @@ static void Stop(audio_output_t *aout)
/* The callback takes mainloop lock, so it CANNOT be held here! */ /* The callback takes mainloop lock, so it CANNOT be held here! */
var_DelCallback (aout, "audio-device", StreamMove, s); var_DelCallback (aout, "audio-device", StreamMove, s);
var_Destroy (aout, "audio-device");
pa_threaded_mainloop_lock(sys->mainloop); pa_threaded_mainloop_lock(sys->mainloop);
if (unlikely(sys->trigger != NULL)) if (unlikely(sys->trigger != NULL))
...@@ -1013,9 +994,9 @@ static void Stop(audio_output_t *aout) ...@@ -1013,9 +994,9 @@ static void Stop(audio_output_t *aout)
pa_stream_set_started_callback(s, NULL, NULL); pa_stream_set_started_callback(s, NULL, NULL);
pa_stream_set_suspended_callback(s, NULL, NULL); pa_stream_set_suspended_callback(s, NULL, NULL);
pa_stream_set_underflow_callback(s, NULL, NULL); pa_stream_set_underflow_callback(s, NULL, NULL);
pa_context_set_subscribe_callback(sys->context, NULL, NULL);
pa_stream_unref(s); pa_stream_unref(s);
sys->stream = NULL;
pa_threaded_mainloop_unlock(sys->mainloop); pa_threaded_mainloop_unlock(sys->mainloop);
} }
...@@ -1023,6 +1004,7 @@ static int Open(vlc_object_t *obj) ...@@ -1023,6 +1004,7 @@ static int Open(vlc_object_t *obj)
{ {
audio_output_t *aout = (audio_output_t *)obj; audio_output_t *aout = (audio_output_t *)obj;
aout_sys_t *sys = malloc(sizeof (*sys)); aout_sys_t *sys = malloc(sizeof (*sys));
pa_operation *op;
#if !PA_CHECK_VERSION(0,9,22) #if !PA_CHECK_VERSION(0,9,22)
if (!vlc_xlib_init(obj)) if (!vlc_xlib_init(obj))
...@@ -1038,6 +1020,7 @@ static int Open(vlc_object_t *obj) ...@@ -1038,6 +1020,7 @@ static int Open(vlc_object_t *obj)
free(sys); free(sys);
return VLC_EGENERIC; return VLC_EGENERIC;
} }
sys->stream = NULL;
sys->context = ctx; sys->context = ctx;
aout->sys = sys; aout->sys = sys;
...@@ -1048,6 +1031,27 @@ static int Open(vlc_object_t *obj) ...@@ -1048,6 +1031,27 @@ static int Open(vlc_object_t *obj)
aout->flush = Flush; aout->flush = Flush;
aout->volume_set = VolumeSet; aout->volume_set = VolumeSet;
aout->mute_set = MuteSet; aout->mute_set = MuteSet;
/* Devices (sinks) */
var_Create(aout, "audio-device", VLC_VAR_INTEGER|VLC_VAR_HASCHOICE);
var_Change(aout, "audio-device", VLC_VAR_SETTEXT,
&(vlc_value_t){ .psz_string = (char *)_("Audio device") },
NULL);
pa_threaded_mainloop_lock(sys->mainloop);
op = pa_context_get_sink_info_list(sys->context, sink_list_cb, aout);
if (op != NULL)
pa_operation_unref(op);
/* Context events */
const pa_subscription_mask_t mask = PA_SUBSCRIPTION_MASK_SINK
| PA_SUBSCRIPTION_MASK_SINK_INPUT;
pa_context_set_subscribe_callback(sys->context, context_cb, aout);
op = pa_context_subscribe(sys->context, mask, NULL, NULL);
if (likely(op != NULL))
pa_operation_unref(op);
pa_threaded_mainloop_unlock(sys->mainloop);
return VLC_SUCCESS; return VLC_SUCCESS;
} }
...@@ -1057,6 +1061,11 @@ static void Close(vlc_object_t *obj) ...@@ -1057,6 +1061,11 @@ static void Close(vlc_object_t *obj)
aout_sys_t *sys = aout->sys; aout_sys_t *sys = aout->sys;
pa_context *ctx = sys->context; pa_context *ctx = sys->context;
pa_threaded_mainloop_lock(sys->mainloop);
pa_context_set_subscribe_callback(sys->context, NULL, NULL);
pa_threaded_mainloop_unlock(sys->mainloop);
vlc_pa_disconnect(obj, ctx, sys->mainloop); vlc_pa_disconnect(obj, ctx, sys->mainloop);
var_Destroy (aout, "audio-device");
free(sys); free(sys);
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment