BMFF: fix handling of boxes w/ zero length or type
(cherry picked from commit f80403767b34818f3298d7ae54e6b36315f3b0a5)
This commit is contained in:
parent
c319699ac5
commit
53fe85b2c4
@ -110,7 +110,7 @@ static bool skipBox(uint32_t box) {
|
||||
// Allows boxHandler() to optimise the reading of files by identifying
|
||||
// box types that we're not interested in. Box types listed here must
|
||||
// not appear in the cases in switch (box_type) in boxHandler().
|
||||
return box == TAG_mdat; // mdat is where the main image lives and can be huge
|
||||
return box == 0 || box == TAG_mdat; // mdat is where the main image lives and can be huge
|
||||
}
|
||||
|
||||
std::string BmffImage::mimeType() const {
|
||||
@ -277,6 +277,11 @@ uint64_t BmffImage::boxHandler(std::ostream& out /* = std::cout*/, Exiv2::PrintS
|
||||
box_length = data.read_uint64(0, endian_);
|
||||
}
|
||||
|
||||
if (box_length == 0) {
|
||||
// Zero length is also valid and indicates box extends to the end of file.
|
||||
box_length = pbox_end - address;
|
||||
}
|
||||
|
||||
// read data in box and restore file position
|
||||
const size_t restore = io_->tell();
|
||||
Internal::enforce(box_length >= hdrsize, Exiv2::ErrorCode::kerCorruptedMetadata);
|
||||
|
||||
BIN
test/data/pr_2612_poc.heic
Normal file
BIN
test/data/pr_2612_poc.heic
Normal file
Binary file not shown.
1
test/data/test_reference_files/pr_2612_poc.heic.out
Normal file
1
test/data/test_reference_files/pr_2612_poc.heic.out
Normal file
@ -0,0 +1 @@
|
||||
|
||||
Loading…
Reference in New Issue
Block a user