length = header.toUInt();
- if(length == 1) {
+ if(length == 0) {
+ // The last atom which extends to the end of the file.
+ length = file->length() - offset;
+ }
+ else if(length == 1) {
+ // The atom has a 64-bit length.
const long long longLength = file->readBlock(8).toLongLong();
if(longLength <= LONG_MAX) {
- // The atom has a 64-bit length, but it's actually a 31-bit value or long is 64-bit.
+ // The actual length fits in long. That's always the case if long is 64-bit.
length = static_cast<long>(longLength);
}
else {
return;
}
}
+
if(length < 8) {
debug("MP4: Invalid atom size");
length = 0;
CPPUNIT_TEST(testProperties);
CPPUNIT_TEST(testFuzzedFile);
CPPUNIT_TEST(testRepeatedSave);
+ CPPUNIT_TEST(testWithZeroLengthAtom);
CPPUNIT_TEST_SUITE_END();
public:
CPPUNIT_ASSERT_EQUAL(2862L, f.find("0123456789"));
CPPUNIT_ASSERT_EQUAL(-1L, f.find("0123456789", 2863));
}
+
+ void testWithZeroLengthAtom()
+ {
+ MP4::File f(TEST_FILE_PATH_C("zero-length-mdat.m4a"));
+ CPPUNIT_ASSERT(f.isValid());
+ CPPUNIT_ASSERT_EQUAL(1115, f.audioProperties()->lengthInMilliseconds());
+ CPPUNIT_ASSERT_EQUAL(22050, f.audioProperties()->sampleRate());
+ }
+
};
CPPUNIT_TEST_SUITE_REGISTRATION(TestMP4);