Consolidate PinDialog Session/recording checks
[ardour.git] / gtk2_ardour / save_as_dialog.cc
index 2f9c7c517f66040f11a8f90d963f65763fb8fbdb..eaee07764cd7f54c1f9332e3c776d2807dbf1272 100644 (file)
@@ -23,7 +23,7 @@
 
 #include "save_as_dialog.h"
 
-#include "i18n.h"
+#include "pbd/i18n.h"
 
 using namespace std;
 using namespace Gtk;
@@ -39,7 +39,7 @@ SaveAsDialog::SaveAsDialog ()
        VBox* vbox = get_vbox();
 
        vbox->set_spacing (6);
-       
+
        HBox* hbox;
        Label* label;
 
@@ -62,7 +62,7 @@ SaveAsDialog::SaveAsDialog ()
        VBox* sub_vbox = manage (new VBox);
        HBox* sub_hbox = manage (new HBox);
        HBox* empty = manage (new HBox);
-       
+
        sub_vbox->pack_start (copy_media_button, false, false);
        sub_vbox->pack_start (copy_external_button, false, false);
 
@@ -73,20 +73,22 @@ SaveAsDialog::SaveAsDialog ()
 
        vbox->pack_start (no_include_media_button, false, false);
        vbox->pack_start (*sub_hbox, false, false);
-       
+
        switch_to_button.set_active (true);
        copy_media_button.set_active (true);
-       
+
        vbox->show_all ();
 
        add_button (Stock::CANCEL, RESPONSE_CANCEL);
        add_button (Stock::OK, RESPONSE_OK);
 
        no_include_media_button.signal_toggled ().connect (sigc::mem_fun (*this, &SaveAsDialog::no_include_toggled));
-       
+
        new_parent_folder_selector.set_action (FILE_CHOOSER_ACTION_SELECT_FOLDER);
-       new_parent_folder_selector.set_current_folder (Glib::get_home_dir());
+       new_parent_folder_selector.set_current_folder (Config->get_default_session_parent_dir ());
        new_name_entry.signal_changed().connect (sigc::mem_fun (*this, &SaveAsDialog::name_entry_changed));
+       new_parent_folder_selector.signal_current_folder_changed().connect (sigc::mem_fun (*this, &SaveAsDialog::name_entry_changed));
+       new_parent_folder_selector.signal_selection_changed().connect (sigc::mem_fun (*this, &SaveAsDialog::name_entry_changed));
        set_response_sensitive (RESPONSE_OK, false);
 }
 
@@ -157,6 +159,13 @@ SaveAsDialog::clear_name ()
        set_response_sensitive (RESPONSE_OK, false);
 }
 
+void
+SaveAsDialog::set_name (std::string name)
+{
+       new_name_entry.set_text (name);
+       name_entry_changed ();
+}
+
 bool
 SaveAsDialog::include_media () const
 {