summaryrefslogtreecommitdiff
path: root/gtk2_ardour/export_format_selector.cc
diff options
context:
space:
mode:
authorAdrian Knoth <adi@drcomp.erfurt.thur.de>2013-06-19 18:52:06 +0200
committerAdrian Knoth <adi@drcomp.erfurt.thur.de>2013-06-19 18:52:06 +0200
commit93349141379343c91ea0ec2127d694f6cf2e230e (patch)
tree78c2d1b561f0a827b434f496412ea84020c3f77e /gtk2_ardour/export_format_selector.cc
parentb407b753f718d9244f16c23eb31a137be00f230e (diff)
Prompt the user for confirmation before removing an export format.
Requested by Radio SRB (http://srb.fm)
Diffstat (limited to 'gtk2_ardour/export_format_selector.cc')
-rw-r--r--gtk2_ardour/export_format_selector.cc21
1 files changed, 18 insertions, 3 deletions
diff --git a/gtk2_ardour/export_format_selector.cc b/gtk2_ardour/export_format_selector.cc
index f66d13d62e..a2ba3f352f 100644
--- a/gtk2_ardour/export_format_selector.cc
+++ b/gtk2_ardour/export_format_selector.cc
@@ -43,7 +43,7 @@ ExportFormatSelector::ExportFormatSelector () :
new_button.set_name ("PaddedButton");
edit_button.signal_clicked().connect (sigc::hide_return (sigc::bind (sigc::mem_fun (*this, &ExportFormatSelector::open_edit_dialog), false)));
- remove_button.signal_clicked().connect (sigc::mem_fun (*this, &ExportFormatSelector::remove_format));
+ remove_button.signal_clicked().connect (sigc::bind (sigc::mem_fun (*this, &ExportFormatSelector::remove_format), true));
new_button.signal_clicked().connect (sigc::mem_fun (*this, &ExportFormatSelector::add_new_format));
/* Format combo */
@@ -122,7 +122,7 @@ ExportFormatSelector::add_new_format ()
FormatPtr new_format = state->format = NewFormat (state->format);
if (open_edit_dialog (true) != Gtk::RESPONSE_APPLY) {
- remove_format();
+ remove_format(false);
if (state->list->empty()) {
state->format.reset ();
}
@@ -130,11 +130,26 @@ ExportFormatSelector::add_new_format ()
}
void
-ExportFormatSelector::remove_format ()
+ExportFormatSelector::remove_format (bool called_from_button)
{
+ if (called_from_button) {
+ Gtk::MessageDialog dialog (_("Do you really want to remove the format?"),
+ false,
+ Gtk::MESSAGE_QUESTION,
+ Gtk::BUTTONS_YES_NO);
+
+ if (Gtk::RESPONSE_YES != dialog.run ()) {
+ /* User has selected "no" or closed the dialog, better
+ * abort
+ */
+ return;
+ }
+ }
+
FormatPtr remove;
Gtk::TreeModel::iterator it = format_combo.get_active();
remove = it->get_value (format_cols.format);
+
FormatRemoved (remove);
}