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 5327eb59d7a00273ff157835b660d8e83c8859bd..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__
 #include <pbd/xml++.h>
 #include <ardour/ardour.h>
 #include <ardour/route.h>
+#include <ardour/track.h>
 
 #include "axis_view.h"
 
-namespace Gtkmm2ext {
-       class BindableToggleButton;
-}
-
 namespace ARDOUR {
        class AudioTrack;
+       class MidiTrack;
 }
 
 namespace Gtk {
@@ -43,55 +40,78 @@ namespace Gtk {
        class Widget;
 }
 
+class BindableToggleButton;
+
 class RouteUI : public virtual AxisView
 {
   public:
-       RouteUI(ARDOUR::Route&, ARDOUR::Session&, const char*, const char*, const char*);
+       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;
-       ARDOUR::DiskStream* get_diskstream() const;
+       bool is_midi_track() const;
 
-       ARDOUR::Route& route() const { return _route; }
-       ARDOUR::AudioTrack* audio_track() const;
+       boost::shared_ptr<ARDOUR::Route> route() const { return _route; }
+       
+       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;
 
        string name() const;
+
+       // protected: XXX sigh this should be here
+
+       boost::shared_ptr<ARDOUR::Route> _route;
        
-       ARDOUR::Route& _route;
-       
-       void set_color (Gdk::Color c);
+       void set_color (const Gdk::Color & c);
        bool choose_color ();
 
        bool ignore_toggle;
        bool wait_for_release;
+       bool multiple_mute_change;
+       bool multiple_solo_change;
 
-       Gtkmm2ext::BindableToggleButton * mute_button;
-       Gtkmm2ext::BindableToggleButton * solo_button;
-       Gtkmm2ext::BindableToggleButton * rec_enable_button;
+       BindableToggleButton* mute_button;
+       BindableToggleButton* solo_button;
+       BindableToggleButton* rec_enable_button;
        
        virtual string solo_button_name () const { return "SoloButton"; }
        virtual string safe_solo_button_name () const { return "SafeSoloButton"; }
        
        Gtk::Menu* mute_menu;
        Gtk::Menu* solo_menu;
+       Gtk::Menu* remote_control_menu;
 
        XMLNode *xml_node;
        void ensure_xml_node ();
 
-       XMLNode* get_child_xml_node (std::string childname);
+       virtual XMLNode* get_automation_child_xml_node (Evoral::Parameter param);
        
-       gint mute_press(GdkEventButton*);
-       gint mute_release(GdkEventButton*);
-       gint solo_press(GdkEventButton*);
-       gint solo_release(GdkEventButton*);
-       gint rec_enable_press(GdkEventButton*);
+       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*);
-       void route_rec_enable_changed(void*);
+       virtual void processors_changed () {}
+       void route_rec_enable_changed();
        void session_rec_enable_changed();
 
        void build_solo_menu (void);
+       void build_remote_control_menu (void);
+       void refresh_remote_control_menu ();
 
        void solo_safe_toggle (void*, Gtk::CheckMenuItem*);
        void toggle_solo_safe (Gtk::CheckMenuItem*);
@@ -105,40 +125,58 @@ class RouteUI : public virtual AxisView
        void build_mute_menu(void);
        void init_mute_menu(ARDOUR::mute_type, Gtk::CheckMenuItem*);
        
-       void set_mix_group_solo(ARDOUR::Route&, bool);
-       void set_mix_group_mute(ARDOUR::Route&, bool);
-       void set_mix_group_rec_enable(ARDOUR::Route&, bool);
+       void set_mix_group_solo(boost::shared_ptr<ARDOUR::Route>, bool);
+       void set_mix_group_mute(boost::shared_ptr<ARDOUR::Route>, bool);
+       void set_mix_group_rec_enable(boost::shared_ptr<ARDOUR::Route>, bool);
 
        int  set_color_from_route ();
 
-       sigc::connection blink_connection;
-
-       void rec_enable_button_blink (bool onoff, ARDOUR::DiskStream *, 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 ();
 
-       static gint okay_gplusplus_cannot_do_complex_templates (RouteUI *rui);
-
        Gtk::CheckMenuItem *route_active_menu_item;
        void toggle_route_active ();
        virtual void route_active_changed ();
 
+       Gtk::CheckMenuItem *polarity_menu_item;
+       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__ */