bool operator!= (const AutomationList &) const;
- XMLNode* before () { return _before; }
+ XMLNode* before () { XMLNode* rv = _before; _before = 0; return rv; }
void clear_history ();
private:
void create_curve_if_necessary ();
AutomationList::~AutomationList()
{
+ delete _before;
}
boost::shared_ptr<Evoral::ControlList>
{
if (s != _state) {
_state = s;
+ delete _before;
if (s == Write && _desc.toggled) {
_before = &get_state ();
+ } else {
+ _before = 0;
}
automation_state_changed (s); /* EMIT SIGNAL */
}
void
AutomationList::start_write_pass (double when)
{
+ delete _before;
if (in_new_write_pass ()) {
_before = &get_state ();
+ } else {
+ _before = 0;
}
ControlList::start_write_pass (when);
}
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;
}
void
/* _before may be owned by the undo stack,
* so we have to be careful about doing this.
-*/
+ *
+ * ::before () transfers ownership, setting _before to 0
+ */
void
AutomationList::clear_history ()
{