summaryrefslogtreecommitdiff
path: root/src/lib/writer.cc
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2021-02-23 20:01:49 +0100
committerCarl Hetherington <cth@carlh.net>2021-02-23 20:01:49 +0100
commit4d8c69b356f770144c59982c4196846d6f1dc0b0 (patch)
treed2d1601e1ff8ffc420bbb238874620ac448811a5 /src/lib/writer.cc
parent216ab537915307f5033e8b1fce13bc2517bc4bb9 (diff)
Fix assertion failure in AudioBuffers::copy_from() (#1909)win-splash
A number of frames N was being split up into two parts which together were bigger than N, meaning a copy of one of the parts failed.
Diffstat (limited to 'src/lib/writer.cc')
-rw-r--r--src/lib/writer.cc5
1 files changed, 4 insertions, 1 deletions
diff --git a/src/lib/writer.cc b/src/lib/writer.cc
index 9ebdd92a3..ad588f0a6 100644
--- a/src/lib/writer.cc
+++ b/src/lib/writer.cc
@@ -306,11 +306,14 @@ Writer::write (shared_ptr<const AudioBuffers> audio, DCPTime const time)
end - _audio_reel->period().to
};
+ /* Be careful that part_lengths[0] + part_lengths[1] can't be bigger than audio->frames() */
Frame part_frames[2] = {
part_lengths[0].frames_ceil(afr),
- part_lengths[1].frames_ceil(afr)
+ part_lengths[1].frames_floor(afr)
};
+ DCPOMATIC_ASSERT ((part_frames[0] + part_frames[1]) <= audio->frames());
+
if (part_frames[0]) {
shared_ptr<AudioBuffers> part (new AudioBuffers(audio, part_frames[0], 0));
_audio_reel->write (part);