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:
Ronald S. Bultje 2004-01-30 12:37:58 +00:00
parent 9718c77293
commit 8032ddd30a
2 changed files with 26 additions and 14 deletions

View file

@ -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):

View file

@ -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;