summaryrefslogtreecommitdiff
path: root/libs/ardour/capturing_processor.cc
diff options
context:
space:
mode:
authorRobin Gareus <robin@gareus.org>2016-07-10 02:40:24 +0200
committerRobin Gareus <robin@gareus.org>2016-07-10 03:21:29 +0200
commit0a52b325f4e1eaf39be65a24f9a594ffe1f66e79 (patch)
tree7240941a5b0ab516a8f4f41156335e35f3aac23e /libs/ardour/capturing_processor.cc
parent7c13a165891bd22a958a743489c6138efa103b54 (diff)
align stem-export (raw track outputs (with and w/p processing)
Diffstat (limited to 'libs/ardour/capturing_processor.cc')
-rw-r--r--libs/ardour/capturing_processor.cc15
1 files changed, 12 insertions, 3 deletions
diff --git a/libs/ardour/capturing_processor.cc b/libs/ardour/capturing_processor.cc
index 755a00c4c4..8951bee487 100644
--- a/libs/ardour/capturing_processor.cc
+++ b/libs/ardour/capturing_processor.cc
@@ -26,9 +26,10 @@
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 ();
}
@@ -48,8 +49,14 @@ CapturingProcessor::set_block_size (pframes_t nframes)
void
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,6 +64,7 @@ bool
CapturingProcessor::configure_io (ChanCount in, ChanCount out)
{
Processor::configure_io (in, out);
+ _delaybuffers.set (out, _latency);
realloc_buffers();
return true;
}
@@ -72,6 +80,7 @@ void
CapturingProcessor::realloc_buffers()
{
capture_buffers.ensure_buffers (_configured_input, block_size);
+ _delaybuffers.flush ();
}
XMLNode &