canvas HSV color serialization needs LocaleGuard
[ardour.git] / gtk2_ardour / route_ui.h
index f9f48855b50a20364768eb95b66cf176f77f4bc3..e05db7f67708f4f7b633f91b4e4a368af1225425 100644 (file)
@@ -31,8 +31,9 @@
 
 #include "ardour/ardour.h"
 #include "ardour/mute_master.h"
-#include "ardour/session_event.h"
 #include "ardour/session.h"
+#include "ardour/session_event.h"
+#include "ardour/session_handle.h"
 #include "ardour/route.h"
 #include "ardour/route_group.h"
 #include "ardour/track.h"
@@ -55,6 +56,7 @@ namespace Gtk {
 class ArdourButton;
 class ArdourWindow;
 class IOSelectorWindow;
+class ControlSlaveUI;
 
 class RoutePinWindowProxy : public WM::ProxyBase
 {
@@ -72,15 +74,14 @@ class RoutePinWindowProxy : public WM::ProxyBase
        PBD::ScopedConnection going_away_connection;
 };
 
-class RouteUI : public virtual AxisView
+class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual PBD::ScopedConnectionList, public virtual Selectable, public virtual sigc::trackable
 {
   public:
-       RouteUI(ARDOUR::Session*);
-       RouteUI(boost::shared_ptr<ARDOUR::Route>, ARDOUR::Session*);
+       RouteUI (ARDOUR::Session*);
 
        virtual ~RouteUI();
 
-       Gdk::Color color () const;
+       boost::shared_ptr<ARDOUR::Stripable> stripable() const;
 
        virtual void set_route (boost::shared_ptr<ARDOUR::Route>);
        virtual void set_button_names () = 0;
@@ -97,15 +98,14 @@ class RouteUI : public virtual AxisView
        boost::shared_ptr<ARDOUR::AudioTrack> audio_track() const;
        boost::shared_ptr<ARDOUR::MidiTrack>  midi_track() const;
 
-       std::string name() const;
-
        // protected: XXX sigh this should be here
 
        boost::shared_ptr<ARDOUR::Route> _route;
 
        void request_redraw ();
 
-       virtual void set_color (const Gdk::Color & c);
+       virtual void set_color (uint32_t c);
+       Gdk::Color route_color () const;
        void choose_color ();
 
        bool ignore_toggle;
@@ -126,7 +126,6 @@ class RouteUI : public virtual AxisView
         ArdourButton* solo_safe_led;
         ArdourButton* solo_isolated_led;
 
-       std::vector<ArdourButton*> vca_buttons;
 
        Gtk::Label monitor_input_button_label;
        Gtk::Label monitor_disk_button_label;
@@ -156,7 +155,6 @@ class RouteUI : public virtual AxisView
        bool monitor_input_release(GdkEventButton*);
        bool monitor_disk_press(GdkEventButton*);
        bool monitor_disk_release(GdkEventButton*);
-       void monitoring_changed ();
        void update_monitoring_display ();
 
        void edit_input_configuration ();
@@ -211,7 +209,7 @@ class RouteUI : public virtual AxisView
        void manage_pins ();
        void maybe_add_route_print_mgr ();
 
-       virtual void property_changed (const PBD::PropertyChange&);
+       virtual void route_property_changed (const PBD::PropertyChange&) = 0;
        void route_removed ();
 
        virtual void route_active_changed () {}
@@ -247,12 +245,11 @@ class RouteUI : public virtual AxisView
        void adjust_latency ();
        bool process_save_template_prompter (ArdourPrompter& prompter, const std::string& dir);
        void save_as_template ();
-       void open_remote_control_id_dialog ();
 
-       static Gtkmm2ext::ActiveState solo_active_state (boost::shared_ptr<ARDOUR::Route>);
-       static Gtkmm2ext::ActiveState solo_isolate_active_state (boost::shared_ptr<ARDOUR::Route>);
-       static Gtkmm2ext::ActiveState solo_safe_active_state (boost::shared_ptr<ARDOUR::Route>);
-       static Gtkmm2ext::ActiveState mute_active_state (ARDOUR::Session*, boost::shared_ptr<ARDOUR::Route>);
+       static Gtkmm2ext::ActiveState solo_active_state (boost::shared_ptr<ARDOUR::Stripable>);
+       static Gtkmm2ext::ActiveState solo_isolate_active_state (boost::shared_ptr<ARDOUR::Stripable>);
+       static Gtkmm2ext::ActiveState solo_safe_active_state (boost::shared_ptr<ARDOUR::Stripable>);
+       static Gtkmm2ext::ActiveState mute_active_state (ARDOUR::Session*, boost::shared_ptr<ARDOUR::Stripable>);
 
        /** Emitted when a bus has been set or unset from `display sends to this bus' mode
         *  by a click on the `Sends' button.  The parameter is the route that the sends are
@@ -290,7 +287,7 @@ class RouteUI : public virtual AxisView
         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 ();
@@ -299,6 +296,8 @@ class RouteUI : public virtual AxisView
 
        static std::string program_port_prefix;
 
+       bool mark_hidden (bool yn);
+
   private:
        void parameter_changed (std::string const &);
        void relabel_solo_button ();
@@ -306,7 +305,7 @@ class RouteUI : public virtual AxisView
 
        std::string route_state_id () const;
 
-protected:
+  protected:
        struct SoloMuteRelease {
            SoloMuteRelease (bool was_active)
            : active (was_active)
@@ -323,6 +322,8 @@ protected:
        SoloMuteRelease* _solo_release;
        SoloMuteRelease* _mute_release;
 
+       ControlSlaveUI* csu;
+
 private:
        void setup_invert_buttons ();
        void set_invert_button_state ();