summaryrefslogtreecommitdiffstats
path: root/gst/wavparse/gstwavparse.c
diff options
context:
space:
mode:
Diffstat (limited to 'gst/wavparse/gstwavparse.c')
-rw-r--r--gst/wavparse/gstwavparse.c17
1 files changed, 8 insertions, 9 deletions
diff --git a/gst/wavparse/gstwavparse.c b/gst/wavparse/gstwavparse.c
index 8512ed52..78394426 100644
--- a/gst/wavparse/gstwavparse.c
+++ b/gst/wavparse/gstwavparse.c
@@ -1974,8 +1974,10 @@ gst_wavparse_pad_query (GstPad * pad, GstQuery * query)
GstWavParse *wav = GST_WAVPARSE (gst_pad_get_parent (pad));
/* only if we know */
- if (wav->state != GST_WAVPARSE_DATA)
+ if (wav->state != GST_WAVPARSE_DATA) {
+ gst_object_unref (wav);
return FALSE;
+ }
switch (GST_QUERY_TYPE (query)) {
case GST_QUERY_POSITION:
@@ -2117,20 +2119,17 @@ gst_wavparse_sink_activate (GstPad * sinkpad)
static gboolean
gst_wavparse_sink_activate_pull (GstPad * sinkpad, gboolean active)
{
- GstWavParse *wav = GST_WAVPARSE (gst_pad_get_parent (sinkpad));
-
- GST_DEBUG_OBJECT (wav, "activating pull");
+ GstWavParse *wav = GST_WAVPARSE (GST_OBJECT_PARENT (sinkpad));
if (active) {
/* if we have a scheduler we can start the task */
wav->segment_running = TRUE;
- gst_pad_start_task (sinkpad, (GstTaskFunction) gst_wavparse_loop, sinkpad);
+ return gst_pad_start_task (sinkpad, (GstTaskFunction) gst_wavparse_loop,
+ sinkpad);
} else {
- gst_pad_stop_task (sinkpad);
+ wav->segment_running = FALSE;
+ return gst_pad_stop_task (sinkpad);
}
- gst_object_unref (wav);
-
- return TRUE;
};
static GstStateChangeReturn