Add missing snap-to actions to the main menu so that their keyboard accelerators...
[ardour.git] / gtk2_ardour / route_ui.h
index 4f7aaddea5f0245b56efef3c42a5449756ea3cf5..4a33c8f16dcdb0c0e246840a158de50a3e0fc800 100644 (file)
@@ -63,6 +63,7 @@ class RouteUI : public virtual AxisView
        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; }
 
@@ -76,15 +77,15 @@ class RouteUI : public virtual AxisView
 
        boost::shared_ptr<ARDOUR::Route> _route;
 
-       void set_color (const Gdk::Color & c);
-       bool choose_color ();
+       virtual void set_color (const Gdk::Color & c);
+       void choose_color ();
 
        bool ignore_toggle;
        bool wait_for_release;
        bool multiple_mute_change;
        bool multiple_solo_change;
 
-       BindableToggleButton* invert_button;
+       Gtk::HBox _invert_button_box;
        BindableToggleButton* mute_button;
        BindableToggleButton* solo_button;
        BindableToggleButton* rec_enable_button; /* audio tracks */
@@ -95,7 +96,6 @@ class RouteUI : public virtual AxisView
 
        Gtk::Label solo_button_label;
        Gtk::Label mute_button_label;
-       Gtk::Label invert_button_label;
        Gtk::Label rec_enable_button_label;
 
        void send_blink (bool);
@@ -111,9 +111,8 @@ class RouteUI : public virtual AxisView
        XMLNode *xml_node;
        void ensure_xml_node ();
 
-       virtual XMLNode* get_automation_child_xml_node (Evoral::Parameter param);
+       virtual XMLNode* get_automation_child_xml_node (Evoral::Parameter);
 
-       void invert_toggled();
        bool mute_press(GdkEventButton*);
        bool mute_release(GdkEventButton*);
        bool solo_press(GdkEventButton*);
@@ -132,8 +131,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 ();
@@ -224,6 +223,8 @@ class RouteUI : public virtual AxisView
         virtual void start_step_editing () {}
         virtual void stop_step_editing() {}
 
+        void set_invert_sensitive (bool);
+
   private:
        void check_rec_enable_sensitivity ();
        void parameter_changed (std::string const &);
@@ -245,6 +246,17 @@ class RouteUI : public virtual AxisView
        SoloMuteRelease* _solo_release;
        SoloMuteRelease* _mute_release;
 
+       void setup_invert_buttons ();
+       void set_invert_button_state ();
+       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;
+
+       static uint32_t _max_invert_buttons;
 };
 
 #endif /* __ardour_route_ui__ */