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.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.c')
-rw-r--r-- | src/pulsecore/source.c | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/src/pulsecore/source.c b/src/pulsecore/source.c index 241e1fb5..f7825931 100644 --- a/src/pulsecore/source.c +++ b/src/pulsecore/source.c @@ -73,6 +73,9 @@ pa_source* pa_source_new( pa_return_null_if_fail(!driver || pa_utf8_valid(driver)); pa_return_null_if_fail(pa_utf8_valid(name) && *name); + if (pa_hook_fire(&core->hook_sink_new, NULL) < 0) /* FIXME */ + return NULL; + s = pa_msgobject_new(pa_source); if (!(name = pa_namereg_register(core, name, PA_NAMEREG_SOURCE, s, fail))) { @@ -125,6 +128,8 @@ pa_source* pa_source_new( pa_subscription_post(core, PA_SUBSCRIPTION_EVENT_SOURCE | PA_SUBSCRIPTION_EVENT_NEW, s->index); + pa_hook_fire(&core->hook_source_new_post, s); + return s; } @@ -153,11 +158,11 @@ void pa_source_disconnect(pa_source *s) { pa_assert(s); pa_return_if_fail(s->state != PA_SOURCE_DISCONNECTED); + pa_hook_fire(&s->core->hook_source_disconnect, s); + pa_namereg_unregister(s->core, s->name); pa_idxset_remove_by_data(s->core->sources, s, NULL); - pa_hook_fire(&s->core->hook_source_disconnect, s); - while ((o = pa_idxset_first(s->outputs, NULL))) { pa_assert(o != j); pa_source_output_kill(o); @@ -174,6 +179,8 @@ void pa_source_disconnect(pa_source *s) { s->set_state = NULL; pa_subscription_post(s->core, PA_SUBSCRIPTION_EVENT_SOURCE | PA_SUBSCRIPTION_EVENT_REMOVE, s->index); + + pa_hook_fire(&s->core->hook_source_disconnect_post, s); } static void source_free(pa_object *o) { |