Add missing files.
[ardour.git] / gtk2_ardour / route_ui.h
index d2df30dad7cca7e544218712588c9b4df7997414..e9d81451f6d7497ae544bfeb6d97ba62290d7b80 100644 (file)
@@ -47,7 +47,7 @@ namespace Gtk {
 }
 
 class BindableToggleButton;
-class LED;
+class ArdourButton;
 
 class RouteUI : public virtual AxisView
 {
@@ -57,6 +57,8 @@ class RouteUI : public virtual AxisView
 
        virtual ~RouteUI();
 
+       Gdk::Color color () const;
+
        virtual void set_route (boost::shared_ptr<ARDOUR::Route>);
        virtual void set_button_names () = 0;
 
@@ -77,8 +79,10 @@ class RouteUI : public virtual AxisView
 
        boost::shared_ptr<ARDOUR::Route> _route;
 
-       void set_color (const Gdk::Color & c);
-       bool choose_color ();
+       void request_redraw ();
+
+       virtual void set_color (const Gdk::Color & c);
+       void choose_color ();
 
        bool ignore_toggle;
        bool wait_for_release;
@@ -90,13 +94,19 @@ class RouteUI : public virtual AxisView
        BindableToggleButton* solo_button;
        BindableToggleButton* rec_enable_button; /* audio tracks */
        BindableToggleButton* show_sends_button; /* busses */
+       ArdourButton* monitor_input_button;
+       ArdourButton* monitor_disk_button;
+
+       Gtk::Image* solo_safe_image;
 
-        LED* solo_safe_led;
-        LED* solo_isolated_led;
+        ArdourButton* solo_safe_led;
+        ArdourButton* solo_isolated_led;
 
        Gtk::Label solo_button_label;
        Gtk::Label mute_button_label;
        Gtk::Label rec_enable_button_label;
+       Gtk::Label monitor_input_button_label;
+       Gtk::Label monitor_disk_button_label;
 
        void send_blink (bool);
        sigc::connection send_blink_connection;
@@ -108,11 +118,6 @@ class RouteUI : public virtual AxisView
        Gtk::Menu* solo_menu;
        Gtk::Menu* sends_menu;
 
-       XMLNode *xml_node;
-       void ensure_xml_node ();
-
-       virtual XMLNode* get_automation_child_xml_node (Evoral::Parameter);
-
        bool mute_press(GdkEventButton*);
        bool mute_release(GdkEventButton*);
        bool solo_press(GdkEventButton*);
@@ -122,6 +127,14 @@ class RouteUI : public virtual AxisView
        bool show_sends_press(GdkEventButton*);
        bool show_sends_release(GdkEventButton*);
 
+       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 monitoring_changed ();
+       void update_monitoring_display ();
+
        void step_gain_up ();
        void step_gain_down ();
        void page_gain_up ();
@@ -131,8 +144,8 @@ class RouteUI : public virtual AxisView
        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(bool, void*);
        void solo_changed_so_update_mute ();
@@ -167,7 +180,7 @@ class RouteUI : public virtual AxisView
 
        int  set_color_from_route ();
 
-       void remove_this_route ();
+       void remove_this_route (bool apply_to_selection = false);
        static gint idle_remove_this_route (RouteUI *);
 
        void route_rename();
@@ -175,9 +188,8 @@ class RouteUI : public virtual AxisView
        virtual void property_changed (const PBD::PropertyChange&);
        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);
 
         Gtk::Menu* record_menu;
         void build_record_menu ();
@@ -185,7 +197,7 @@ class RouteUI : public virtual AxisView
        Gtk::CheckMenuItem *step_edit_item;
        void toggle_step_edit ();
        virtual void step_edit_changed (bool);
-        
+
        virtual void polarity_changed ();
 
        Gtk::CheckMenuItem *denormal_menu_item;
@@ -223,16 +235,24 @@ class RouteUI : public virtual AxisView
         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 (std::string);
+       virtual void route_color_changed () {}
+
   private:
        void check_rec_enable_sensitivity ();
        void parameter_changed (std::string const &);
        void relabel_solo_button ();
 
+       std::string route_state_id () const;
+
        struct SoloMuteRelease {
-           SoloMuteRelease (bool was_active) 
+           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;
@@ -249,7 +269,7 @@ class RouteUI : public virtual AxisView
        void invert_toggled (uint32_t, BindableToggleButton *);
        void invert_menu_toggled (uint32_t);
        bool invert_press (GdkEventButton *);
-       
+
        int _i_am_the_modifier;
        std::list<BindableToggleButton*> _invert_buttons;
        Gtk::Menu* _invert_menu;