Optimize automation-event process splitting
[ardour.git] / gtk2_ardour / route_ui.h
index 167ecf1307a1706d7acdcb737deac9cb216dca1d..bac608eed43dcf217f522e0dac2c75247a9997a3 100644 (file)
@@ -55,10 +55,16 @@ 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
 {
@@ -108,23 +114,25 @@ public:
        Gdk::Color route_color () const;
        void choose_color ();
 
+       void select_midi_patch ();
+
        bool ignore_toggle;
        bool wait_for_release;
        bool multiple_mute_change;
        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;
@@ -160,11 +168,6 @@ public:
        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 ();
@@ -244,7 +247,7 @@ public:
        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,6 +271,8 @@ public:
        void comment_edited ();
        bool ignore_comment_edit;
 
+       void set_disk_io_point (ARDOUR::DiskIOPoint);
+
 protected:
 
        ArdourWindow*  comment_window;
@@ -299,10 +304,13 @@ protected:
 
        bool mark_hidden (bool yn);
 
+       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;
 
@@ -334,7 +342,7 @@ 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;