summaryrefslogtreecommitdiff
path: root/src/lib/audio_merger.cc
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2017-04-19 09:24:59 +0100
committerCarl Hetherington <cth@carlh.net>2017-04-19 23:04:32 +0100
commit0a2fe723109c6a8fbb61ea5721b5a475e4b480d0 (patch)
tree513782d152de6976646e900b55c2665c4cd1e80e /src/lib/audio_merger.cc
parent0dc26c2ec9aba5fd5f4ca281711fb8ac5a76612b (diff)
Various fixes to seeking with audio.
Diffstat (limited to 'src/lib/audio_merger.cc')
-rw-r--r--src/lib/audio_merger.cc11
1 files changed, 11 insertions, 0 deletions
diff --git a/src/lib/audio_merger.cc b/src/lib/audio_merger.cc
index 4bed4b3a5..ecfdfdc27 100644
--- a/src/lib/audio_merger.cc
+++ b/src/lib/audio_merger.cc
@@ -64,22 +64,31 @@ AudioMerger::pull (DCPTime time)
BOOST_FOREACH (Buffer i, _buffers) {
if (i.period().to <= time) {
/* Completely within the pull period */
+ DCPOMATIC_ASSERT (i.audio->frames() > 0);
out.push_back (make_pair (i.audio, i.time));
} else if (i.time < time) {
/* Overlaps the end of the pull period */
shared_ptr<AudioBuffers> audio (new AudioBuffers (i.audio->channels(), frames(DCPTime(time - i.time))));
audio->copy_from (i.audio.get(), audio->frames(), 0, 0);
+ DCPOMATIC_ASSERT (audio->frames() > 0);
out.push_back (make_pair (audio, i.time));
i.audio->trim_start (audio->frames ());
i.time += DCPTime::from_frames(audio->frames(), _frame_rate);
+ DCPOMATIC_ASSERT (i.audio->frames() > 0);
new_buffers.push_back (i);
} else {
/* Not involved */
+ DCPOMATIC_ASSERT (i.audio->frames() > 0);
new_buffers.push_back (i);
}
}
_buffers = new_buffers;
+
+ for (list<pair<shared_ptr<AudioBuffers>, DCPTime> >::const_iterator i = out.begin(); i != out.end(); ++i) {
+ DCPOMATIC_ASSERT (i->first->frames() > 0);
+ }
+
return out;
}
@@ -88,6 +97,7 @@ void
AudioMerger::push (boost::shared_ptr<const AudioBuffers> audio, DCPTime time)
{
DCPOMATIC_ASSERT (time >= _last_pull);
+ DCPOMATIC_ASSERT (audio->frames() > 0);
DCPTimePeriod period (time, time + DCPTime::from_frames (audio->frames(), _frame_rate));
@@ -129,6 +139,7 @@ AudioMerger::push (boost::shared_ptr<const AudioBuffers> audio, DCPTime time)
if (before == _buffers.end() && after == _buffers.end()) {
/* New buffer */
+ DCPOMATIC_ASSERT (part->frames() > 0);
_buffers.push_back (Buffer (part, time, _frame_rate));
} else if (before != _buffers.end() && after == _buffers.end()) {
/* We have an existing buffer before this one; append new data to it */