From a9a5690eafe589cf58fd1901f5d16c8908cbd248 Mon Sep 17 00:00:00 2001 From: Zeugma440 Date: Fri, 19 Apr 2024 08:25:03 +0200 Subject: [PATCH] Handle variable size atom header [#261] --- ATL/AudioData/IO/MP4.cs | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/ATL/AudioData/IO/MP4.cs b/ATL/AudioData/IO/MP4.cs index 58897467..df95a104 100644 --- a/ATL/AudioData/IO/MP4.cs +++ b/ATL/AudioData/IO/MP4.cs @@ -1574,7 +1574,7 @@ private static uint navigateToAtom(Stream source, string atomKey) /// Source to read from /// Atom key to look for (e.g. "udta") /// - /// - Item1 : If atom found : raw size of the atom (including the already-read 8-byte header); + /// - Item1 : If atom found : raw size of the atom (including the already-read 8 or 16-byte header); /// If atom not found : 0 /// - Item2 : Size of the atom header (may vary if using the 64-bit variant) /// @@ -1584,13 +1584,13 @@ private static Tuple navigateToAtomSize(Stream source, string atomKey string atomHeader; bool first = true; int iterations = 0; - int atomHeaderSize; + int atomHeaderSize = 8; byte[] data = new byte[8]; do { - atomHeaderSize = 8; - if (!first) source.Seek(atomSize - 8, SeekOrigin.Current); + if (!first) source.Seek(atomSize - atomHeaderSize, SeekOrigin.Current); + atomHeaderSize = 8; // Default 8-bit variant source.Read(data, 0, 4); atomSize = StreamUtils.DecodeBEUInt32(data); source.Read(data, 0, 4);