Optimize automation-event process splitting
[ardour.git] / gtk2_ardour / route_ui.h
index 275366cbe6804eff3346e211271eaca43848d063..bac608eed43dcf217f522e0dac2c75247a9997a3 100644 (file)
 #include <list>
 
 #include "pbd/xml++.h"
+#include "pbd/signals.h"
+
+#include <gtkmm/textview.h>
+#include <gtkmm/colorselection.h>
+
+#include "gtkmm2ext/widget_state.h"
+
 #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"
 
 #include "axis_view.h"
+#include "selectable.h"
+#include "stripable_colorpicker.h"
+#include "window_manager.h"
 
 namespace ARDOUR {
        class AudioTrack;
@@ -44,69 +55,99 @@ namespace Gtk {
        class Widget;
 }
 
-class BindableToggleButton;
+namespace ArdourWidgets {
+       class ArdourButton;
+       class Prompter;
+}
+
+class ArdourWindow;
+class IOSelectorWindow;
+class ControlSlaveUI;
+class PatchChangeGridDialog;
+class SaveTemplateDialog;
 
-class RouteUI : public virtual AxisView
+class RoutePinWindowProxy : public WM::ProxyBase
 {
-  public:
-       RouteUI(ARDOUR::Session&);
-       RouteUI(boost::shared_ptr<ARDOUR::Route>, ARDOUR::Session&);
+public:
+       RoutePinWindowProxy (std::string const &, boost::shared_ptr<ARDOUR::Route>);
+       ~RoutePinWindowProxy();
+
+       Gtk::Window* get (bool create = false);
+       ARDOUR::SessionHandlePtr* session_handle();
+
+private:
+       boost::weak_ptr<ARDOUR::Route> _route;
+
+       void route_going_away ();
+       PBD::ScopedConnection going_away_connection;
+};
+
+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;
 
        bool is_track() const;
        bool is_audio_track() const;
        bool is_midi_track() const;
+       bool has_audio_outputs () const;
 
        boost::shared_ptr<ARDOUR::Route> route() const { return _route; }
+       ARDOUR::RouteGroup* route_group() const;
 
        boost::shared_ptr<ARDOUR::Track>      track() const;
        boost::shared_ptr<ARDOUR::AudioTrack> audio_track() const;
        boost::shared_ptr<ARDOUR::MidiTrack>  midi_track() const;
 
-       boost::shared_ptr<ARDOUR::Diskstream> get_diskstream() const;
-
-       std::string name() const;
-
        // protected: XXX sigh this should be here
 
        boost::shared_ptr<ARDOUR::Route> _route;
 
-       void set_color (const Gdk::Color & c);
-       bool choose_color ();
+       virtual void set_color (uint32_t c);
+       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;
 
-       BindableToggleButton* mute_button;
-       BindableToggleButton* solo_button;
-       BindableToggleButton* rec_enable_button; /* audio tracks */
-       BindableToggleButton* show_sends_button; /* busses */
+       Gtk::HBox _invert_button_box;
+       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;
 
-       Gtk::Label solo_button_label;
-       Gtk::Label mute_button_label;
-       Gtk::Label rec_enable_button_label;
+       ArdourWidgets::ArdourButton* solo_safe_led;
+       ArdourWidgets::ArdourButton* solo_isolated_led;
+
+
+       Gtk::Label monitor_input_button_label;
+       Gtk::Label monitor_disk_button_label;
 
        void send_blink (bool);
        sigc::connection send_blink_connection;
 
-       virtual std::string solo_button_name () const { return "SoloButton"; }
-       virtual std::string safe_solo_button_name () const { return "SafeSoloButton"; }
+       sigc::connection rec_blink_connection;
 
        Gtk::Menu* mute_menu;
        Gtk::Menu* solo_menu;
        Gtk::Menu* sends_menu;
 
-
-       XMLNode *xml_node;
-       void ensure_xml_node ();
-
-       virtual XMLNode* get_automation_child_xml_node (Evoral::Parameter param);
+       boost::shared_ptr<ARDOUR::Delivery> _current_delivery;
 
        bool mute_press(GdkEventButton*);
        bool mute_release(GdkEventButton*);
@@ -117,21 +158,25 @@ class RouteUI : public virtual AxisView
        bool show_sends_press(GdkEventButton*);
        bool show_sends_release(GdkEventButton*);
 
-       void step_gain_up ();
-       void step_gain_down ();
-       void page_gain_up ();
-       void page_gain_down ();
+       bool monitor_release(GdkEventButton*, ARDOUR::MonitorChoice);
+       bool monitor_input_press(GdkEventButton*);
+       bool monitor_input_release(GdkEventButton*);
+       bool monitor_disk_press(GdkEventButton*);
+       bool monitor_disk_release(GdkEventButton*);
+       void update_monitoring_display ();
+
+       void edit_input_configuration ();
+       void edit_output_configuration ();
 
        void build_sends_menu ();
        void set_sends_gain_from_track ();
        void set_sends_gain_to_zero ();
        void set_sends_gain_to_unity ();
-       void create_sends (ARDOUR::Placement);
-       void create_selected_sends (ARDOUR::Placement);
+       void create_sends (ARDOUR::Placement, bool);
+       void create_selected_sends (ARDOUR::Placement, bool);
 
-       void solo_changed(void*);
+       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();
@@ -142,6 +187,9 @@ class RouteUI : public virtual AxisView
        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*);
