new mix group interface, not yet finished and still to propagate to edit_group
[ardour.git] / libs / ardour / ardour / route_group.h
index f5c55e184fcc90300d8f61ea18e893dee35c04ab..c9f966666f14e5ba3d03b2e97db94c5e4c9ad2cc 100644 (file)
@@ -36,6 +36,7 @@ namespace ARDOUR {
 
 class Route;
 class AudioTrack;
+class Session;
 
 class RouteGroup : public Stateful, public sigc::trackable {
   public:
@@ -45,18 +46,19 @@ class RouteGroup : public Stateful, public sigc::trackable {
            Hidden = 0x4,
     };
 
-    RouteGroup(const string &n, Flag f = Flag(0)) : _name (n), _flags (f) {}
+    RouteGroup (Session& s, const string &n, Flag f = Flag(0));
 
     const string& name() { return _name; }
+    void set_name (std::string str);
 
     bool is_active () const { return _flags & Active; }
     bool is_relative () const { return _flags & Relative; }
     bool is_hidden () const { return _flags & Hidden; }
     bool empty() const {return routes.empty();}
 
-       gain_t get_max_factor(gain_t factor);
-       gain_t get_min_factor(gain_t factor);
-
+    gain_t get_max_factor(gain_t factor);
+    gain_t get_min_factor(gain_t factor);
+    
     int size() { return routes.size();}
     ARDOUR::Route * first () const { return *routes.begin();}
 
@@ -64,7 +66,6 @@ class RouteGroup : public Stateful, public sigc::trackable {
     void set_relative (bool yn, void *src);
     void set_hidden (bool yn, void *src);
 
-
     int add (Route *);
 
     int remove (Route *);
@@ -110,6 +111,7 @@ class RouteGroup : public Stateful, public sigc::trackable {
     int set_state (const XMLNode&);
 
  private:
+    Session& _session;
     list<Route *> routes;
     string _name;
     uint32_t _flags;