X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fcapturing_processor.cc;h=b94288325068575eb346d8c9e17f0656de8ca2e2;hb=cf8cc1944928132c99e382918b3c7c03b2298b80;hp=f14e01809765af1045ff9fa4a2123385fc421b50;hpb=9ac6bb9befa047a6c349bed02d40da84600b67cc;p=ardour.git diff --git a/libs/ardour/capturing_processor.cc b/libs/ardour/capturing_processor.cc index f14e018097..b942883250 100644 --- a/libs/ardour/capturing_processor.cc +++ b/libs/ardour/capturing_processor.cc @@ -22,13 +22,14 @@ #include "ardour/session.h" #include "ardour/audioengine.h" -#include "i18n.h" +#include "pbd/i18n.h" namespace ARDOUR { -CapturingProcessor::CapturingProcessor (Session & session) +CapturingProcessor::CapturingProcessor (Session & session, framecnt_t latency) : Processor (session, X_("capture point")) , block_size (AudioEngine::instance()->samples_per_cycle()) + , _latency (latency) { realloc_buffers (); } @@ -46,10 +47,16 @@ CapturingProcessor::set_block_size (pframes_t nframes) } void -CapturingProcessor::run (BufferSet& bufs, framepos_t, framepos_t, pframes_t nframes, bool) +CapturingProcessor::run (BufferSet& bufs, framepos_t, framepos_t, double, pframes_t nframes, bool) { - if (active()) { - capture_buffers.read_from (bufs, nframes); + if (!active()) { + _delaybuffers.flush (); + return; + } + for (DataType::iterator t = DataType::begin(); t != DataType::end(); ++t) { + for (uint32_t b = 0; b < bufs.count().get (*t); ++b) { + _delaybuffers.delay (*t, b, capture_buffers.get (*t, b), bufs.get (*t, b), nframes, 0, 0); + } } } @@ -57,12 +64,13 @@ bool CapturingProcessor::configure_io (ChanCount in, ChanCount out) { Processor::configure_io (in, out); + _delaybuffers.set (out, _latency); realloc_buffers(); return true; } bool -CapturingProcessor::can_support_io_configuration (const ChanCount& in, ChanCount& out) const +CapturingProcessor::can_support_io_configuration (const ChanCount& in, ChanCount& out) { out = in; return true; @@ -72,6 +80,7 @@ void CapturingProcessor::realloc_buffers() { capture_buffers.ensure_buffers (_configured_input, block_size); + _delaybuffers.flush (); } XMLNode &