rationalize destruction pathway (some more); tidy-ify some ImageFrame code
[ardour.git] / gtk2_ardour / mixer_strip.h
index 46cc572200e2922fc97dcf5f7fe05817fce9e80c..acb69534b3d590b667e1076590bd8a416f059aa2 100644 (file)
@@ -53,9 +53,6 @@
 #include "processor_box.h"
 #include "ardour_dialog.h"
 
-class MotionController;
-
-
 namespace Gtkmm2ext {
        class SliderController;
 }
@@ -76,31 +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_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; }
+       GainMeter&      gain_meter()      { return gpm; }
+       PannerUI&       panner_ui()       { return panners; }
+       PluginSelector* plugin_selector();
 
        void fast_update ();
        void set_embedded (bool);
-       
+
        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>);
 
        sigc::signal<void>      WidthChanged;
 
        static sigc::signal<void,boost::shared_ptr<ARDOUR::Route> > SwitchIO;
+       static PBD::Signal1<void,MixerStrip*> CatchDeletion;
 
   protected:
        friend class Mixer_UI;
@@ -110,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;
 
@@ -135,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;
@@ -159,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;
@@ -173,20 +180,23 @@ 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;
+       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;
+       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>);
 
@@ -205,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 ();
@@ -226,9 +236,8 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
        bool ignore_comment_edit;
 
        void set_route_group (ARDOUR::RouteGroup *);
-       void add_route_group_to_menu (ARDOUR::RouteGroup *, Gtk::RadioMenuItem::Group*);
        bool select_route_group (GdkEventButton *);
-       void route_group_changed (void *);
+       void route_group_changed ();
 
        IOSelectorWindow *input_selector;
        IOSelectorWindow *output_selector;
@@ -256,9 +265,14 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
        boost::shared_ptr<ARDOUR::Delivery> _current_delivery;
        void revert_to_default_display ();
 
-       void set_route_group_to_new ();
+       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__ */