use CoreSelection for track selection
[ardour.git] / gtk2_ardour / route_ui.h
index d7106142998096a911bb9105e498342dd14ca56d..7e4dd2e9688bc4669ea9a6e440461552351936de 100644 (file)
@@ -26,6 +26,7 @@
 #include "pbd/signals.h"
 
 #include <gtkmm/textview.h>
+#include <gtkmm/colorselection.h>
 
 #include "gtkmm2ext/widget_state.h"
 
@@ -40,6 +41,7 @@
 
 #include "axis_view.h"
 #include "selectable.h"
+#include "stripable_colorpicker.h"
 #include "window_manager.h"
 
 namespace ARDOUR {
@@ -56,6 +58,7 @@ namespace Gtk {
 class ArdourButton;
 class ArdourWindow;
 class IOSelectorWindow;
+class ControlSlaveUI;
 
 class RoutePinWindowProxy : public WM::ProxyBase
 {
@@ -73,13 +76,15 @@ 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 Selectable, public virtual ARDOUR::SessionHandlePtr, public virtual PBD::ScopedConnectionList, public virtual sigc::trackable
 {
   public:
        RouteUI (ARDOUR::Session*);
 
        virtual ~RouteUI();
 
+       boost::shared_ptr<ARDOUR::Stripable> stripable() const;
+
        virtual void set_route (boost::shared_ptr<ARDOUR::Route>);
        virtual void set_button_names () = 0;
 
@@ -105,8 +110,6 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual sigc::tr
        Gdk::Color route_color () const;
        void choose_color ();
 
-       void set_selected (bool);
-
        bool ignore_toggle;
        bool wait_for_release;
        bool multiple_mute_change;
@@ -122,10 +125,9 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual sigc::tr
 
        Glib::RefPtr<Gdk::Pixbuf> solo_safe_pixbuf;
 
-        ArdourButton* solo_safe_led;
-        ArdourButton* solo_isolated_led;
+       ArdourButton* solo_safe_led;
+       ArdourButton* solo_isolated_led;
 
-       ArdourButton* vca_button;
 
        Gtk::Label monitor_input_button_label;
        Gtk::Label monitor_disk_button_label;
@@ -184,8 +186,8 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual sigc::tr
        void solo_isolated_toggle (void*, Gtk::CheckMenuItem*);
        void toggle_solo_isolated (Gtk::CheckMenuItem*);
 
-        bool solo_isolate_button_release (GdkEventButton*);
-        bool solo_safe_button_release (GdkEventButton*);
+       bool solo_isolate_button_release (GdkEventButton*);
+       bool solo_safe_button_release (GdkEventButton*);
 
        void solo_safe_toggle (void*, Gtk::CheckMenuItem*);
        void toggle_solo_safe (Gtk::CheckMenuItem*);
@@ -208,6 +210,7 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual sigc::tr
 
        void manage_pins ();
        void maybe_add_route_print_mgr ();
+       void fan_out (bool to_busses = true, bool group = true);
 
        virtual void route_property_changed (const PBD::PropertyChange&) = 0;
        void route_removed ();
@@ -216,8 +219,8 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual sigc::tr
        void set_route_active (bool, bool);
        void duplicate_selected_routes ();
 
-        Gtk::Menu* record_menu;
-        void build_record_menu ();
+       Gtk::Menu* record_menu;
+       void build_record_menu ();
 
        Gtk::CheckMenuItem *step_edit_item;
        void toggle_step_edit ();
@@ -240,8 +243,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 ();
@@ -283,13 +284,13 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual sigc::tr
        void reset ();
 
        void self_delete ();
-        virtual void start_step_editing () {}
-        virtual void stop_step_editing() {}
+       virtual void start_step_editing () {}
+       virtual void stop_step_editing() {}
 
-        void set_invert_sensitive (bool);
+       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 ();
@@ -301,13 +302,13 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual sigc::tr
        bool mark_hidden (bool yn);
 
   private:
-       void parameter_changed (std::string const &);
+       void parameter_changed (std::string const&);
        void relabel_solo_button ();
        void track_mode_changed ();
 
        std::string route_state_id () const;
 
-protected:
+  protected:
        struct SoloMuteRelease {
            SoloMuteRelease (bool was_active)
            : active (was_active)
@@ -324,6 +325,8 @@ protected:
        SoloMuteRelease* _solo_release;
        SoloMuteRelease* _mute_release;
 
+       ControlSlaveUI* csu;
+
 private:
        void setup_invert_buttons ();
        void set_invert_button_state ();
@@ -335,6 +338,8 @@ private:
        std::vector<ArdourButton*> _invert_buttons;
        Gtk::Menu* _invert_menu;
 
+       StripableColorDialog _color_picker;
+
        static void set_showing_sends_to (boost::shared_ptr<ARDOUR::Route>);
        static boost::weak_ptr<ARDOUR::Route> _showing_sends_to;