isomp4: Make 'hdlr' atom dump more flexible

The smallest possible is 24 (and not 25) bytes.

The last "name" field can according to QTFF specifications not be present
at all. The parser will handle this fine and so will the rest of
the qtdemux code.
This commit is contained in:
Edward Hervey 2018-02-09 08:35:52 +01:00 committed by Edward Hervey
parent 8239c67799
commit b415358c7e

View file

@ -185,7 +185,7 @@ qtdemux_dump_hdlr (GstQTDemux * qtdemux, GstByteReader * data, int depth)
guint32 version, type, subtype, manufacturer; guint32 version, type, subtype, manufacturer;
const gchar *name; const gchar *name;
if (!qt_atom_parser_has_remaining (data, 4 + 4 + 4 + 4 + 4 + 4 + 1)) if (!qt_atom_parser_has_remaining (data, 4 + 4 + 4 + 4 + 4 + 4))
return FALSE; return FALSE;
version = GET_UINT32 (data); version = GET_UINT32 (data);
@ -208,10 +208,10 @@ qtdemux_dump_hdlr (GstQTDemux * qtdemux, GstByteReader * data, int depth)
GST_LOG ("%*s name: %s", depth, "", name); GST_LOG ("%*s name: %s", depth, "", name);
} else { } else {
gchar buf[256]; gchar buf[256];
guint len; guint8 len;
len = gst_byte_reader_get_uint8_unchecked (data); if (gst_byte_reader_get_uint8 (data, &len)
if (qt_atom_parser_has_remaining (data, len)) { && qt_atom_parser_has_remaining (data, len)) {
memcpy (buf, gst_byte_reader_peek_data_unchecked (data), len); memcpy (buf, gst_byte_reader_peek_data_unchecked (data), len);
buf[len] = '\0'; buf[len] = '\0';
GST_LOG ("%*s name: %s", depth, "", buf); GST_LOG ("%*s name: %s", depth, "", buf);