extern PBD::PropertyDescriptor<bool> recenable;
extern PBD::PropertyDescriptor<bool> select;
extern PBD::PropertyDescriptor<bool> edit;
+ extern PBD::PropertyDescriptor<bool> route_active;
+ extern PBD::PropertyDescriptor<bool> color;
+ extern PBD::PropertyDescriptor<bool> monitoring;
/* we use this, but its declared in region.cc */
extern PBD::PropertyDescriptor<bool> hidden;
};
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 ();
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();}
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<Route>);
int remove (boost::shared_ptr<Route>);
- void apply (void (Route::*func)(void *), void *src) {
- for (RouteList::iterator i = routes->begin(); i != routes->end(); ++i) {
- ((*i).get()->*func)(src);
- }
- }
-
- template<class T> void apply (void (Route::*func)(T, void *), T val, void *src) {
+ template<typename Function>
+ void foreach_route (Function f) {
for (RouteList::iterator i = routes->begin(); i != routes->end(); ++i) {
- ((*i).get()->*func)(val, src);
- }
- }
-
- template<class T> 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());
}
}
changed();
}
- void make_subgroup ();
+ void make_subgroup (bool, Placement);
void destroy_subgroup ();
boost::shared_ptr<RouteList> route_list() { return routes; }
- PBD::Signal0<void> changed;
- PBD::Signal1<void,void*> FlagsChanged;
+ /** Emitted when a route has been added to this group */
+ PBD::Signal2<void, RouteGroup *, boost::weak_ptr<ARDOUR::Route> > RouteAdded;
+ /** Emitted when a route has been removed from this group */
+ PBD::Signal2<void, RouteGroup *, boost::weak_ptr<ARDOUR::Route> > RouteRemoved;
XMLNode& get_state ();
-
+
int set_state (const XMLNode&, int version);
-
+
private:
boost::shared_ptr<RouteList> routes;
boost::shared_ptr<Route> subgroup_bus;
PBD::Property<bool> _recenable;
PBD::Property<bool> _select;
PBD::Property<bool> _edit;
+ PBD::Property<bool> _route_active;
+ PBD::Property<bool> _color;
+ PBD::Property<bool> _monitoring;
void remove_when_going_away (boost::weak_ptr<Route>);
int set_state_2X (const XMLNode&, int);