Remove some unused code.
[ardour.git] / gtk2_ardour / mixer_ui.h
index 2945e008588052354203a968a3f46dccbcb3d438..08d7b6e487f5c077a001e321cf8aeab97dfff2f5 100644 (file)
 #include <gtkmm/paned.h>
 #include <gtkmm/menu.h>
 #include <gtkmm/treeview.h>
+#include <gtkmm/liststore.h>
 
 #include "pbd/stateful.h"
+#include "pbd/signals.h"
 
 #include "ardour/ardour.h"
+#include "ardour/session_handle.h"
 
-#include "route_processor_selection.h"
 #include "enums.h"
+#include "mixer_actor.h"
 
 namespace ARDOUR {
        class Route;
        class RouteGroup;
-       class Session;
-       class AudioDiskstream;
 };
 
 class MixerStrip;
 class PluginSelector;
 class MixerGroupTabs;
+class MonitorSection;
 
-class Mixer_UI : public Gtk::Window
+class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public ARDOUR::SessionHandlePtr, public MixerActor
 {
   public:
-       Mixer_UI ();
+       static Mixer_UI* instance();
        ~Mixer_UI();
 
-       void connect_to_session (ARDOUR::Session *);
+       void set_session (ARDOUR::Session *);
+       void track_editor_selection ();
 
        PluginSelector* plugin_selector();
 
@@ -75,13 +78,15 @@ class Mixer_UI : public Gtk::Window
        void hide_strip (MixerStrip *);
 
        void ensure_float (Gtk::Window&);
-       void toggle_auto_rebinding ();
-       void set_auto_rebinding(bool);
 
-       RouteRedirectSelection& selection() { return _selection; }
+        MonitorSection* monitor_section() const { return _monitor_section; }
+
+  protected:
+       void set_route_targets_for_operation ();
 
   private:
-       ARDOUR::Session         *session;
+       Mixer_UI ();
+       static Mixer_UI* _instance;
 
        bool                                    _visible;
 
@@ -127,6 +132,8 @@ class Mixer_UI : public Gtk::Window
        void add_strip (ARDOUR::RouteList&);
        void remove_strip (MixerStrip *);
 
+       MixerStrip* strip_by_route (boost::shared_ptr<ARDOUR::Route>);
+
        void hide_all_strips (bool with_select);
        void unselect_all_strips();
        void select_all_strips ();
@@ -135,18 +142,13 @@ class Mixer_UI : public Gtk::Window
        void unselect_all_audiobus_strips ();
        void select_all_audiobus_strips ();
 
-       void auto_rebind_midi_controls ();
-       bool auto_rebinding;
-
        void strip_select_op (bool audiotrack, bool select);
        void select_strip_op (MixerStrip*, bool select);
 
-       void follow_strip_selection ();
-
        gint start_updating ();
        gint stop_updating ();
 
-       void disconnect_from_session ();
+       void session_going_away ();
 
        sigc::connection fast_screen_update_connection;
        void fast_update_strips ();
@@ -175,7 +177,6 @@ class Mixer_UI : public Gtk::Window
        void show_all_audiotracks();
        void hide_all_audiotracks ();
 
-       Gtk::Menu* route_group_context_menu;
        bool in_group_row_change;
 
        void group_selected (gint row, gint col, GdkEvent *ev);
@@ -183,23 +184,23 @@ class Mixer_UI : public Gtk::Window
        void group_display_active_clicked();
        void new_route_group ();
        void remove_selected_route_group ();
-       void build_route_group_context_menu ();
        void activate_all_route_groups ();
        void disable_all_route_groups ();
        void add_route_group (ARDOUR::RouteGroup *);
        void route_groups_changed ();
-       void route_group_name_edit (const Glib::ustring&, const Glib::ustring&);
+       void route_group_name_edit (const std::string&, const std::string&);
        void route_group_row_change (const Gtk::TreeModel::Path& path,const Gtk::TreeModel::iterator& iter);
+       void route_group_row_deleted (Gtk::TreeModel::Path const &);
 
        Gtk::Menu *track_menu;
        void track_column_click (gint);
        void build_track_menu ();
 
+        MonitorSection* _monitor_section;
        PluginSelector    *_plugin_selector;
 
-       void strip_name_changed (MixerStrip *);
-
-       void group_flags_changed (void *src, ARDOUR::RouteGroup *);
+       void strip_property_changed (const PBD::PropertyChange&, MixerStrip *);
+       void route_group_property_changed (ARDOUR::RouteGroup *, const PBD::PropertyChange &);
 
        /* various treeviews */
 
@@ -211,7 +212,7 @@ class Mixer_UI : public Gtk::Window
                    add (strip);
            }
            Gtk::TreeModelColumn<bool>           visible;
-           Gtk::TreeModelColumn<Glib::ustring>  text;
+           Gtk::TreeModelColumn<std::string>  text;
            Gtk::TreeModelColumn<boost::shared_ptr<ARDOUR::Route> > route;
            Gtk::TreeModelColumn<MixerStrip*>    strip;
        };
@@ -223,7 +224,7 @@ class Mixer_UI : public Gtk::Window
                    add (group);
            }
            Gtk::TreeModelColumn<bool>                                  visible;
-           Gtk::TreeModelColumn<Glib::ustring>                 text;
+           Gtk::TreeModelColumn<std::string>                   text;
            Gtk::TreeModelColumn<ARDOUR::RouteGroup*>   group;
        };
 
@@ -241,8 +242,6 @@ class Mixer_UI : public Gtk::Window
 
        bool strip_button_release_event (GdkEventButton*, MixerStrip*);
 
-       RouteRedirectSelection _selection;
-
        Width _strip_width;
 
        void sync_order_keys (std::string const &);
@@ -253,10 +252,26 @@ class Mixer_UI : public Gtk::Window
        void parameter_changed (std::string const &);
        void set_route_group_activation (ARDOUR::RouteGroup *, bool);
 
+       void setup_track_display ();
+       void new_track_or_bus ();
+
        static const int32_t default_width = 478;
        static const int32_t default_height = 765;
 
+       /** true if we are rebuilding the route group list, or clearing
+           it during a session teardown.
+       */
+       bool _in_group_rebuild_or_clear;
+
+       void update_title ();
+       MixerStrip* strip_by_x (int x);
+
        friend class MixerGroupTabs;
+
+       void follow_editor_selection ();
+       bool _following_editor_selection;
+
+       void monitor_section_going_away ();
 };
 
 #endif /* __ardour_mixer_ui_h__ */