rationalize destruction pathway (some more); tidy-ify some ImageFrame code
[ardour.git] / gtk2_ardour / mixer_strip.h
index e859e520267a29e450ea955a563d1d0bb201a697..acb69534b3d590b667e1076590bd8a416f059aa2 100644 (file)
 #include <gtkmm2ext/click_box.h>
 #include <gtkmm2ext/slider_controller.h>
 
-#include <pbd/stateful.h>
+#include "pbd/stateful.h"
 
-#include <ardour/types.h>
-#include <ardour/ardour.h>
-#include <ardour/processor.h>
+#include "ardour/types.h"
+#include "ardour/ardour.h"
+#include "ardour/processor.h"
 
-#include <pbd/fastlog.h>
+#include "pbd/fastlog.h"
 
 #include "route_ui.h"
 #include "gain_meter.h"
@@ -53,9 +53,6 @@
 #include "processor_box.h"
 #include "ardour_dialog.h"
 
-class MotionController;
-
-
 namespace Gtkmm2ext {
        class SliderController;
 }
@@ -76,27 +73,36 @@ namespace Gtk {
 
 class Mixer_UI;
 class IOSelectorWindow;
+class MotionController;
+class RouteGroupMenu;
 
 class MixerStrip : public RouteUI, public Gtk::EventBox
 {
   public:
-       MixerStrip (Mixer_UI&, ARDOUR::Session&, boost::shared_ptr<ARDOUR::Route>, bool in_mixer = true);
-       MixerStrip (Mixer_UI&, ARDOUR::Session&, bool in_mixer = true);
+       MixerStrip (Mixer_UI&, ARDOUR::Session*, boost::shared_ptr<ARDOUR::Route>, bool in_mixer = true);
+       MixerStrip (Mixer_UI&, ARDOUR::Session*, bool in_mixer = true);
        ~MixerStrip ();
 
-       void set_width (Width, void* owner);
-       Width get_width() const { return _width; }
-       void* width_owner() const { return _width_owner; }
+       void set_width_enum (Width, void* owner);
+       Width get_width_enum () const { return _width; }
+       void* width_owner () const { return _width_owner; }
+
+       GainMeter&      gain_meter()      { return gpm; }
+       PannerUI&       panner_ui()       { return panners; }
+       PluginSelector* plugin_selector();
 
        void fast_update ();
        void set_embedded (bool);
-       
-       ARDOUR::RouteGroup* mix_group() const;
+
+       ARDOUR::RouteGroup* route_group() const;
        void set_route (boost::shared_ptr<ARDOUR::Route>);
+       void set_button_names ();
+       void show_send (boost::shared_ptr<ARDOUR::Send>);
 
-#ifdef GTKOSX
        sigc::signal<void>      WidthChanged;
-#endif
+
+       static sigc::signal<void,boost::shared_ptr<ARDOUR::Route> > SwitchIO;
+       static PBD::Signal1<void,MixerStrip*> CatchDeletion;
 
   protected:
        friend class Mixer_UI;
@@ -106,6 +112,11 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
        void set_selected(bool yn);
        void set_stuff_from_route ();
 
+       bool on_leave_notify_event (GdkEventCrossing* ev);
+       bool on_enter_notify_event (GdkEventCrossing* ev);
+       bool on_key_press_event (GdkEventKey* ev);
+       bool on_key_release_event (GdkEventKey* ev);
+
   private:
        Mixer_UI& _mixer;
 
@@ -131,11 +142,11 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
        Gtk::Frame          global_frame;
        Gtk::VBox           global_vpacker;
 
-       ProcessorBox pre_processor_box;
-       ProcessorBox post_processor_box;
+       ProcessorBox processor_box;
        GainMeter   gpm;
        PannerUI    panners;
-       
+       Gtk::ToggleButton _mono_button;
+
        Gtk::Table button_table;
        Gtk::Table middle_button_table;
        Gtk::Table bottom_button_table;
@@ -155,11 +166,11 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
        Gtk::Button output_button;
        Gtk::Label  output_label;
 
-       sigc::connection newplug_connection;
-    
+       std::string longest_label;
+
        gint    mark_update_safe ();
        guint32 mode_switch_in_progress;
-       
+
        Gtk::Button   name_button;
 
        ArdourDialog*  comment_window;
@@ -169,22 +180,25 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
        void comment_editor_done_editing();
        void setup_comment_editor ();
        void comment_button_clicked ();
+       void mono_button_clicked ();
 
        Gtk::Button   group_button;
        Gtk::Label    group_label;
-       Gtk::Menu    *group_menu;
+       RouteGroupMenu *group_menu;
 
        gint input_press (GdkEventButton *);
        gint output_press (GdkEventButton *);
 
-       Gtk::Menu  input_menu;
-       void add_bundle_to_input_menu (boost::shared_ptr<ARDOUR::Bundle>, ARDOUR::BundleList const &);
+       Gtk::Menu input_menu;
+       std::list<boost::shared_ptr<ARDOUR::Bundle> > input_menu_bundles;
+       void maybe_add_bundle_to_input_menu (boost::shared_ptr<ARDOUR::Bundle>, ARDOUR::BundleList const &);
 
        Gtk::Menu output_menu;
-       void add_bundle_to_output_menu (boost::shared_ptr<ARDOUR::Bundle>, ARDOUR::BundleList const &);
-       
-       void bundle_input_chosen (boost::shared_ptr<ARDOUR::Bundle>);
-       void bundle_output_chosen (boost::shared_ptr<ARDOUR::Bundle>);
+       std::list<boost::shared_ptr<ARDOUR::Bundle> > output_menu_bundles;
+       void maybe_add_bundle_to_output_menu (boost::shared_ptr<ARDOUR::Bundle>, ARDOUR::BundleList const &);
+
+       void bundle_input_toggled (boost::shared_ptr<ARDOUR::Bundle>);
+       void bundle_output_toggled (boost::shared_ptr<ARDOUR::Bundle>);
 
        void edit_input_configuration ();
        void edit_output_configuration ();
@@ -192,6 +206,7 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
        void diskstream_changed ();
 
        Gtk::Menu *send_action_menu;
+       Gtk::MenuItem* rename_menu_item;
        void build_send_action_menu ();
 
        void new_send ();
@@ -200,8 +215,8 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
        void input_changed (ARDOUR::IOChange, void *);
        void output_changed (ARDOUR::IOChange, void *);
 
-       sigc::connection panstate_connection;
-       sigc::connection panstyle_connection;
+       PBD::ScopedConnection panstate_connection;
+       PBD::ScopedConnection panstyle_connection;
        void connect_to_pan ();
 
        void update_diskstream_display ();
@@ -220,31 +235,21 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
        void comment_edited ();
        bool ignore_comment_edit;
 
-       void set_mix_group (ARDOUR::RouteGroup *);
-       void add_mix_group_to_menu (ARDOUR::RouteGroup *, Gtk::RadioMenuItem::Group*);
-       bool select_mix_group (GdkEventButton *);
-       void mix_group_changed (void *);
+       void set_route_group (ARDOUR::RouteGroup *);
+       bool select_route_group (GdkEventButton *);
+       void route_group_changed ();
 
        IOSelectorWindow *input_selector;
        IOSelectorWindow *output_selector;
 
        Gtk::Style *passthru_style;
 
-       void route_gui_changed (string, void*);
+       void route_gui_changed (std::string, void*);
        void show_route_color ();
        void show_passthru_color ();
 
        void route_active_changed ();
 
-       /* speed control (for tracks only) */
-
-       Gtk::Adjustment    speed_adjustment;
-       Gtkmm2ext::ClickBox speed_spinner;
-       Gtk::Label         speed_label;
-       Gtk::Frame         speed_frame;
-
-       void speed_adjustment_changed ();
-       void speed_changed ();
        void name_changed ();
        void update_speed_display ();
        void map_frozen ();
@@ -256,7 +261,18 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
        void engine_running();
        void engine_stopped();
 
+       void switch_io (boost::shared_ptr<ARDOUR::Route>);
+       boost::shared_ptr<ARDOUR::Delivery> _current_delivery;
+       void revert_to_default_display ();
+
+       void drop_send ();
+       PBD::ScopedConnection send_gone_connection;
+
+       void reset_strip_style ();
+
        static int scrollbar_height;
+
+       void update_io_button (boost::shared_ptr<ARDOUR::Route> route, Width width, bool input_button);
 };
 
 #endif /* __ardour_mixer_strip__ */