X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fardour%2Fautomatable.h;h=c7db1c7a218021f94c92b66dd85f470fecbec614;hb=6bd583803ea1daf19a1c088766122b5cdf340171;hp=dc86c0cdddc5298f9924d08eedc6b4b2e71a2465;hpb=106024330230fca331e2f611fec42ec1f4f43e5a;p=ardour.git diff --git a/libs/ardour/ardour/automatable.h b/libs/ardour/ardour/automatable.h index dc86c0cddd..c7db1c7a21 100644 --- a/libs/ardour/ardour/automatable.h +++ b/libs/ardour/ardour/automatable.h @@ -23,9 +23,15 @@ #include #include #include + #include + #include "pbd/signals.h" + #include "evoral/ControlSet.hpp" + +#include "ardour/libardour_visibility.h" +#include "ardour/slavable.h" #include "ardour/types.h" class XMLNode; @@ -35,66 +41,73 @@ namespace ARDOUR { class Session; class AutomationControl; - -/** Note this class is abstract, actual objects must either be - * an AutomatableControls or an AutomatableSequence +/* The inherited ControlSet is virtual because AutomatableSequence inherits + * from this AND EvoralSequence, which is also a ControlSet */ -class Automatable : virtual public Evoral::ControlSet +class LIBARDOUR_API Automatable : virtual public Evoral::ControlSet, public Slavable { public: Automatable(Session&); Automatable (const Automatable& other); - virtual ~Automatable() {} + virtual ~Automatable(); - boost::shared_ptr - control_factory(const Evoral::Parameter& id); + static bool skip_saving_automation; // to be used only by session-state - boost::shared_ptr - automation_control (const Evoral::Parameter& id, bool create_if_missing=false); + boost::shared_ptr control_factory(const Evoral::Parameter& id); - boost::shared_ptr - automation_control (const Evoral::Parameter& id) const; + boost::shared_ptr automation_control (PBD::ID const & id) const; + /* derived classes need to provide some way to search their own child + automatable's for a control. normally, we'd just make the method + above virtual, and let them override it. But that wouldn't + differentiate the "check children" and "just your own" cases. + + We could theoretically just overload the above method with an extra + "bool recurse = default", but the rules of name hiding for C++ mean + that making a method virtual will hide other overloaded versions of + the same name. This means that virtual automation_control (PBD::ID + const &) would hide automation_control (Evoral::Parameter const & + id). + + So, skip around all that with a different name. + */ + virtual boost::shared_ptr automation_control_recurse (PBD::ID const & id) const { + return automation_control (id); + } + + boost::shared_ptr automation_control (const Evoral::Parameter& id) { + return automation_control (id, false); + } + boost::shared_ptr automation_control (const Evoral::Parameter& id, bool create_if_missing); + boost::shared_ptr automation_control (const Evoral::Parameter& id) const; virtual void add_control(boost::shared_ptr); + virtual bool find_next_event (double start, double end, Evoral::ControlEvent& ev, bool only_active = true) const; void clear_controls (); - virtual void automation_snapshot (framepos_t now, bool force); - 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); virtual std::string describe_parameter(Evoral::Parameter param); - virtual std::string value_as_string (boost::shared_ptr) const; AutoState get_parameter_automation_state (Evoral::Parameter param); virtual void set_parameter_automation_state (Evoral::Parameter param, AutoState); - AutoStyle get_parameter_automation_style (Evoral::Parameter param); - void set_parameter_automation_style (Evoral::Parameter param, AutoStyle); - void protect_automation (); const std::set& what_can_be_automated() const { return _can_automate_list; } void what_has_existing_automation (std::set&) const; - inline bool should_snapshot (framepos_t now) { - return (_last_automation_snapshot > now - || (now - _last_automation_snapshot) > _automation_interval); - } - - static void set_automation_interval (framecnt_t frames) { - _automation_interval = frames; - } - - static framecnt_t automation_interval() { - return _automation_interval; - } - static const std::string xml_node_name; int set_automation_xml_state (const XMLNode&, Evoral::Parameter default_param); XMLNode& get_automation_xml_state(); - protected: + PBD::Signal0 AutomationStateChanged; + +protected: Session& _a_session; void can_automate(Evoral::Parameter); @@ -106,8 +119,9 @@ public: std::set _can_automate_list; - framepos_t _last_automation_snapshot; - static framecnt_t _automation_interval; + samplepos_t _last_automation_snapshot; + + SlavableControlList slavables () const { return SlavableControlList(); } private: PBD::ScopedConnectionList _control_connections; ///< connections to our controls' signals