summaryrefslogtreecommitdiffstats
path: root/src/pulsecore/source.c
diff options
context:
space:
mode:
authorLennart Poettering <lennart@poettering.net>2007-08-09 21:05:20 +0000
committerLennart Poettering <lennart@poettering.net>2007-08-09 21:05:20 +0000
commit30ccf9a5c9b31fcb370d3c724a1a02fdea94ce65 (patch)
tree39413bebab17e4e8b2c9e380e3bb3f98526b6de3 /src/pulsecore/source.c
parented01e1adb52c804bc43a4ba7b5a7060071a60030 (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.c11
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) {