X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fardour%2Froute_group.h;h=890bf8af40aa8ba0a98889c16c82d974841f732b;hb=33c61757fc8352fdb1280bca28b54d1adee183ff;hp=c7616a746e6784b8e9c7106d785109c13bd0434d;hpb=b68256a8ff670d0f9206858daa69e1bdf7810684;p=ardour.git diff --git a/libs/ardour/ardour/route_group.h b/libs/ardour/ardour/route_group.h index c7616a746e..890bf8af40 100644 --- a/libs/ardour/ardour/route_group.h +++ b/libs/ardour/ardour/route_group.h @@ -43,6 +43,9 @@ namespace Properties { extern PBD::PropertyDescriptor recenable; extern PBD::PropertyDescriptor select; extern PBD::PropertyDescriptor edit; + extern PBD::PropertyDescriptor route_active; + extern PBD::PropertyDescriptor color; + extern PBD::PropertyDescriptor monitoring; /* we use this, but its declared in region.cc */ extern PBD::PropertyDescriptor hidden; }; @@ -52,11 +55,11 @@ class Track; class AudioTrack; class Session; -class RouteGroup : public SessionObject +class RouteGroup : public SessionObject { public: static void make_property_quarks(); - + RouteGroup (Session& s, const std::string &n); ~RouteGroup (); @@ -69,6 +72,9 @@ class RouteGroup : public SessionObject 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();} @@ -86,27 +92,19 @@ class RouteGroup : public SessionObject 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) { + template + void foreach_route (Function f) { 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); + f (i->get()); } } @@ -123,18 +121,20 @@ class RouteGroup : public SessionObject changed(); } - void make_subgroup (); + void make_subgroup (bool, Placement); void destroy_subgroup (); boost::shared_ptr route_list() { return routes; } - /** Emitted when a route has been added to or removed from this group */ - PBD::Signal0 MembershipChanged; + /** 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: boost::shared_ptr routes; boost::shared_ptr subgroup_bus; @@ -148,6 +148,9 @@ private: PBD::Property _recenable; PBD::Property _select; PBD::Property _edit; + PBD::Property _route_active; + PBD::Property _color; + PBD::Property _monitoring; void remove_when_going_away (boost::weak_ptr); int set_state_2X (const XMLNode&, int);