Merging from trunk
[ardour.git] / gtk2_ardour / add_route_dialog.cc
index f1ec91f636ce3568963736fd90b6f181e8cd1163..7e89489afd92cdcb5e3da60f5c40bc427c98f8f0 100644 (file)
@@ -22,7 +22,9 @@
 #include <cmath>
 
 #include <sigc++/bind.h>
-
+#include <gtkmm/stock.h>
+#include <pbd/error.h>
+#include <pbd/convert.h>
 #include <gtkmm2ext/utils.h>
 
 #include "utils.h"
 using namespace Gtk;
 using namespace Gtkmm2ext;
 using namespace sigc;
+using namespace std;
+using namespace PBD;
+
+static const char* channel_setup_names[] = {
+       "Mono",
+       "Stereo",
+       "3 Channels",
+       "4 Channels",
+       "6 Channels",
+       "8 Channels",
+       "Manual Setup",
+       0
+};
+
+static const char* track_mode_names[] = {
+       "Normal",
+       "Tape",
+       0
+};
+
+static vector<string> channel_combo_strings;
+static vector<string> track_mode_strings;
 
-extern std::vector<string> channel_combo_strings;
 
 AddRouteDialog::AddRouteDialog ()
-       : ArdourDialog ("add route dialog"),
-         ok_button (_("OK")),
-         cancel_button (_("Cancel")),
+       : Dialog (_("ardour: add track/bus")),
          track_button (_("Tracks")),
          bus_button (_("Busses")),
