summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSebastian Dröge <slomo@circular-chaos.org>2008-10-27 09:20:01 +0000
committerSebastian Dröge <slomo@circular-chaos.org>2008-10-27 09:20:01 +0000
commit04795346c5da5f10dcb013d89ca4b799497e89f2 (patch)
tree8a2e15d0a860ee253a625ef332d25dc6e91a4515
parent8877f3590d6dc4558099aaf3b632a7d5084fbdb9 (diff)
downloadgst-plugins-bad-04795346c5da5f10dcb013d89ca4b799497e89f2.tar.gz
gst-plugins-bad-04795346c5da5f10dcb013d89ca4b799497e89f2.tar.bz2
gst-plugins-bad-04795346c5da5f10dcb013d89ca4b799497e89f2.zip
gst/flv/gstflvdemux.c: Instead of using gst_pad_event_default() use a small gst_pad_push_event() wrapper that only do...
Original commit message from CVS: * gst/flv/gstflvdemux.c: (gst_flv_demux_push_src_event), (gst_flv_demux_loop), (gst_flv_demux_handle_seek_pull), (gst_flv_demux_sink_event): Instead of using gst_pad_event_default() use a small gst_pad_push_event() wrapper that only does what we want and is much more simple.
-rw-r--r--ChangeLog9
-rw-r--r--gst/flv/gstflvdemux.c34
2 files changed, 34 insertions, 9 deletions
diff --git a/ChangeLog b/ChangeLog
index 80058b0e..cc59d462 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,14 @@
2008-10-27 Sebastian Dröge <sebastian.droege@collabora.co.uk>
+ * gst/flv/gstflvdemux.c: (gst_flv_demux_push_src_event),
+ (gst_flv_demux_loop), (gst_flv_demux_handle_seek_pull),
+ (gst_flv_demux_sink_event):
+ Instead of using gst_pad_event_default() use a small
+ gst_pad_push_event() wrapper that only does what we want and is much
+ more simple.
+
+2008-10-27 Sebastian Dröge <sebastian.droege@collabora.co.uk>
+
* gst/flv/gstflvdemux.c: (gst_flv_demux_change_state),
(gst_flv_demux_set_index), (gst_flv_demux_init):
* gst/flv/gstflvdemux.h:
diff --git a/gst/flv/gstflvdemux.c b/gst/flv/gstflvdemux.c
index 3ab2edc7..8f13ef0b 100644
--- a/gst/flv/gstflvdemux.c
+++ b/gst/flv/gstflvdemux.c
@@ -432,6 +432,22 @@ gst_flv_demux_seek_to_prev_keyframe (GstFLVDemux * demux)
return GST_FLOW_OK;
}
+static gboolean
+gst_flv_demux_push_src_event (GstFLVDemux * demux, GstEvent * event)
+{
+ gboolean ret = TRUE;
+
+ if (demux->audio_pad)
+ ret |= gst_pad_push_event (demux->audio_pad, gst_event_ref (event));
+
+ if (demux->video_pad)
+ ret |= gst_pad_push_event (demux->video_pad, gst_event_ref (event));
+
+ gst_event_unref (event);
+
+ return ret;
+}
+
static void
gst_flv_demux_loop (GstPad * pad)
{
@@ -563,7 +579,7 @@ pause:
/* normal playback, send EOS to all linked pads */
gst_element_no_more_pads (GST_ELEMENT (demux));
GST_LOG_OBJECT (demux, "Sending EOS, at end of stream");
- if (!gst_pad_event_default (demux->sinkpad, gst_event_new_eos ())) {
+ if (!gst_flv_demux_push_src_event (demux, gst_event_new_eos ())) {
GST_WARNING_OBJECT (demux, "failed pushing EOS on streams");
GST_ELEMENT_ERROR (demux, STREAM, FAILED,
("Internal data stream error."),
@@ -575,7 +591,7 @@ pause:
GST_ELEMENT_ERROR (demux, STREAM, FAILED,
("Internal data stream error."),
("stream stopped, reason %s", reason));
- gst_pad_event_default (demux->sinkpad, gst_event_new_eos ());
+ gst_flv_demux_push_src_event (demux, gst_event_new_eos ());
}
}
gst_object_unref (demux);
@@ -732,7 +748,7 @@ gst_flv_demux_handle_seek_pull (GstFLVDemux * demux, GstEvent * event)
if (flush) {
/* Flush start up and downstream to make sure data flow and loops are
idle */
- gst_pad_event_default (demux->sinkpad, gst_event_new_flush_start ());
+ gst_flv_demux_push_src_event (demux, gst_event_new_flush_start ());
gst_pad_push_event (demux->sinkpad, gst_event_new_flush_start ());
} else {
/* Pause the pulling task */
@@ -777,7 +793,7 @@ gst_flv_demux_handle_seek_pull (GstFLVDemux * demux, GstEvent * event)
if (flush) {
/* Stop flushing, the sinks are at time 0 now */
- gst_pad_event_default (demux->sinkpad, gst_event_new_flush_stop ());
+ gst_flv_demux_push_src_event (demux, gst_event_new_flush_stop ());
} else {
GST_DEBUG_OBJECT (demux, "closing running segment %" GST_SEGMENT_FORMAT,
demux->segment);
@@ -909,12 +925,12 @@ gst_flv_demux_sink_event (GstPad * pad, GstEvent * event)
case GST_EVENT_FLUSH_START:
GST_DEBUG_OBJECT (demux, "trying to force chain function to exit");
demux->flushing = TRUE;
- ret = gst_pad_event_default (demux->sinkpad, event);
+ ret = gst_flv_demux_push_src_event (demux, event);
break;
case GST_EVENT_FLUSH_STOP:
GST_DEBUG_OBJECT (demux, "flushing FLV demuxer");
gst_flv_demux_flush (demux, TRUE);
- ret = gst_pad_event_default (demux->sinkpad, event);
+ ret = gst_flv_demux_push_src_event (demux, event);
break;
case GST_EVENT_EOS:
GST_DEBUG_OBJECT (demux, "received EOS");
@@ -923,7 +939,7 @@ gst_flv_demux_sink_event (GstPad * pad, GstEvent * event)
gst_index_commit (demux->index, demux->index_id);
}
gst_element_no_more_pads (GST_ELEMENT (demux));
- if (!gst_pad_event_default (demux->sinkpad, event)) {
+ if (!gst_flv_demux_push_src_event (demux, event)) {
GST_WARNING_OBJECT (demux, "failed pushing EOS on streams");
GST_ELEMENT_ERROR (demux, STREAM, FAILED,
("Internal data stream error."),
@@ -953,7 +969,7 @@ gst_flv_demux_sink_event (GstPad * pad, GstEvent * event)
demux->segment);
/* and forward */
- ret = gst_pad_event_default (demux->sinkpad, event);
+ ret = gst_flv_demux_push_src_event (demux, event);
} else {
/* non-time format */
demux->audio_need_segment = TRUE;
@@ -964,7 +980,7 @@ gst_flv_demux_sink_event (GstPad * pad, GstEvent * event)
break;
}
default:
- ret = gst_pad_event_default (demux->sinkpad, event);
+ ret = gst_flv_demux_push_src_event (demux, event);
break;
}