summaryrefslogtreecommitdiff
path: root/src/lib/audio_ring_buffers.cc
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2021-02-16 10:40:12 +0100
committerCarl Hetherington <cth@carlh.net>2021-02-16 10:40:12 +0100
commitbb949ec65adf95f4a2c7dd5ee7e97b9daaaf3d3f (patch)
tree09153b297f7cebd3f13ab58188982366185298f6 /src/lib/audio_ring_buffers.cc
parent39d51cddeeea82e602ab1925430b0dfb5752ac79 (diff)
C++11 tidying.
Diffstat (limited to 'src/lib/audio_ring_buffers.cc')
-rw-r--r--src/lib/audio_ring_buffers.cc19
1 files changed, 13 insertions, 6 deletions
diff --git a/src/lib/audio_ring_buffers.cc b/src/lib/audio_ring_buffers.cc
index 289045ff5..1a216ab33 100644
--- a/src/lib/audio_ring_buffers.cc
+++ b/src/lib/audio_ring_buffers.cc
@@ -1,5 +1,5 @@
/*
- Copyright (C) 2016-2019 Carl Hetherington <cth@carlh.net>
+ Copyright (C) 2016-2021 Carl Hetherington <cth@carlh.net>
This file is part of DCP-o-matic.
@@ -18,11 +18,13 @@
*/
+
#include "audio_ring_buffers.h"
#include "dcpomatic_assert.h"
#include "exceptions.h"
#include <iostream>
+
using std::min;
using std::cout;
using std::make_pair;
@@ -32,12 +34,13 @@ using std::shared_ptr;
using boost::optional;
using namespace dcpomatic;
+
AudioRingBuffers::AudioRingBuffers ()
- : _used_in_head (0)
{
}
+
/** @param frame_rate Frame rate in use; this is only used to check timing consistency of the incoming data */
void
AudioRingBuffers::put (shared_ptr<const AudioBuffers> data, DCPTime time, int frame_rate)
@@ -56,6 +59,7 @@ AudioRingBuffers::put (shared_ptr<const AudioBuffers> data, DCPTime time, int fr
_buffers.push_back(make_pair(data, time));
}
+
/** @return time of the returned data; if it's not set this indicates an underrun */
optional<DCPTime>
AudioRingBuffers::get (float* out, int channels, int frames)
@@ -75,7 +79,7 @@ AudioRingBuffers::get (float* out, int channels, int frames)
return time;
}
- pair<shared_ptr<const AudioBuffers>, DCPTime> front = _buffers.front ();
+ auto front = _buffers.front ();
if (!time) {
time = front.second + DCPTime::from_frames(_used_in_head, 48000);
}
@@ -103,16 +107,18 @@ AudioRingBuffers::get (float* out, int channels, int frames)
return time;
}
+
optional<DCPTime>
AudioRingBuffers::peek () const
{
boost::mutex::scoped_lock lm (_mutex);
if (_buffers.empty()) {
- return optional<DCPTime>();
+ return {};
}
return _buffers.front().second;
}
+
void
AudioRingBuffers::clear ()
{
@@ -121,13 +127,14 @@ AudioRingBuffers::clear ()
_used_in_head = 0;
}
+
Frame
AudioRingBuffers::size () const
{
boost::mutex::scoped_lock lm (_mutex);
Frame s = 0;
- for (list<pair<shared_ptr<const AudioBuffers>, DCPTime> >::const_iterator i = _buffers.begin(); i != _buffers.end(); ++i) {
- s += i->first->frames();
+ for (auto const& i: _buffers) {
+ s += i.first->frames();
}
return s - _used_in_head;
}