mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-11-27 20:21:24 +00:00
gst/avi/gstavidemux.c: Make _push_event() return TRUE if the event could be pushed on at least one pad and not only i...
Original commit message from CVS: * gst/avi/gstavidemux.c: (gst_avi_demux_push_event), (gst_avi_demux_loop): Make _push_event() return TRUE if the event could be pushed on at least one pad and not only if it could be pushed on all pads, otherwise we'll end up posting an error message on EOS if one or more source pads are not connected.
This commit is contained in:
parent
0ea8d875a2
commit
f91649edb8
2 changed files with 18 additions and 8 deletions
|
@ -1,3 +1,12 @@
|
|||
2007-05-30 Tim-Philipp Müller <tim at centricular dot net>
|
||||
|
||||
* gst/avi/gstavidemux.c: (gst_avi_demux_push_event),
|
||||
(gst_avi_demux_loop):
|
||||
Make _push_event() return TRUE if the event could be pushed on at
|
||||
least one pad and not only if it could be pushed on all pads,
|
||||
otherwise we'll end up posting an error message on EOS if one or
|
||||
more source pads are not connected.
|
||||
|
||||
2007-05-28 Wim Taymans <wim@fluendo.com>
|
||||
|
||||
* gst/rtsp/rtsptransport.c:
|
||||
|
|
|
@ -2451,22 +2451,22 @@ gst_avi_demux_calculate_durations_from_index (GstAviDemux * avi)
|
|||
static gboolean
|
||||
gst_avi_demux_push_event (GstAviDemux * avi, GstEvent * event)
|
||||
{
|
||||
gboolean result = FALSE;
|
||||
gint i;
|
||||
gboolean result = TRUE;
|
||||
|
||||
GST_DEBUG_OBJECT (avi, "sending event to %d streams", avi->num_streams);
|
||||
GST_DEBUG_OBJECT (avi, "sending %s event to %d streams",
|
||||
GST_EVENT_TYPE_NAME (event), avi->num_streams);
|
||||
|
||||
if (avi->num_streams) {
|
||||
for (i = 0; i < avi->num_streams; i++) {
|
||||
avi_stream_context *stream = &avi->stream[i];
|
||||
|
||||
if (stream->pad) {
|
||||
gst_event_ref (event);
|
||||
result &= gst_pad_push_event (stream->pad, event);
|
||||
if (gst_pad_push_event (stream->pad, event))
|
||||
result = TRUE;
|
||||
}
|
||||
}
|
||||
} else {
|
||||
/* return error, as the event was not send */
|
||||
result = FALSE;
|
||||
}
|
||||
gst_event_unref (event);
|
||||
return result;
|
||||
|
@ -3725,9 +3725,10 @@ pause:
|
|||
if (push_eos) {
|
||||
GST_INFO_OBJECT (avi, "sending eos");
|
||||
if (!(gst_avi_demux_push_event (avi, gst_event_new_eos ()))) {
|
||||
/* if we don't error out here it will hand */
|
||||
/* if we don't error out here it will hang */
|
||||
GST_ELEMENT_ERROR (avi, STREAM, FAILED,
|
||||
(_("Internal data stream error.")), ("corrupted file"));
|
||||
(_("Internal data stream error.")),
|
||||
("downstream did not handle EOS"));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue