From 6d82cda0ff9dd5591aadf0f10b8b08b0a7742725 Mon Sep 17 00:00:00 2001 From: Jan Urbanski Date: Thu, 22 Jan 2009 13:39:34 +0100 Subject: [MOVED FROM BAD 49/57] Add support for ECMA arrays in script tags. Fixes bug #567965. Add support for ECMA arrays in script tags. This fixes seeking on some files that have the seek table stored inside an ECMA array instead of the normal array. --- gst/flv/gstflvparse.c | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) (limited to 'gst/flv') diff --git a/gst/flv/gstflvparse.c b/gst/flv/gstflvparse.c index b15a65ba..8c29a325 100644 --- a/gst/flv/gstflvparse.c +++ b/gst/flv/gstflvparse.c @@ -206,6 +206,29 @@ gst_flv_parse_metadata_item (GstFLVDemux * demux, GstByteReader * reader, break; } + case 8: // ECMA array + { + guint32 nb_elems; + gboolean end_of_object_marker = FALSE; + + if (!gst_byte_reader_get_uint32_be (reader, &nb_elems)) + goto error; + + GST_DEBUG_OBJECT (demux, "there are approx. %d elements in the array", + nb_elems); + + while (!end_of_object_marker) { + gboolean ok = + gst_flv_parse_metadata_item (demux, reader, &end_of_object_marker); + + if (G_UNLIKELY (!ok)) { + GST_WARNING_OBJECT (demux, "failed reading a tag, skipping"); + goto error; + } + } + + break; + } case 9: // End marker { GST_DEBUG_OBJECT (demux, "end marker ?"); -- cgit