diff options
author | Julien "_FrnchFrgg_" RIVAUD <frnchfrgg@free.fr> | 2016-07-15 01:51:55 +0200 |
---|---|---|
committer | Paul Davis <paul@linuxaudiosystems.com> | 2016-07-14 21:55:49 -0400 |
commit | 9ba6e938d8f7d61bc747ed5e9a102638bb1a8eb1 (patch) | |
tree | 28e156038e560d286b26cb7840177d27452a8fc9 /libs/ardour/route.cc | |
parent | 8af589b322408aba38413dc2c85dc77ae1c9f2e4 (diff) |
Also flush buffers of the inner delivery of inserts
When flushing the buffers of Delivery processors owned by a Route/Track,
inner deliveries of PortInsert processors were missed since PortInsert
is not a Delivery subclass, but rather owns a Delivery as a private
member. Expose a flush_buffers() for PortInsert and call it too.
This is correct since (external) Send is a Delivery subclass, so that
just makes the send part of inserts behave as external sends do.
Diffstat (limited to 'libs/ardour/route.cc')
-rw-r--r-- | libs/ardour/route.cc | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/libs/ardour/route.cc b/libs/ardour/route.cc index cd670df02e..1e1be37d9f 100644 --- a/libs/ardour/route.cc +++ b/libs/ardour/route.cc @@ -3398,6 +3398,11 @@ Route::flush_processor_buffers_locked (framecnt_t nframes) boost::shared_ptr<Delivery> d = boost::dynamic_pointer_cast<Delivery> (*i); if (d) { d->flush_buffers (nframes); + } else { + boost::shared_ptr<PortInsert> p = boost::dynamic_pointer_cast<PortInsert> (*i); + if (p) { + p->flush_buffers (nframes); + } } } } |