diff options
author | Lennart Poettering <lennart@poettering.net> | 2007-08-09 21:05:20 +0000 |
---|---|---|
committer | Lennart Poettering <lennart@poettering.net> | 2007-08-09 21:05:20 +0000 |
commit | 30ccf9a5c9b31fcb370d3c724a1a02fdea94ce65 (patch) | |
tree | 39413bebab17e4e8b2c9e380e3bb3f98526b6de3 /src/pulsecore/source-output.c | |
parent | ed01e1adb52c804bc43a4ba7b5a7060071a60030 (diff) |
add a couple of additional hooks for modules to use
git-svn-id: file:///home/lennart/svn/public/pulseaudio/branches/lennart@1600 fefdeb5f-60dc-0310-8127-8f9354f1896f
Diffstat (limited to 'src/pulsecore/source-output.c')
-rw-r--r-- | src/pulsecore/source-output.c | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/src/pulsecore/source-output.c b/src/pulsecore/source-output.c index 9b828e1a..95755f3b 100644 --- a/src/pulsecore/source-output.c +++ b/src/pulsecore/source-output.c @@ -187,21 +187,26 @@ void pa_source_output_disconnect(pa_source_output*o) { pa_assert(o); pa_return_if_fail(o->state != PA_SOURCE_OUTPUT_DISCONNECTED); + pa_hook_fire(&o->source->core->hook_source_output_disconnect, o); + pa_asyncmsgq_send(o->source->asyncmsgq, PA_MSGOBJECT(o->source), PA_SOURCE_MESSAGE_REMOVE_OUTPUT, o, 0, NULL); pa_idxset_remove_by_data(o->source->core->source_outputs, o, NULL); pa_idxset_remove_by_data(o->source->outputs, o, NULL); - pa_source_output_unref(o); pa_subscription_post(o->source->core, PA_SUBSCRIPTION_EVENT_SOURCE_OUTPUT|PA_SUBSCRIPTION_EVENT_REMOVE, o->index); source_output_set_state(o, PA_SOURCE_OUTPUT_DISCONNECTED); pa_source_update_status(o->source); - o->source = NULL; o->push = NULL; o->kill = NULL; o->get_latency = NULL; + + pa_hook_fire(&o->source->core->hook_source_output_disconnect_post, o); + + o->source = NULL; + pa_source_output_unref(o); } static void source_output_free(pa_object* mo) { @@ -229,6 +234,8 @@ void pa_source_output_put(pa_source_output *o) { pa_source_update_status(o->source); pa_subscription_post(o->source->core, PA_SUBSCRIPTION_EVENT_SOURCE_OUTPUT|PA_SUBSCRIPTION_EVENT_NEW, o->index); + + pa_hook_fire(&o->source->core->hook_source_output_new_post, o); } void pa_source_output_kill(pa_source_output*o) { |