output/pulse: clear the "mainloop" attribute on error

When enabling the pulse device fails, clear po->mainloop after
pa_threaded_mainloop_free() has finished.  This is important for the
assertions.

Two wrong g_free() calls were also removed.
This commit is contained in:
Max Kellermann 2010-01-17 12:03:22 +01:00
parent 26841b6058
commit 828a5f552f

View File

@ -244,6 +244,7 @@ pulse_output_setup_context(struct pulse_output *po, GError **error_r)
if (!pulse_output_connect(po, error_r)) { if (!pulse_output_connect(po, error_r)) {
pa_context_unref(po->context); pa_context_unref(po->context);
po->context = NULL;
return false; return false;
} }
@ -315,7 +316,7 @@ pulse_output_enable(void *data, GError **error_r)
if (pa_threaded_mainloop_start(po->mainloop) < 0) { if (pa_threaded_mainloop_start(po->mainloop) < 0) {
pa_threaded_mainloop_unlock(po->mainloop); pa_threaded_mainloop_unlock(po->mainloop);
pa_threaded_mainloop_free(po->mainloop); pa_threaded_mainloop_free(po->mainloop);
g_free(po); po->mainloop = NULL;
g_set_error(error_r, pulse_output_quark(), 0, g_set_error(error_r, pulse_output_quark(), 0,
"pa_threaded_mainloop_start() has failed"); "pa_threaded_mainloop_start() has failed");
@ -332,7 +333,7 @@ pulse_output_enable(void *data, GError **error_r)
pa_threaded_mainloop_unlock(po->mainloop); pa_threaded_mainloop_unlock(po->mainloop);
pa_threaded_mainloop_stop(po->mainloop); pa_threaded_mainloop_stop(po->mainloop);
pa_threaded_mainloop_free(po->mainloop); pa_threaded_mainloop_free(po->mainloop);
g_free(po); po->mainloop = NULL;
return false; return false;
} }