selecting a track/bus in the editor list now selects it in the canvas, and also ensur...
[ardour.git] / gtk2_ardour / editor_routes.h
index 6297f906bbe806921364a36982e7b35fe89a4e2e..9780307435adf3d3b38110a8961607cc06ea70e2 100644 (file)
@@ -21,6 +21,7 @@
 #define __ardour_gtk_editor_route_h__
 
 #include "pbd/signals.h"
+#include "gtkmm2ext/widget_state.h"
 #include "editor_component.h"
 
 class EditorRoutes : public EditorComponent, public PBD::ScopedConnectionList, public ARDOUR::SessionHandlePtr
@@ -36,16 +37,20 @@ public:
 
        void move_selected_tracks (bool);
        void show_track_in_display (TimeAxisView &);
-       
+
        void suspend_redisplay () {
                _no_redisplay = true;
        }
-       
+
+        void allow_redisplay () { 
+               _no_redisplay = false;
+       }
+
        void resume_redisplay () {
                _no_redisplay = false;
                redisplay ();
        }
-       
+
        void redisplay ();
        void update_visibility ();
        void routes_added (std::list<RouteTimeAxisView*> routes);
@@ -54,11 +59,12 @@ public:
        std::list<TimeAxisView*> views () const;
        void hide_all_tracks (bool);
        void clear ();
-       void sync_order_keys (std::string const &);
+        void sync_order_keys_from_treeview ();
+        void reset_remote_control_ids ();
 
 private:
-
        void initial_display ();
+       void on_input_active_changed (std::string const &);
        void on_tv_rec_enable_changed (std::string const &);
        void on_tv_mute_enable_toggled (std::string const &);
        void on_tv_solo_enable_toggled (std::string const &);
@@ -66,8 +72,10 @@ private:
        void on_tv_solo_safe_toggled (std::string const &);
        void build_menu ();
        void show_menu ();
+        void sync_treeview_from_order_keys ();
        void route_deleted (Gtk::TreeModel::Path const &);
        void visible_changed (std::string const &);
+       void active_changed (std::string const &);
        void reordered (Gtk::TreeModel::Path const &, Gtk::TreeModel::iterator const &, int *);
        bool button_press (GdkEventButton *);
        void route_property_changed (const PBD::PropertyChange&, boost::weak_ptr<ARDOUR::Route>);
@@ -77,6 +85,8 @@ private:
        void update_solo_display (bool);
        void update_solo_isolate_display ();
        void update_solo_safe_display ();
+       void update_input_active_display ();
+       void update_active_display ();
        void set_all_tracks_visibility (bool);
        void set_all_audio_midi_visibility (int, bool);
        void show_all_routes ();
@@ -88,12 +98,12 @@ private:
        void show_all_miditracks ();
        void hide_all_miditracks ();
        void show_tracks_with_regions_at_playhead ();
-       
+        void selection_changed ();
+
        void display_drag_data_received (
                Glib::RefPtr<Gdk::DragContext> const &, gint, gint, Gtk::SelectionData const &, guint, guint
                );
-       
-       void track_list_reorder (Gtk::TreeModel::Path const &, Gtk::TreeModel::iterator const & iter, int* new_order);
+
        bool selection_filter (Glib::RefPtr<Gtk::TreeModel> const &, Gtk::TreeModel::Path const &, bool);
        void name_edit (std::string const &, std::string const &);
        void solo_changed_so_update_mute ();
@@ -105,39 +115,50 @@ private:
                        add (rec_state);
                        add (mute_state);
                        add (solo_state);
+                       add (solo_visible);
                        add (solo_isolate_state);
                        add (solo_safe_state);
                        add (is_track);
                        add (tv);
                        add (route);
                        add (name_editable);
+                       add (is_input_active);
+                       add (is_midi);
+                       add (active);
                }
-               
-               Gtk::TreeModelColumn<std::string>  text;
+
+               Gtk::TreeModelColumn<std::string>    text;
                Gtk::TreeModelColumn<bool>           visible;
                Gtk::TreeModelColumn<uint32_t>       rec_state;
                Gtk::TreeModelColumn<uint32_t>       mute_state;
                Gtk::TreeModelColumn<uint32_t>       solo_state;
+               /** true if the solo buttons are visible for this route, otherwise false */
+               Gtk::TreeModelColumn<bool>           solo_visible;
                Gtk::TreeModelColumn<uint32_t>       solo_isolate_state;
                Gtk::TreeModelColumn<uint32_t>       solo_safe_state;
                Gtk::TreeModelColumn<bool>           is_track;
                Gtk::TreeModelColumn<TimeAxisView*>  tv;
                Gtk::TreeModelColumn<boost::shared_ptr<ARDOUR::Route> >  route;
                Gtk::TreeModelColumn<bool>           name_editable;
+               Gtk::TreeModelColumn<bool>           is_input_active;
+               Gtk::TreeModelColumn<bool>           is_midi;
+               Gtk::TreeModelColumn<bool>           active;
        };
 
        Gtk::ScrolledWindow _scroller;
        Gtkmm2ext::DnDTreeView<boost::shared_ptr<ARDOUR::Route> > _display;
        Glib::RefPtr<Gtk::ListStore> _model;
        ModelColumns _columns;
-       
+       int _name_column;
+       int _visible_column;
+       int _active_column;
+
        bool _ignore_reorder;
        bool _no_redisplay;
-       bool _redisplay_does_not_sync_order_keys;
-       bool _redisplay_does_not_reset_order_keys;
-       
+        bool _adding_routes;
+
        Gtk::Menu* _menu;
-        Gtk::Widget* old_focus; 
+        Gtk::Widget* old_focus;
         uint32_t selection_countdown;
         Gtk::CellEditable* name_editable;