fix dragging of region gain line, affected by coordinate system change caused by...
[ardour.git] / gtk2_ardour / route_ui.h
index c7c7fb094484a775f43962481198cb526a5121a9..e18eda687175b39fc6b523f7372529d5bbe1bed9 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 {
@@ -50,12 +50,13 @@ class RouteUI : public virtual AxisView
 
        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;
 
@@ -85,7 +86,7 @@ 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*);
@@ -97,7 +98,7 @@ class RouteUI : public virtual AxisView
        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();
 
@@ -123,16 +124,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;
@@ -143,10 +140,14 @@ 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;
@@ -157,7 +158,9 @@ class RouteUI : public virtual AxisView
        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 ();
 };
 
 #endif /* __ardour_route_ui__ */