diff options
author | Paul Davis <paul@linuxaudiosystems.com> | 2016-04-25 11:03:08 -0400 |
---|---|---|
committer | Paul Davis <paul@linuxaudiosystems.com> | 2016-05-31 15:30:41 -0400 |
commit | 1e9b2abe730b89ff212ef61cee9e7112bf7c8f50 (patch) | |
tree | 2d666b2fab23475235b53bcc799a3ad9f5cab954 /libs/ardour/ardour/slavable.h | |
parent | 760beab7fa1b3fcccd653279ad736656793302ea (diff) |
save and restore vca assignments
Diffstat (limited to 'libs/ardour/ardour/slavable.h')
-rw-r--r-- | libs/ardour/ardour/slavable.h | 14 |
1 files changed, 11 insertions, 3 deletions
diff --git a/libs/ardour/ardour/slavable.h b/libs/ardour/ardour/slavable.h index ae53caef38..b0ef33e1b4 100644 --- a/libs/ardour/ardour/slavable.h +++ b/libs/ardour/ardour/slavable.h @@ -26,12 +26,14 @@ #include <boost/shared_ptr.hpp> +#include <pbd/signals.h> + class XMLNode; namespace ARDOUR { class VCA; -class Session; +class VCAManager; class Slavable { @@ -39,14 +41,17 @@ class Slavable Slavable (); virtual ~Slavable() {} - XMLNode& state () const; - int assign (Session& s, XMLNode const&); + XMLNode& get_state () const; + int set_state (XMLNode const&, int); void assign (boost::shared_ptr<VCA>); void unassign (boost::shared_ptr<VCA>); static std::string xml_node_name; + /* signal sent VCAManager once assignment is possible */ + static PBD::Signal1<void,VCAManager*> Assign; + protected: virtual int assign_controls (boost::shared_ptr<VCA>) = 0; virtual int unassign_controls (boost::shared_ptr<VCA>) = 0; @@ -54,6 +59,9 @@ class Slavable private: mutable Glib::Threads::RWLock master_lock; std::set<uint32_t> _masters; + PBD::ScopedConnection assign_connection; + + int do_assign (VCAManager* s); }; } // namespace ARDOUR |