Better method for redrawing gain meter pixmaps upon theme change
[ardour.git] / gtk2_ardour / route_params_ui.h
index a229d050b0b79b3b53d6440e4c78970972916c49..c0b70cbdb1669c25a5c74b86cd47e9810be009c3 100644 (file)
@@ -15,7 +15,6 @@
     along with this program; if not, write to the Free Software
     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 
-    $Id$
 */
 
 #ifndef __ardour_route_params_ui_h__
 
 #include <list>
 
-#include <gtkmm.h>
+#include <gtkmm/box.h>
+#include <gtkmm/button.h>
+#include <gtkmm/eventbox.h>
+#include <gtkmm/frame.h>
+#include <gtkmm/label.h>
+#include <gtkmm/paned.h>
+#include <gtkmm/scrolledwindow.h>
+#include <gtkmm/togglebutton.h>
+#include <gtkmm/treeview.h>
+
+#include <pbd/stateful.h>
 
 #include <ardour/ardour.h>
-#include <ardour/stateful.h>
 #include <ardour/io.h>
 #include <ardour/redirect.h>
 
 #include "io_selector.h"
 #include "ardour_dialog.h"
-#include "keyboard_target.h"
 #include "redirect_box.h"
 #include "route_redirect_selection.h"
 
@@ -51,7 +58,7 @@ class PluginSelector;
 class RouteParams_UI : public ArdourDialog
 {
   public:
-       RouteParams_UI (ARDOUR::AudioEngine&);
+       RouteParams_UI ();
        ~RouteParams_UI();
 
        void set_session (ARDOUR::Session *);
@@ -59,8 +66,6 @@ class RouteParams_UI : public ArdourDialog
        PluginSelector&  plugin_selector() { return *_plugin_selector; }
 
   private:
-       ARDOUR::AudioEngine&     engine;
-
        Gtk::HBox                global_hpacker;
        Gtk::VBox                global_vpacker;
        Gtk::ScrolledWindow      scroller;
@@ -69,7 +74,6 @@ class RouteParams_UI : public ArdourDialog
        Gtk::VBox                mixer_scroller_vpacker;
 
        Gtk::VBox                list_vpacker;
-       Gtk::TreeView            route_select_list;
        Gtk::Label               route_list_button_label;
        Gtk::Button              route_list_button;
        Gtk::ScrolledWindow      route_select_scroller;
@@ -113,14 +117,14 @@ class RouteParams_UI : public ArdourDialog
        PluginSelector    *_plugin_selector;
        RouteRedirectSelection  _rr_selection;
 
-       ARDOUR::Route           *_route;
+       boost::shared_ptr<ARDOUR::Route> _route;
        sigc::connection            _route_conn;
        sigc::connection            _route_ds_conn;
 
-       ARDOUR::Redirect       * _pre_redirect;
+       boost::shared_ptr<ARDOUR::Redirect> _pre_redirect;
        sigc::connection            _pre_plugin_conn;
 
-       ARDOUR::Redirect       * _post_redirect;
+       boost::shared_ptr<ARDOUR::Redirect> _post_redirect;
        sigc::connection            _post_plugin_conn;
        
        
@@ -134,15 +138,31 @@ class RouteParams_UI : public ArdourDialog
        };
        
        ConfigView _current_view;
+
+
+       /* treeview */
+       struct RouteDisplayModelColumns : public Gtk::TreeModel::ColumnRecord {
+               RouteDisplayModelColumns() {
+                       add(text);
+                       add(route);
+               }
+               Gtk::TreeModelColumn<Glib::ustring> text;
+               Gtk::TreeModelColumn<boost::shared_ptr<ARDOUR::Route> > route;
+       };
+
+       RouteDisplayModelColumns route_display_columns ;
+       Gtk::TreeView route_display;
+       Glib::RefPtr<Gtk::ListStore> route_display_model;
+
        
-       void add_route (ARDOUR::Route*);
+       void add_routes (ARDOUR::Session::RouteList&);
 
-       void route_name_changed (void *src, ARDOUR::Route *route);
-       void route_removed (ARDOUR::Route *route);
+       void route_name_changed (void *src, boost::shared_ptr<ARDOUR::Route> route);
+       void route_removed (boost::shared_ptr<ARDOUR::Route> route);
 
 
-       void route_selected (gint row, gint col, GdkEvent *ev);
-       void route_unselected (gint row, gint col, GdkEvent *ev);
+       void route_selected();
+       //void route_unselected (gint row, gint col, GdkEvent *ev);
 
        void setup_io_frames();
        void cleanup_io_frames();
@@ -156,11 +176,10 @@ class RouteParams_UI : public ArdourDialog
        void setup_redirect_boxes();
        void cleanup_redirect_boxes();
 
-       void redirect_selected (ARDOUR::Redirect *, ARDOUR::Placement);
-       void redirect_unselected (ARDOUR::Redirect *);
+       void redirect_selected (boost::shared_ptr<ARDOUR::Redirect>, ARDOUR::Placement);
        
-       void plugin_going_away (ARDOUR::Plugin *foo, ARDOUR::Placement);
-       void redirect_going_away (ARDOUR::Redirect *foo);
+       void plugin_going_away (ARDOUR::Placement);
+       void redirect_going_away (boost::shared_ptr<ARDOUR::Redirect>);
 
        gint edit_input_configuration (GdkEventButton *ev);
        gint edit_output_configuration (GdkEventButton *ev);
@@ -168,7 +187,7 @@ class RouteParams_UI : public ArdourDialog
        void update_routeinfo (ARDOUR::Route * route);
        
        Gtk::Menu *track_menu;
-       void show_track_menu(gint arg);
+       void show_track_menu();
        
        void update_title ();
        //void unselect_all_redirects ();