X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Faudio_buffer.cc;h=247b4cfebb3f72499cd42645ea6c30fab47b2981;hb=84272b4e27e537bf2c38c9cd25675c61addea40a;hp=a57891a27d7c0a04c699adf7cb849ab89a688cd4;hpb=bb9cc45cd22af67ac275a5e73accbe14fee664d8;p=ardour.git diff --git a/libs/ardour/audio_buffer.cc b/libs/ardour/audio_buffer.cc index a57891a27d..247b4cfebb 100644 --- a/libs/ardour/audio_buffer.cc +++ b/libs/ardour/audio_buffer.cc @@ -22,51 +22,73 @@ #include "pbd/error.h" #include "pbd/malign.h" -#include "i18n.h" +#include "pbd/i18n.h" using namespace PBD; using namespace ARDOUR; AudioBuffer::AudioBuffer(size_t capacity) - : Buffer(DataType::AUDIO, capacity) + : Buffer (DataType::AUDIO) , _owns_data (false) , _data (0) { - if (_capacity > 0) { + if (capacity) { _owns_data = true; // prevent resize() from gagging - resize (_capacity); + resize (capacity); _silent = false; // force silence on the intial buffer state - silence (_capacity); + clear (); } } AudioBuffer::~AudioBuffer() { if (_owns_data) - free(_data); + cache_aligned_free(_data); } void AudioBuffer::resize (size_t size) { if (!_owns_data) { + /* XXX how the hell is this enforced? */ + _capacity = size; return; } - if (size < _capacity) { - _size = size; + if (_data && size < _capacity) { + /* buffer is already large enough */ return; } - if (_data) { - free (_data); - } + cache_aligned_free (_data); + + cache_aligned_malloc ((void**) &_data, sizeof (Sample) * size); _capacity = size; - _size = size; _silent = false; - - cache_aligned_malloc ((void**) &_data, sizeof (Sample) * _capacity); } +bool +AudioBuffer::check_silence (pframes_t nframes, pframes_t& n) const +{ + for (n = 0; n < nframes; ++n) { + if (_data[n] != Sample (0)) { + return false; + } + } + return true; +} +void +AudioBuffer::silence (samplecnt_t len, samplecnt_t offset) { + + if (!_silent) { + assert(_capacity > 0); + assert(offset + len <= _capacity); + memset(_data + offset, 0, sizeof (Sample) * len); + if (len == _capacity) { + _silent = true; + } + } + _written = true; +}