summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--ChangeLog7
-rw-r--r--gst/qtdemux/qtdemux.c36
2 files changed, 33 insertions, 10 deletions
diff --git a/ChangeLog b/ChangeLog
index df7f1523..197d44c0 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,10 @@
+2006-11-27 Wim Taymans <wim@fluendo.com>
+
+ * gst/qtdemux/qtdemux.c: (gst_qtdemux_get_duration),
+ (gst_qtdemux_handle_src_query), (qtdemux_parse_trak):
+ Remove some asserts and replace them with a proper error
+ message. Fixes #379261.
+
2006-11-26 Michael Smith <msmith@fluendo.com>
* ext/theora/theoradec.c: (theora_dec_src_query),
diff --git a/gst/qtdemux/qtdemux.c b/gst/qtdemux/qtdemux.c
index 6d38fa7c..e174fd95 100644
--- a/gst/qtdemux/qtdemux.c
+++ b/gst/qtdemux/qtdemux.c
@@ -3235,10 +3235,12 @@ qtdemux_parse_trak (GstQTDemux * qtdemux, GNode * trak)
QTDEMUX_GUINT32_GET ((guint8 *) tkhd->data + 8));
mdia = qtdemux_tree_get_child_by_type (trak, FOURCC_mdia);
- g_assert (mdia);
+ if (mdia == NULL)
+ goto corrupt_file;
mdhd = qtdemux_tree_get_child_by_type (mdia, FOURCC_mdhd);
- g_assert (mdhd);
+ if (mdhd == NULL)
+ goto corrupt_file;
/* new streams always need a discont */
stream = g_new0 (QtDemuxStream, 1);
@@ -3276,7 +3278,8 @@ qtdemux_parse_trak (GstQTDemux * qtdemux, GNode * trak)
}
hdlr = qtdemux_tree_get_child_by_type (mdia, FOURCC_hdlr);
- g_assert (hdlr);
+ if (hdlr == NULL)
+ goto corrupt_file;
GST_LOG ("track type: %" GST_FOURCC_FORMAT,
GST_FOURCC_ARGS (QTDEMUX_FOURCC_GET ((guint8 *) hdlr->data + 12)));
@@ -3286,13 +3289,16 @@ qtdemux_parse_trak (GstQTDemux * qtdemux, GNode * trak)
GST_FOURCC_ARGS (stream->subtype));
minf = qtdemux_tree_get_child_by_type (mdia, FOURCC_minf);
- g_assert (minf);
+ if (minf == NULL)
+ goto corrupt_file;
stbl = qtdemux_tree_get_child_by_type (minf, FOURCC_stbl);
- g_assert (stbl);
+ if (stbl == NULL)
+ goto corrupt_file;
stsd = qtdemux_tree_get_child_by_type (stbl, FOURCC_stsd);
- g_assert (stsd);
+ if (stsd == NULL)
+ goto corrupt_file;
stsd_data = (const guint8 *) stsd->data;
if (stream->subtype == FOURCC_vide) {
@@ -3607,20 +3613,24 @@ qtdemux_parse_trak (GstQTDemux * qtdemux, GNode * trak)
/* sample to chunk */
stsc = qtdemux_tree_get_child_by_type (stbl, FOURCC_stsc);
- g_assert (stsc);
+ if (stsc == NULL)
+ goto corrupt_file;
stsc_data = (const guint8 *) stsc->data;
/* sample size */
stsz = qtdemux_tree_get_child_by_type (stbl, FOURCC_stsz);
- g_assert (stsz);
+ if (stsz == NULL)
+ goto corrupt_file;
stsz_data = (const guint8 *) stsz->data;
/* chunk offsets */
stco = qtdemux_tree_get_child_by_type (stbl, FOURCC_stco);
co64 = qtdemux_tree_get_child_by_type (stbl, FOURCC_co64);
- g_assert (stco || co64);
+ if (stco == NULL && co64 == NULL)
+ goto corrupt_file;
stco_data = (const guint8 *) stco->data;
/* sample time */
stts = qtdemux_tree_get_child_by_type (stbl, FOURCC_stts);
- g_assert (stts);
+ if (stts == NULL)
+ goto corrupt_file;
/* sample sync, can be NULL */
stss = qtdemux_tree_get_child_by_type (stbl, FOURCC_stss);
@@ -3895,6 +3905,12 @@ done3:
return;
/* ERRORS */
+corrupt_file:
+ {
+ GST_ELEMENT_ERROR (qtdemux, STREAM, DECODE,
+ (_("This file is corrupt and cannot be played.")), (NULL));
+ return;
+ }
error_encrypted:
{
GST_ELEMENT_ERROR (qtdemux, STREAM, DECODE,