summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRobin Gareus <robin@gareus.org>2017-07-27 01:40:13 +0200
committerRobin Gareus <robin@gareus.org>2017-07-27 01:40:13 +0200
commit3899c06fae96c09a04a2bc63a414a1fcfa847557 (patch)
tree1e739e36a5f9662e7e9e66e21a33e0d4756d2a3d
parent97e31684668424fd04faa0f6c48e491ee6aff00e (diff)
Start a new write-pass when writing automation and locating while rolling
-rw-r--r--libs/ardour/automatable.cc32
1 files changed, 30 insertions, 2 deletions
diff --git a/libs/ardour/automatable.cc b/libs/ardour/automatable.cc
index a8f755da5e..3dad4ccd31 100644
--- a/libs/ardour/automatable.cc
+++ b/libs/ardour/automatable.cc
@@ -340,6 +340,8 @@ Automatable::protect_automation ()
void
Automatable::non_realtime_locate (framepos_t now)
{
+ bool rolling = _a_session.transport_rolling ();
+
for (Controls::iterator li = controls().begin(); li != controls().end(); ++li) {
boost::shared_ptr<AutomationControl> c
@@ -348,8 +350,34 @@ Automatable::non_realtime_locate (framepos_t now)
boost::shared_ptr<AutomationList> l
= boost::dynamic_pointer_cast<AutomationList>(c->list());
- if (l) {
- l->start_write_pass (now);
+ if (!l) {
+ continue;
+ }
+
+ bool am_touching = c->touching ();
+ if (rolling && am_touching) {
+ /* when locating while rolling, and writing automation,
+ * start a new write pass.
+ * compare to compare to non_realtime_transport_stop()
+ */
+ const bool list_did_write = !l->in_new_write_pass ();
+ c->stop_touch (-1); // time is irrelevant
+ l->stop_touch (-1);
+ c->commit_transaction (list_did_write);
+ l->write_pass_finished (now, Config->get_automation_thinning_factor ());
+
+ if (l->automation_state () == Write) {
+ l->set_automation_state (Touch);
+ }
+ if (l->automation_playback ()) {
+ c->set_value_unchecked (c->list ()->eval (now));
+ }
+ }
+
+ l->start_write_pass (now);
+
+ if (rolling && am_touching) {
+ c->start_touch (now);
}
}
}