Set the revision mechanism independent from the VCS name
[ardour.git] / libs / ardour / ardour / route_group.h
index 1f6be864cdd3e90b560468e5426ed2fab7ff4943..2f62193d83843cbdd79a500b91310b434dee20c4 100644 (file)
@@ -42,9 +42,9 @@ namespace Properties {
        extern PBD::PropertyDescriptor<bool> solo;
        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;
 };
@@ -70,9 +70,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();}
@@ -89,9 +89,9 @@ 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);
 
@@ -118,13 +118,16 @@ class RouteGroup : public SessionObject
                changed();
        }
 
+        bool has_subgroup() const;
        void make_subgroup (bool, Placement);
        void destroy_subgroup ();
 
        boost::shared_ptr<RouteList> route_list() { return routes; }
 
-       /** Emitted when a route has been added to or removed from this group */
-       PBD::Signal0<void> MembershipChanged;
+       /** 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 ();
 
@@ -142,9 +145,9 @@ private:
        PBD::Property<bool> _solo;
        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);