-         routes_adjustment (1, 1, 32, 1, 4),
+         routes_adjustment (1, 1, 128, 1, 4),
          routes_spinner (routes_adjustment)
 {
+       if (channel_combo_strings.empty()) {
+               channel_combo_strings = PBD::internationalize (channel_setup_names);
+       }
+
+       if (track_mode_strings.empty()) {
+               track_mode_strings = PBD::internationalize (track_mode_names);
+       }
+
        set_name ("AddRouteDialog");
-       set_title (_("ardour: add track/bus"));
        set_wmclass (X_("ardour_add_track_bus"), "Ardour");
        set_position (Gtk::WIN_POS_MOUSE);
-       set_keyboard_input (true);
 
        name_template_entry.set_name ("AddRouteDialogNameTemplateEntry");
        track_button.set_name ("AddRouteDialogRadioButton");
        bus_button.set_name ("AddRouteDialogRadioButton");
-       ok_button.set_name ("AddRouteDialogButton");
-       cancel_button.set_name ("AddRouteDialogButton");
        routes_spinner.set_name ("AddRouteDialogSpinner");
        
        RadioButton::Group g = track_button.get_group();
@@ -64,63 +89,69 @@ AddRouteDialog::AddRouteDialog ()
        HBox *hbrb = manage (new HBox);
 
        hbrb->set_spacing (6);
-       hbrb->pack_start (*(manage (new Label (_("Add")))), false, false);
-       hbrb->pack_start (routes_spinner, false, false);
-       hbrb->pack_start (track_button, false, false);
-       hbrb->pack_start (bus_button, false, false);
+       hbrb->pack_start (routes_spinner, true, false, 5);
+       hbrb->pack_start (track_button, true, false, 5);
+       hbrb->pack_start (bus_button, true, false, 5);
+
+       aframe.set_label (_("Add"));
+       aframe.set_shadow_type (SHADOW_IN);
+       aframe.add (*hbrb);
 
        set_popdown_strings (channel_combo, channel_combo_strings);
+       set_popdown_strings (track_mode_combo, track_mode_strings);
+       channel_combo.set_active_text (channel_combo_strings.front());
        channel_combo.set_name (X_("ChannelCountSelector"));
-       
-       VBox *vbcc = manage (new VBox);
 
-       vbcc->set_spacing (6);
-       vbcc->pack_start (*(manage (new Label ("Channel configuration"))), false, false);
-       vbcc->pack_start (channel_combo, false, false);
+       track_button.signal_clicked().connect (mem_fun (*this, &AddRouteDialog::track_type_chosen));
+       bus_button.signal_clicked().connect (mem_fun (*this, &AddRouteDialog::track_type_chosen));
 
+       track_mode_combo.set_active_text (track_mode_strings.front());
+       track_mode_combo.set_name (X_("ChannelCountSelector"));
+       
 #if NOT_USEFUL_YET
        HBox *hbnt = manage (new HBox);
 
        hbnt->pack_start (*(manage (new Label (_("Name (template)")))), false, false);
        hbnt->pack_start (name_template_entry, true, true);
 #endif
+       VBox *dvbox = manage (new VBox);
+       HBox *dhbox = manage (new HBox);
 
-       HBox* hbbut = manage (new HBox);
-
-       set_size_request_to_display_given_text (ok_button, _("Cancel"), 20, 15); // this is cancel on purpose
-       set_size_request_to_display_given_text (cancel_button, _("Cancel"), 20, 15);
-       
-       hbbut->set_homogeneous (true);
-       hbbut->set_spacing (6);
-       hbbut->pack_end (cancel_button, false, false);  
-       hbbut->pack_end (ok_button, false, false);
+        ccframe.set_label (_("Channel Configuration"));
+       ccframe.set_shadow_type (SHADOW_IN);
 
-       HBox* hbbutouter = manage (new HBox);
-       hbbutouter->set_border_width (12);
-       hbbutouter->pack_end (*hbbut, false, false);
+       dvbox->pack_start (channel_combo, true, false, 5);
+       dvbox->pack_start (track_mode_combo, true, false, 5);
+       dhbox->pack_start (*dvbox, true, false, 5);
 
-       VBox* vb2 = manage (new VBox);
+       ccframe.add (*dhbox);
 
-       vb2->set_border_width (12);
-       vb2->set_spacing (6);
-       vb2->pack_start (*hbrb, false, false);
-       vb2->pack_start (*vbcc, false, false);
+       get_vbox()->pack_start (aframe, true, false, 10);
+       get_vbox()->pack_start (ccframe, true, false);
 #if NOT_USEFUL_YET
-       vb2->pack_start (*hbnt, false, false);
+       get_vbox()->pack_start (*hbnt, false, false);
 #endif
-       vb2->pack_start (*hbbutouter, false, false);
 
-       add (*vb2);
+       get_vbox()->show_all ();
 
-       // delete_event.connect (mem_fun(*this, &ArdourDialog::wm_close_event));
-       ok_button.signal_clicked().connect (bind (mem_fun(*this,  &ArdourDialog::stop), 0));
-       cancel_button.signal_clicked().connect (bind (mem_fun(*this, &ArdourDialog::stop), 1));
+       add_button (Stock::CANCEL, RESPONSE_CANCEL);
+       add_button (Stock::ADD, RESPONSE_ACCEPT);
 }
 
 AddRouteDialog::~AddRouteDialog ()
 {
 }
 
+void
+AddRouteDialog::track_type_chosen ()
+{
+       if (track_button.get_active()) {
+               track_mode_combo.set_sensitive (true);
+       } else {
+               track_mode_combo.set_sensitive (true);
+       }
+}
+
 bool
 AddRouteDialog::track ()
 {
@@ -139,8 +170,37 @@ AddRouteDialog::count ()
        return (int) floor (routes_adjustment.get_value ());
 }
 
+ARDOUR::TrackMode
+AddRouteDialog::mode ()
+{
+       Glib::ustring str = track_mode_combo.get_active_text();
+       if (str == _("Normal")) {
+               return ARDOUR::Normal;
+       } else if (str == _("Tape")) {
+               return ARDOUR::Destructive;
+       } else {
+               fatal << string_compose (X_("programming error: unknown track mode in add route dialog combo = %1"), str)
+                     << endmsg;
+               /*NOTREACHED*/
+       }
+       /* keep gcc happy */
+       return ARDOUR::Normal;
+}
+
 int
 AddRouteDialog::channels ()
 {
-       return channel_combo_get_channel_count (channel_combo);
+       string str = channel_combo.get_active_text();
+       int chns;
+
+       if (str == _("Mono")) {
+               return 1;
+       } else if (str == _("Stereo")) {
+               return 2;
+       } else if ((chns = PBD::atoi (str)) != 0) {
+               return chns;
+       } 
+
+       return 0;
 }
+