Another similar fix for use of an uninitialized variable.
[ardour.git] / gtk2_ardour / add_route_dialog.h
index 984f98735fbf09cc8bf0b902732731169e069500..78dd51035c08d3bbd03716afb936d04b5632ae6c 100644 (file)
 #include <gtkmm/spinbutton.h>
 #include <gtkmm/button.h>
 #include <gtkmm/comboboxtext.h>
+#include <gtkmm/treemodel.h>
 
 #include "ardour/types.h"
 #include "ardour/template_utils.h"
 #include "ardour/session.h"
 
-class AddRouteDialog : public Gtk::Dialog
+#include "ardour_dialog.h"
+
+class Editor;
+
+class AddRouteDialog : public ArdourDialog
 {
   public:
        AddRouteDialog (ARDOUR::Session &);
@@ -50,24 +55,28 @@ class AddRouteDialog : public Gtk::Dialog
 
        ARDOUR::DataType type();
        ARDOUR::TrackMode mode();
-       ARDOUR::RouteGroup* edit_group ();
+       ARDOUR::RouteGroup* route_group ();
 
   private:
        ARDOUR::Session& _session;
        Gtk::Entry name_template_entry;
-       Gtk::RadioButton track_button;
-       Gtk::RadioButton bus_button;
+       Gtk::ComboBoxText track_bus_combo;
        Gtk::Adjustment routes_adjustment;
        Gtk::SpinButton routes_spinner;
        Gtk::ComboBoxText channel_combo;
+       Gtk::Label track_mode_label;
        Gtk::ComboBoxText track_mode_combo;
-       Gtk::ComboBoxText edit_group_combo;
+       Gtk::ComboBoxText route_group_combo;
 
        std::vector<ARDOUR::TemplateInfo> route_templates;
        
        void track_type_chosen ();
        void refill_channel_setups ();
-       void add_edit_group (ARDOUR::RouteGroup *);
+       void refill_route_groups ();
+       void add_route_group (ARDOUR::RouteGroup *);
+       void group_changed ();
+       bool channel_separator (const Glib::RefPtr<Gtk::TreeModel> &m, const Gtk::TreeModel::iterator &i);
+       bool route_separator (const Glib::RefPtr<Gtk::TreeModel> &m, const Gtk::TreeModel::iterator &i);
 
        void reset_template_option_visibility ();