+
        void solo_safe_toggle (void*, Gtk::CheckMenuItem*);
        void toggle_solo_safe (Gtk::CheckMenuItem*);
 
@@ -149,32 +197,39 @@ class RouteUI : public virtual AxisView
        Gtk::CheckMenuItem* post_fader_mute_check;
        Gtk::CheckMenuItem* listen_mute_check;
        Gtk::CheckMenuItem* main_mute_check;
+       Gtk::CheckMenuItem* solo_safe_check;
+       Gtk::CheckMenuItem* solo_isolated_check;
 
        void toggle_mute_menu(ARDOUR::MuteMaster::MutePoint, Gtk::CheckMenuItem*);
        void muting_change ();
        void build_mute_menu(void);
        void init_mute_menu(ARDOUR::MuteMaster::MutePoint, Gtk::CheckMenuItem*);
 
-       void set_route_group_solo (boost::shared_ptr<ARDOUR::Route>, bool);
-       void set_route_group_mute (boost::shared_ptr<ARDOUR::Route>, bool);
-       void set_route_group_rec_enable (boost::shared_ptr<ARDOUR::Route>, bool);
-
        int  set_color_from_route ();
 
-       void remove_this_route ();
-       static gint idle_remove_this_route (RouteUI *);
-
        void route_rename();
 
-       virtual void name_changed ();
+       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 ();
 
-       Gtk::CheckMenuItem *route_active_menu_item;
-       void toggle_route_active ();
-       virtual void route_active_changed ();
+       virtual void route_active_changed () {}
+       void set_route_active (bool, bool);
+       void duplicate_selected_routes ();
+
+       Gtk::Menu* record_menu;
+       void build_record_menu ();
+
+       Gtk::CheckMenuItem *step_edit_item;
+       void toggle_step_edit ();
+       virtual void step_edit_changed (bool);
+
+       Gtk::CheckMenuItem *rec_safe_item;
+       void toggle_rec_safe ();
 
-       Gtk::CheckMenuItem *polarity_menu_item;
-       void toggle_polarity ();
        virtual void polarity_changed ();
 
        Gtk::CheckMenuItem *denormal_menu_item;
@@ -184,39 +239,118 @@ 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 ();
 
        virtual void map_frozen ();
 
-       void reversibly_apply_route_boolean (std::string name, void (ARDOUR::Route::*func)(bool, void*), bool, void *);
-       void reversibly_apply_track_boolean (std::string name, void (ARDOUR::Track::*func)(bool, void*), bool, void *);
-
        void adjust_latency ();
+       void save_as_template_dialog_response (int response, SaveTemplateDialog* d);
        void save_as_template ();
-       void open_remote_control_id_dialog ();
 
-       static int solo_visual_state (boost::shared_ptr<ARDOUR::Route>);
-       static int mute_visual_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
+        *  to, or 0 if no route is now in this mode.
+        */
+       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:
-       std::vector<sigc::connection> connections;
+       void set_disk_io_point (ARDOUR::DiskIOPoint);
+
+protected:
+
+       ArdourWindow*  comment_window;
+       Gtk::TextView* comment_area;
+       IOSelectorWindow *input_selector;
+       IOSelectorWindow *output_selector;
+
+       PBD::ScopedConnectionList route_connections;
        bool self_destruct;
 
-       void init ();
-       void reset ();
+       void init ();
+       void reset ();
 
-       void queue_route_group_op (ARDOUR::RouteGroup::Property prop, void (ARDOUR::Session::*session_method)(boost::shared_ptr<ARDOUR::RouteList>, bool), bool yn);
+       void self_delete ();
+       virtual void start_step_editing () {}
+       virtual void stop_step_editing() {}
+
+       void set_invert_sensitive (bool);
+       bool verify_new_route_name (const std::string& name);
+
+       void route_gui_changed (PBD::PropertyChange const&);
+       virtual void route_color_changed () {}
 
-  private:
        void check_rec_enable_sensitivity ();
-       void parameter_changed (std::string const &);
+
+       virtual void bus_send_display_changed (boost::shared_ptr<ARDOUR::Route>);
+
+       static std::string program_port_prefix;
+
+       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;
+
+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* _solo_release;
+       SoloMuteRelease* _mute_release;
+
+       ControlSlaveUI* csu;
+
+private:
+       void setup_invert_buttons ();
+       void set_invert_button_state ();
+       void invert_menu_toggled (uint32_t);
+       bool invert_press (GdkEventButton *);
+       bool invert_release (GdkEventButton *, uint32_t i);
+
+       int _i_am_the_modifier;
+       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;
 
-       void post_rtop_cleanup (ARDOUR::SessionEvent* ev);
-       void post_group_rtop_cleanup (ARDOUR::SessionEvent* ev, ARDOUR::RouteGroup*, ARDOUR::RouteGroup::Property);
+       static uint32_t _max_invert_buttons;
 };
 
 #endif /* __ardour_route_ui__ */