extend strict-i/o to include route outputs.
[ardour.git] / gtk2_ardour / route_ui.h
index 245101f61627b2cb8a72bcbb2fc8b7b3767313b1..461419c8480d1b7f13ceade57554aeb753e2f8fd 100644 (file)
@@ -25,6 +25,8 @@
 #include "pbd/xml++.h"
 #include "pbd/signals.h"
 
+#include <gtkmm/textview.h>
+
 #include "gtkmm2ext/widget_state.h"
 
 #include "ardour/ardour.h"
@@ -49,8 +51,9 @@ namespace Gtk {
        class Widget;
 }
 
-class BindableToggleButton;
 class ArdourButton;
+class ArdourWindow;
+class IOSelectorWindow;
 
 class RouteUI : public virtual AxisView
 {
@@ -112,10 +115,14 @@ class RouteUI : public virtual AxisView
        void send_blink (bool);
        sigc::connection send_blink_connection;
 
+       sigc::connection rec_blink_connection;
+
        Gtk::Menu* mute_menu;
        Gtk::Menu* solo_menu;
        Gtk::Menu* sends_menu;
 
+       boost::shared_ptr<ARDOUR::Delivery> _current_delivery;
+
        bool mute_press(GdkEventButton*);
        bool mute_release(GdkEventButton*);
        bool solo_press(GdkEventButton*);
@@ -133,6 +140,9 @@ class RouteUI : public virtual AxisView
        void monitoring_changed ();
        void update_monitoring_display ();
 
+       void edit_input_configuration ();
+       void edit_output_configuration ();
+
        void step_gain_up ();
        void step_gain_down ();
        void page_gain_up ();
@@ -147,7 +157,6 @@ class RouteUI : public virtual AxisView
 
        void solo_changed(bool, void*);
        void solo_changed_so_update_mute ();
-       void mute_changed(void*);
        void listen_changed(void*);
        virtual void processors_changed (ARDOUR::RouteProcessorChange) {}
        void route_rec_enable_changed();
@@ -178,9 +187,6 @@ class RouteUI : public virtual AxisView
 
        int  set_color_from_route ();
 
-       void remove_this_route (bool apply_to_selection = false);
-       static gint idle_remove_this_route (RouteUI *);
-
        void route_rename();
 
        virtual void property_changed (const PBD::PropertyChange&);
@@ -188,6 +194,7 @@ class RouteUI : public virtual AxisView
 
        virtual void route_active_changed () {}
        void set_route_active (bool, bool);
+       void duplicate_selected_routes ();
 
         Gtk::Menu* record_menu;
         void build_record_menu ();
@@ -205,7 +212,7 @@ class RouteUI : public virtual AxisView
        void disconnect_input ();
        void disconnect_output ();
 
-       virtual void update_rec_display ();
+       virtual void blink_rec_display (bool onoff);
        void update_mute_display ();
 
        void update_solo_display ();
@@ -213,6 +220,7 @@ class RouteUI : public virtual AxisView
        virtual void map_frozen ();
 
        void adjust_latency ();
+       bool process_save_template_prompter (ArdourPrompter& prompter, const std::string& dir);
        void save_as_template ();
        void open_remote_control_id_dialog ();
 
@@ -227,7 +235,23 @@ class RouteUI : public virtual AxisView
         */
        static PBD::Signal1<void, boost::shared_ptr<ARDOUR::Route> > BusSendDisplayChanged;
 
+       void comment_editor_done_editing ();
+       void setup_comment_editor ();
+       void open_comment_editor ();
+       void toggle_comment_editor ();
+
+       gint comment_key_release_handler (GdkEventKey*);
+       void comment_changed ();
+       void comment_edited ();
+       bool ignore_comment_edit;
+
    protected:
+
+       ArdourWindow*  comment_window;
+       Gtk::TextView* comment_area;
+       IOSelectorWindow *input_selector;
+       IOSelectorWindow *output_selector;
+
        PBD::ScopedConnectionList route_connections;
        bool self_destruct;
 
@@ -246,10 +270,13 @@ class RouteUI : public virtual AxisView
 
        virtual void bus_send_display_changed (boost::shared_ptr<ARDOUR::Route>);
 
+       static std::string program_port_prefix;
+
   private:
        void check_rec_enable_sensitivity ();
        void parameter_changed (std::string const &);
        void relabel_solo_button ();
+       void track_mode_changed ();
 
        std::string route_state_id () const;
 
@@ -281,7 +308,7 @@ class RouteUI : public virtual AxisView
 
        static void set_showing_sends_to (boost::shared_ptr<ARDOUR::Route>);
        static boost::weak_ptr<ARDOUR::Route> _showing_sends_to;
-       
+
        static uint32_t _max_invert_buttons;
 };