mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-04 22:48:49 +00:00
gst/: Fix event handling.
Original commit message from CVS: 2004-01-30 Ronald Bultje <rbultje@ronald.bitfreak.net> * gst-libs/gst/riff/riff-read.c: (gst_riff_peek_head), (gst_riff_read_seek): * gst/matroska/ebml-read.c: (gst_ebml_read_element_id), (gst_ebml_read_seek): Fix event handling.
This commit is contained in:
parent
9718c77293
commit
8032ddd30a
2 changed files with 26 additions and 14 deletions
|
@ -1,3 +1,11 @@
|
||||||
|
2004-01-30 Ronald Bultje <rbultje@ronald.bitfreak.net>
|
||||||
|
|
||||||
|
* gst-libs/gst/riff/riff-read.c: (gst_riff_peek_head),
|
||||||
|
(gst_riff_read_seek):
|
||||||
|
* gst/matroska/ebml-read.c: (gst_ebml_read_element_id),
|
||||||
|
(gst_ebml_read_seek):
|
||||||
|
Fix event handling.
|
||||||
|
|
||||||
2004-01-30 Benjamin Otte <in7y118@public.uni-hamburg.de>
|
2004-01-30 Benjamin Otte <in7y118@public.uni-hamburg.de>
|
||||||
|
|
||||||
* ext/ffmpeg/gstffmpegcodecmap.c: (gst_ffmpeg_codecid_to_caps):
|
* ext/ffmpeg/gstffmpegcodecmap.c: (gst_ffmpeg_codecid_to_caps):
|
||||||
|
|
|
@ -158,20 +158,20 @@ gst_riff_peek_head (GstRiffRead *riff,
|
||||||
guint8 *data;
|
guint8 *data;
|
||||||
|
|
||||||
/* read */
|
/* read */
|
||||||
if (gst_bytestream_peek_bytes (riff->bs, &data, 8) != 8) {
|
while (gst_bytestream_peek_bytes (riff->bs, &data, 8) != 8) {
|
||||||
GstEvent *event = NULL;
|
GstEvent *event = NULL;
|
||||||
guint32 remaining;
|
guint32 remaining;
|
||||||
|
|
||||||
/* Here, we might encounter EOS */
|
/* Here, we might encounter EOS */
|
||||||
gst_bytestream_get_status (riff->bs, &remaining, &event);
|
gst_bytestream_get_status (riff->bs, &remaining, &event);
|
||||||
if (event && GST_EVENT_TYPE (event) == GST_EVENT_EOS) {
|
if (event) {
|
||||||
gst_pad_event_default (riff->sinkpad, event);
|
gst_pad_event_default (riff->sinkpad, event);
|
||||||
} else {
|
} else {
|
||||||
gst_event_unref (event);
|
gst_event_unref (event);
|
||||||
GST_ELEMENT_ERROR (riff, RESOURCE, READ, NULL, NULL);
|
GST_ELEMENT_ERROR (riff, RESOURCE, READ, NULL, NULL);
|
||||||
}
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* parse tag + length (if wanted) */
|
/* parse tag + length (if wanted) */
|
||||||
*tag = GUINT32_FROM_LE (((guint32 *) data)[0]);
|
*tag = GUINT32_FROM_LE (((guint32 *) data)[0]);
|
||||||
|
@ -222,7 +222,7 @@ gst_riff_read_seek (GstRiffRead *riff,
|
||||||
{
|
{
|
||||||
guint64 length = gst_bytestream_length (riff->bs);
|
guint64 length = gst_bytestream_length (riff->bs);
|
||||||
guint32 remaining;
|
guint32 remaining;
|
||||||
GstEvent *event;
|
GstEvent *event = NULL;
|
||||||
guchar *data;
|
guchar *data;
|
||||||
|
|
||||||
/* hack for AVI files with broken idx1 size chunk markers */
|
/* hack for AVI files with broken idx1 size chunk markers */
|
||||||
|
@ -246,17 +246,21 @@ gst_riff_read_seek (GstRiffRead *riff,
|
||||||
|
|
||||||
/* and now, peek a new byte. This will fail because there's a
|
/* and now, peek a new byte. This will fail because there's a
|
||||||
* pending event. Then, take the event and return it. */
|
* pending event. Then, take the event and return it. */
|
||||||
if (gst_bytestream_peek_bytes (riff->bs, &data, 1))
|
while (!event) {
|
||||||
g_warning ("Unexpected data after seek");
|
if (gst_bytestream_peek_bytes (riff->bs, &data, 1)) {
|
||||||
|
GST_WARNING ("Unexpected data after seek - this means seek failed");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
/* get the discont event and return */
|
/* get the discont event and return */
|
||||||
gst_bytestream_get_status (riff->bs, &remaining, &event);
|
gst_bytestream_get_status (riff->bs, &remaining, &event);
|
||||||
if (!event || GST_EVENT_TYPE (event) != GST_EVENT_DISCONTINUOUS) {
|
if (!event) {
|
||||||
GST_ELEMENT_ERROR (riff, CORE, EVENT, NULL,
|
GST_WARNING ("No discontinuity event after seek - seek failed");
|
||||||
("No discontinuity event after seek"));
|
break;
|
||||||
if (event)
|
} else if (GST_EVENT_TYPE (event) != GST_EVENT_DISCONTINUOUS) {
|
||||||
gst_event_unref (event);
|
gst_pad_event_default (riff->sinkpad, event);
|
||||||
return NULL;
|
event = NULL;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return event;
|
return event;
|
||||||
|
|
Loading…
Reference in a new issue