most of the 2.X->3.0 commit (up to rev 4299) except for gtk2_ardour/editor_canvas...
[ardour.git] / gtk2_ardour / route_ui.h
index ea860419860883ad8496b2c713fb647571654de1..c784b9766801f2ae56ba06b0e14a7a6ff045400c 100644 (file)
@@ -15,7 +15,6 @@
     along with this program; if not, write to the Free Software
     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 
-    $Id$
 */
 
 #ifndef __ardour_route_ui__
@@ -32,6 +31,7 @@
 
 namespace ARDOUR {
        class AudioTrack;
+       class MidiTrack;
 }
 
 namespace Gtk {
@@ -45,17 +45,23 @@ class BindableToggleButton;
 class RouteUI : public virtual AxisView
 {
   public:
+       RouteUI(ARDOUR::Session&, const char*, const char*, const char*);
        RouteUI(boost::shared_ptr<ARDOUR::Route>, ARDOUR::Session&, const char*, const char*, const char*);
+
        virtual ~RouteUI();
 
+       virtual void set_route (boost::shared_ptr<ARDOUR::Route>);
+       void set_button_names (const char*, const char*, const char*);
+
        bool is_track() const;
        bool is_audio_track() const;
+       bool is_midi_track() const;
 
        boost::shared_ptr<ARDOUR::Route> route() const { return _route; }
        
-       // FIXME: make these return shared_ptr
-       ARDOUR::Track*      track() const;
-       ARDOUR::AudioTrack* audio_track() 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;
 
@@ -70,6 +76,8 @@ class RouteUI : public virtual AxisView
 
        bool ignore_toggle;
        bool wait_for_release;
+       bool multiple_mute_change;
+       bool multiple_solo_change;
 
        BindableToggleButton* mute_button;
        BindableToggleButton* solo_button;
@@ -85,17 +93,19 @@ class RouteUI : public virtual AxisView
        XMLNode *xml_node;
        void ensure_xml_node ();
 
-       XMLNode* get_child_xml_node (const string & childname);
+       virtual XMLNode* get_automation_child_xml_node (Evoral::Parameter param);
        
        bool mute_press(GdkEventButton*);
        bool mute_release(GdkEventButton*);
        bool solo_press(GdkEventButton*);
        bool solo_release(GdkEventButton*);
        bool rec_enable_press(GdkEventButton*);
+       bool rec_enable_release(GdkEventButton*);
 
        void solo_changed(void*);
+       void solo_changed_so_update_mute ();
        void mute_changed(void*);
-       virtual void redirects_changed (void *) {}
+       virtual void processors_changed () {}
        void route_rec_enable_changed();
        void session_rec_enable_changed();
 
@@ -121,16 +131,12 @@ class RouteUI : public virtual AxisView
 
        int  set_color_from_route ();
 
-       sigc::connection blink_connection;
-
-       void rec_enable_button_blink (bool onoff, ARDOUR::AudioDiskstream *, Gtk::Widget *w);
-       
        void remove_this_route ();
        static gint idle_remove_this_route (RouteUI *);
 
        void route_rename();
        
-       virtual void name_changed (void *src);
+       virtual void name_changed ();
        void route_removed ();
 
        Gtk::CheckMenuItem *route_active_menu_item;
@@ -141,18 +147,36 @@ class RouteUI : public virtual AxisView
        void toggle_polarity ();
        virtual void polarity_changed ();
 
+       Gtk::CheckMenuItem *denormal_menu_item;
+       void toggle_denormal_protection();
+       virtual void denormal_protection_changed ();
+
        void disconnect_input ();
        void disconnect_output ();
 
-       void update_rec_display ();
+       virtual void update_rec_display ();
        void update_mute_display ();
+
+       bool was_solo_safe;
        void update_solo_display ();
+
        virtual void map_frozen ();
 
        void set_remote_control_id (uint32_t id, Gtk::CheckMenuItem* item);
 
        void reversibly_apply_route_boolean (string name, void (ARDOUR::Route::*func)(bool, void*), bool, void *);
-       void reversibly_apply_audio_track_boolean (string name, void (ARDOUR::AudioTrack::*func)(bool, void*), bool, void *);
+       void reversibly_apply_track_boolean (string name, void (ARDOUR::Track::*func)(bool, void*), bool, void *);
+
+       void adjust_latency ();
+   protected:
+       std::vector<sigc::connection> connections;
+       std::string s_name;
+       std::string m_name;
+       std::string r_name;
+       void init ();
+       void reset ();
 };
 
 #endif /* __ardour_route_ui__ */