Optimize automation-event process splitting
[ardour.git] / gtk2_ardour / route_ui.h
index ecd4ed520d543edecc2d516d51977f4b2f0b4a61..bac608eed43dcf217f522e0dac2c75247a9997a3 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 {
@@ -53,34 +55,42 @@ namespace Gtk {
        class Widget;
 }
 
-class ArdourButton;
+namespace ArdourWidgets {
+       class ArdourButton;
+       class Prompter;
+}
+
 class ArdourWindow;
 class IOSelectorWindow;
 class ControlSlaveUI;
+class PatchChangeGridDialog;
+class SaveTemplateDialog;
 
 class RoutePinWindowProxy : public WM::ProxyBase
 {
-  public:
+public:
        RoutePinWindowProxy (std::string const &, boost::shared_ptr<ARDOUR::Route>);
        ~RoutePinWindowProxy();
 
        Gtk::Window* get (bool create = false);
        ARDOUR::SessionHandlePtr* session_handle();
 
-  private:
+private:
        boost::weak_ptr<ARDOUR::Route> _route;
 
        void route_going_away ();
        PBD::ScopedConnection going_away_connection;
 };
 
-class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual Selectable, public virtual PBD::ScopedConnectionList
+class RouteUI : public virtual Selectable, public virtual ARDOUR::SessionHandlePtr, public virtual PBD::ScopedConnectionList, public virtual sigc::trackable
 {
-  public:
+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;
 
@@ -100,14 +110,11 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual Selectab
 
        boost::shared_ptr<ARDOUR::Route> _route;
 
-       void request_redraw ();
-
        virtual void set_color (uint32_t c);
        Gdk::Color route_color () const;
        void choose_color ();
 
-       bool selected () const;
-       void set_selected (bool);
+       void select_midi_patch ();
 
        bool ignore_toggle;
        bool wait_for_release;
@@ -115,17 +122,17 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual Selectab
        bool multiple_solo_change;
 
        Gtk::HBox _invert_button_box;
-       ArdourButton* mute_button;
-       ArdourButton* solo_button;
-       ArdourButton* rec_enable_button; /* audio tracks */
-       ArdourButton* show_sends_button; /* busses */
-       ArdourButton* monitor_input_button;
-       ArdourButton* monitor_disk_button;
+       ArdourWidgets::ArdourButton* mute_button;
+       ArdourWidgets::ArdourButton* solo_button;
+       ArdourWidgets::ArdourButton* rec_enable_button; /* audio tracks */
+       ArdourWidgets::ArdourButton* show_sends_button; /* busses */
+       ArdourWidgets::ArdourButton* monitor_input_button;
+       ArdourWidgets::ArdourButton* monitor_disk_button;
 
        Glib::RefPtr<Gdk::Pixbuf> solo_safe_pixbuf;
 
-        ArdourButton* solo_safe_led;
-        ArdourButton* solo_isolated_led;
+       ArdourWidgets::ArdourButton* solo_safe_led;
+       ArdourWidgets::ArdourButton* solo_isolated_led;
 
 
        Gtk::Label monitor_input_button_label;
@@ -161,11 +168,6 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual Selectab
        void edit_input_configuration ();
        void edit_output_configuration ();
 
-       void step_gain_up ();
-       void step_gain_down ();
-       void page_gain_up ();
-       void page_gain_down ();
-
        void build_sends_menu ();
        void set_sends_gain_from_track ();
        void set_sends_gain_to_zero ();
@@ -185,8 +187,8 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual Selectab
        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*);
@@ -209,6 +211,7 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual Selectab
 
        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 ();
@@ -217,8 +220,8 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual Selectab
        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 ();
@@ -244,7 +247,7 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual Selectab
        virtual void map_frozen ();
 
        void adjust_latency ();
-       bool process_save_template_prompter (ArdourPrompter& prompter, const std::string& dir);
+       void save_as_template_dialog_response (int response, SaveTemplateDialog* d);
        void save_as_template ();
 
        static Gtkmm2ext::ActiveState solo_active_state (boost::shared_ptr<ARDOUR::Stripable>);
@@ -268,7 +271,9 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual Selectab
        void comment_edited ();
        bool ignore_comment_edit;
 
-   protected:
+       void set_disk_io_point (ARDOUR::DiskIOPoint);
+
+protected:
 
        ArdourWindow*  comment_window;
        Gtk::TextView* comment_area;
@@ -282,10 +287,10 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual Selectab
        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 (PBD::PropertyChange const&);
@@ -299,25 +304,29 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual Selectab
 
        bool mark_hidden (bool yn);
 
-  private:
-       void parameter_changed (std::string const &);
+       PatchChangeGridDialog* patch_change_dialog () const;
+
+private:
+       void parameter_changed (std::string const&);
        void relabel_solo_button ();
        void track_mode_changed ();
+       void delete_patch_change_dialog ();
 
        std::string route_state_id () const;
 
-  protected:
+protected:
        struct SoloMuteRelease {
-           SoloMuteRelease (bool was_active)
-           : active (was_active)
-           , exclusive (false) {}
-
-           boost::shared_ptr<ARDOUR::RouteList> routes;
-           boost::shared_ptr<ARDOUR::RouteList> routes_on;
-           boost::shared_ptr<ARDOUR::RouteList> routes_off;
-           boost::shared_ptr<ARDOUR::Route> route;
-           bool active;
-           bool exclusive;
+               SoloMuteRelease (bool was_active)
+                       : active (was_active)
+                       , exclusive (false)
+               {}
+
+               boost::shared_ptr<ARDOUR::RouteList> routes;
+               boost::shared_ptr<ARDOUR::RouteList> routes_on;
+               boost::shared_ptr<ARDOUR::RouteList> routes_off;
+               boost::shared_ptr<ARDOUR::Route> route;
+               bool active;
+               bool exclusive;
        };
 
        SoloMuteRelease* _solo_release;
@@ -333,9 +342,11 @@ private:
        bool invert_release (GdkEventButton *, uint32_t i);
 
        int _i_am_the_modifier;
-       std::vector<ArdourButton*> _invert_buttons;
+       std::vector<ArdourWidgets::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;