const ParameterDescriptor& desc() const { return _desc; }
const ARDOUR::Session& session() const { return _session; }
- void commit_transaction ();
+ void commit_transaction (bool did_write);
protected:
bool operator!= (const AutomationList &) const;
XMLNode* before () { return _before; }
+ void clear_history ();
private:
void create_curve_if_necessary ();
int deserialize_events (const XMLNode&);
l->stop_touch (true, now);
- if (list_did_write) {
- c->commit_transaction ();
- }
+ c->commit_transaction (list_did_write);
l->write_pass_finished (now, Config->get_automation_thinning_factor ());
}
void
-AutomationControl::commit_transaction ()
+AutomationControl::commit_transaction (bool did_write)
{
- if (alist ()->before ()) {
- _session.begin_reversible_command (string_compose (_("record %1 automation"), name ()));
- _session.commit_reversible_command (new MementoCommand<AutomationList> (*alist ().get (), alist ()->before (), &alist ()->get_state ()));
+ if (did_write) {
+ if (alist ()->before ()) {
+ _session.begin_reversible_command (string_compose (_("record %1 automation"), name ()));
+ _session.commit_reversible_command (new MementoCommand<AutomationList> (*alist ().get (), alist ()->before (), &alist ()->get_state ()));
+ }
+ } else {
+ alist ()->clear_history ();
}
}
{
if (s != _state) {
_state = s;
- if (s == Write) {
- _before = &get_state ();
- }
automation_state_changed (s); /* EMIT SIGNAL */
}
}
AutomationList::write_pass_finished (double when, double thinning_factor)
{
ControlList::write_pass_finished (when, thinning_factor);
+ /* automation control has deleted this or it is now owned by the session undo stack */
_before = 0;
}
}
}
+/* _before may be owned by the undo stack,
+ * so we have to be careful about doing this.
+*/
+void
+AutomationList::clear_history ()
+{
+ delete _before;
+ _before = 0;
+}
+
void
AutomationList::thaw ()
{