summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gtk2_ardour/ardour_ui.cc7
-rw-r--r--gtk2_ardour/ardour_ui_dependents.cc7
-rw-r--r--libs/ardour/route.cc10
3 files changed, 16 insertions, 8 deletions
diff --git a/gtk2_ardour/ardour_ui.cc b/gtk2_ardour/ardour_ui.cc
index 630716b4a1..c51df14a74 100644
--- a/gtk2_ardour/ardour_ui.cc
+++ b/gtk2_ardour/ardour_ui.cc
@@ -775,8 +775,15 @@ If you still wish to quit, please use the\n\n\
}
}
+ second_connection.disconnect ();
+ point_one_second_connection.disconnect ();
+ point_oh_five_second_connection.disconnect ();
+ point_zero_one_second_connection.disconnect();
+
// session->set_deletion_in_progress ();
+ session->remove_pending_capture_state ();
delete session;
+ session = 0;
}
ArdourDialog::close_all_dialogs ();
diff --git a/gtk2_ardour/ardour_ui_dependents.cc b/gtk2_ardour/ardour_ui_dependents.cc
index 0850d0d707..9a9a575e73 100644
--- a/gtk2_ardour/ardour_ui_dependents.cc
+++ b/gtk2_ardour/ardour_ui_dependents.cc
@@ -50,12 +50,6 @@ using namespace ARDOUR;
void
ARDOUR_UI::shutdown ()
{
- if (session) {
- /* we're exiting cleanly, so remove any auto-save data */
- session->remove_pending_capture_state ();
- session = 0;
- }
-
ui_config->save_state();
}
@@ -124,6 +118,7 @@ ARDOUR_UI::toggle_editor_mixer_on_top ()
}
}
+/** The main editor window has been closed */
gint
ARDOUR_UI::exit_on_main_window_close (GdkEventAny * /*ev*/)
{
diff --git a/libs/ardour/route.cc b/libs/ardour/route.cc
index 8d7c170759..912e80c0ea 100644
--- a/libs/ardour/route.cc
+++ b/libs/ardour/route.cc
@@ -163,8 +163,14 @@ Route::~Route ()
{
Metering::disconnect (_meter_connection);
- clear_processors (PreFader);
- clear_processors (PostFader);
+ /* don't use clear_processors here, as it depends on the session which may
+ be half-destroyed by now */
+
+ Glib::RWLock::WriterLock lm (_processor_lock);
+ for (ProcessorList::iterator i = _processors.begin(); i != _processors.end(); ++i) {
+ (*i)->drop_references ();
+ }
+ _processors.clear ();
}
void