fix background of ArdourButtons with no Body
[ardour.git] / gtk2_ardour / route_ui.h
index 4a17ac22bef992e22d5d0181bf9d701ed6e8fc4a..ecd4ed520d543edecc2d516d51977f4b2f0b4a61 100644 (file)
@@ -56,6 +56,7 @@ namespace Gtk {
 class ArdourButton;
 class ArdourWindow;
 class IOSelectorWindow;
+class ControlSlaveUI;
 
 class RoutePinWindowProxy : public WM::ProxyBase
 {
@@ -73,7 +74,7 @@ class RoutePinWindowProxy : public WM::ProxyBase
        PBD::ScopedConnection going_away_connection;
 };
 
-class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual sigc::trackable, public virtual PBD::ScopedConnectionList
+class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual Selectable, public virtual PBD::ScopedConnectionList
 {
   public:
        RouteUI (ARDOUR::Session*);
@@ -105,6 +106,9 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual sigc::tr
        Gdk::Color route_color () const;
        void choose_color ();
 
+       bool selected () const;
+       void set_selected (bool);
+
        bool ignore_toggle;
        bool wait_for_release;
        bool multiple_mute_change;
@@ -123,7 +127,6 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual sigc::tr
         ArdourButton* solo_safe_led;
         ArdourButton* solo_isolated_led;
 
-       ArdourButton* vca_button;
 
        Gtk::Label monitor_input_button_label;
        Gtk::Label monitor_disk_button_label;
@@ -238,8 +241,6 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual sigc::tr
 
        void update_solo_display ();
 
-       void update_vca_display ();
-
        virtual void map_frozen ();
 
        void adjust_latency ();
@@ -287,7 +288,7 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual sigc::tr
         void set_invert_sensitive (bool);
        bool verify_new_route_name (const std::string& name);
 
-       void route_gui_changed (std::string);
+       void route_gui_changed (PBD::PropertyChange const&);
        virtual void route_color_changed () {}
 
        void check_rec_enable_sensitivity ();
@@ -305,7 +306,7 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual sigc::tr
 
        std::string route_state_id () const;
 
-protected:
+  protected:
        struct SoloMuteRelease {
            SoloMuteRelease (bool was_active)
            : active (was_active)
@@ -322,6 +323,8 @@ protected:
        SoloMuteRelease* _solo_release;
        SoloMuteRelease* _mute_release;
 
+       ControlSlaveUI* csu;
+
 private:
        void setup_invert_buttons ();
        void set_invert_button_state ();