X-Git-Url: https://main.carlh.net/gitweb/?p=ardour.git;a=blobdiff_plain;f=libs%2Fardour%2Fardour%2Fautomatable.h;h=d2fbb1aa8d574bb6457d51bb24040ed79c6908cd;hp=1acb8a60dcd11ca6cee52d8c61f49e092aadaf32;hb=6b1b72a247bf04c81292fc41af4f69c9b7f90379;hpb=9334c99b355c7e326f5659794c88f61805aa16d0 diff --git a/libs/ardour/ardour/automatable.h b/libs/ardour/ardour/automatable.h index 1acb8a60dc..d2fbb1aa8d 100644 --- a/libs/ardour/ardour/automatable.h +++ b/libs/ardour/ardour/automatable.h @@ -26,6 +26,7 @@ #include +#include "pbd/rcu.h" #include "pbd/signals.h" #include "evoral/ControlSet.hpp" @@ -50,7 +51,9 @@ public: Automatable(Session&); Automatable (const Automatable& other); - virtual ~Automatable(); + virtual ~Automatable(); + + static bool skip_saving_automation; // to be used only by session-state boost::shared_ptr control_factory(const Evoral::Parameter& id); @@ -83,8 +86,10 @@ public: virtual bool find_next_event (double start, double end, Evoral::ControlEvent& ev, bool only_active = true) const; void clear_controls (); - virtual void transport_located (framepos_t now); - virtual void transport_stopped (framepos_t now); + virtual void non_realtime_locate (samplepos_t now); + virtual void non_realtime_transport_stop (samplepos_t now, bool flush); + + virtual void automation_run (samplepos_t, pframes_t, bool only_active = false); virtual std::string describe_parameter(Evoral::Parameter param); @@ -103,23 +108,26 @@ public: PBD::Signal0 AutomationStateChanged; - protected: +protected: Session& _a_session; void can_automate(Evoral::Parameter); - virtual void automation_list_automation_state_changed (Evoral::Parameter, AutoState) {} + virtual void automation_list_automation_state_changed (Evoral::Parameter, AutoState); + SerializedRCUManager _automated_controls; int load_automation (const std::string& path); int old_set_automation_state(const XMLNode&); std::set _can_automate_list; - framepos_t _last_automation_snapshot; + samplepos_t _last_automation_snapshot; SlavableControlList slavables () const { return SlavableControlList(); } private: + inline void find_next_ac_event (boost::shared_ptr, double start, double end, Evoral::ControlEvent& ev) const; + PBD::ScopedConnectionList _control_connections; ///< connections to our controls' signals };