X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fardour%2Froute_group.h;h=feeac6a467cba170104ff4f87888ef191377c6cd;hb=653ae4acd639fef149314fe6f8c7a0d862afae40;hp=820295b54a46666ada86984be2415c4f8f9b1895;hpb=ce7a5e1c9fa3edf2d9cc66875505e402a0aaa6f6;p=ardour.git diff --git a/libs/ardour/ardour/route_group.h b/libs/ardour/ardour/route_group.h index 820295b54a..feeac6a467 100644 --- a/libs/ardour/ardour/route_group.h +++ b/libs/ardour/ardour/route_group.h @@ -25,26 +25,31 @@ #include #include +#include "pbd/controllable.h" #include "pbd/signals.h" #include "pbd/stateful.h" -#include "pbd/signals.h" +#include "ardour/control_group.h" #include "ardour/types.h" #include "ardour/session_object.h" +#include "ardour/libardour_visibility.h" + namespace ARDOUR { namespace Properties { - extern PBD::PropertyDescriptor relative; - extern PBD::PropertyDescriptor active; - extern PBD::PropertyDescriptor gain; - extern PBD::PropertyDescriptor mute; - extern PBD::PropertyDescriptor solo; - extern PBD::PropertyDescriptor recenable; - extern PBD::PropertyDescriptor select; - extern PBD::PropertyDescriptor edit; + LIBARDOUR_API extern PBD::PropertyDescriptor relative; + LIBARDOUR_API extern PBD::PropertyDescriptor active; + LIBARDOUR_API extern PBD::PropertyDescriptor gain; + LIBARDOUR_API extern PBD::PropertyDescriptor mute; + LIBARDOUR_API extern PBD::PropertyDescriptor solo; + LIBARDOUR_API extern PBD::PropertyDescriptor recenable; + LIBARDOUR_API extern PBD::PropertyDescriptor select; + LIBARDOUR_API extern PBD::PropertyDescriptor route_active; + LIBARDOUR_API extern PBD::PropertyDescriptor color; + LIBARDOUR_API extern PBD::PropertyDescriptor monitoring; /* we use this, but its declared in region.cc */ - extern PBD::PropertyDescriptor hidden; + LIBARDOUR_API extern PBD::PropertyDescriptor hidden; }; class Route; @@ -52,11 +57,18 @@ class Track; class AudioTrack; class Session; -class RouteGroup : public SessionObject +/** A group identifier for routes. + * + * RouteGroups permit to define properties which are shared + * among all Routes that use the given identifier. + * + * A route can at most be in one group. + */ +class LIBARDOUR_API RouteGroup : public SessionObject { public: static void make_property_quarks(); - + RouteGroup (Session& s, const std::string &n); ~RouteGroup (); @@ -68,7 +80,9 @@ class RouteGroup : public SessionObject bool is_solo () const { return _solo.val(); } bool is_recenable () const { return _recenable.val(); } bool is_select () const { return _select.val(); } - bool is_edit () const { return _edit.val(); } + bool is_route_active () const { return _route_active.val(); } + bool is_color () const { return _color.val(); } + bool is_monitoring() const { return _monitoring.val(); } bool empty() const {return routes->empty();} size_t size() const { return routes->size();} @@ -85,34 +99,25 @@ class RouteGroup : public SessionObject void set_solo (bool yn); void set_recenable (bool yn); void set_select (bool yn); - void set_edit (bool yn); + void set_route_active (bool yn); + void set_color (bool yn); + void set_monitoring (bool yn); bool enabled_property (PBD::PropertyID); int add (boost::shared_ptr); int remove (boost::shared_ptr); - void apply (void (Route::*func)(void *), void *src) { - for (RouteList::iterator i = routes->begin(); i != routes->end(); i++) { - ((*i).get()->*func)(src); - } - } - - template void apply (void (Route::*func)(T, void *), T val, void *src) { - for (RouteList::iterator i = routes->begin(); i != routes->end(); i++) { - ((*i).get()->*func)(val, src); - } - } - - template void foreach_route (T *obj, void (T::*func)(Route&)) { - for (RouteList::iterator i = routes->begin(); i != routes->end(); i++) { - (obj->*func)(**i); + template + void foreach_route (Function f) { + for (RouteList::iterator i = routes->begin(); i != routes->end(); ++i) { + f (i->get()); } } /* to use these, #include "ardour/route_group_specialized.h" */ - template void apply (void (Track::*func)(T, void *), T val, void *src); + template void apply (void (Track::*func)(T, PBD::Controllable::GroupControlDisposition), T val, PBD::Controllable::GroupControlDisposition); /* fills at_set with all members of the group that are AudioTracks */ @@ -123,22 +128,22 @@ class RouteGroup : public SessionObject changed(); } - void make_subgroup (); + bool has_subgroup() const; + void make_subgroup (bool, Placement); void destroy_subgroup (); boost::shared_ptr route_list() { return routes; } - PBD::Signal0 changed; - PBD::Signal1 FlagsChanged; - - static PBD::PropertyChange FlagsChange; - static PBD::PropertyChange PropertiesChange; + /** Emitted when a route has been added to this group */ + PBD::Signal2 > RouteAdded; + /** Emitted when a route has been removed from this group */ + PBD::Signal2 > RouteRemoved; XMLNode& get_state (); - + int set_state (const XMLNode&, int version); - -private: + + private: boost::shared_ptr routes; boost::shared_ptr subgroup_bus; @@ -150,10 +155,21 @@ private: PBD::Property _solo; PBD::Property _recenable; PBD::Property _select; - PBD::Property _edit; + PBD::Property _route_active; + PBD::Property _color; + PBD::Property _monitoring; + + boost::shared_ptr _solo_group; + boost::shared_ptr _mute_group; + boost::shared_ptr _rec_enable_group; + boost::shared_ptr _gain_group; + boost::shared_ptr _monitoring_group; void remove_when_going_away (boost::weak_ptr); int set_state_2X (const XMLNode&, int); + + void post_set (PBD::PropertyChange const &); + void push_to_groups (); }; } /* namespace */