summaryrefslogtreecommitdiff
path: root/libs/ardour/session_midi.cc
diff options
context:
space:
mode:
authorRobin Gareus <robin@gareus.org>2014-09-11 19:29:55 +0200
committerRobin Gareus <robin@gareus.org>2014-09-11 19:30:33 +0200
commitf3f80900f14ae8f8d577f3eb098b5064d4aa0859 (patch)
tree9be39cf41986f10a099a324b916631c83f8b2c69 /libs/ardour/session_midi.cc
parent01974b576995b8a67158fb3d416a1ca8ca224cfd (diff)
fix crash at session close/exit if a midi-control-surface is used
The "real" problem was that MidiControlUI is destroyed while there are still MIDIControllables around that still have a signal connection to a Controllable: controllable->Destroyed(..., MidiControlUI::instance()) If a Contrallable is deleted after the MidiControlUI event loop is gone, the Destroyed() signal can create odd situations...
Diffstat (limited to 'libs/ardour/session_midi.cc')
-rw-r--r--libs/ardour/session_midi.cc1
1 files changed, 1 insertions, 0 deletions
diff --git a/libs/ardour/session_midi.cc b/libs/ardour/session_midi.cc
index 639ea399d3..47c7bd4c40 100644
--- a/libs/ardour/session_midi.cc
+++ b/libs/ardour/session_midi.cc
@@ -597,6 +597,7 @@ Session::send_song_position_pointer (framepos_t)
int
Session::start_midi_thread ()
{
+ if (midi_control_ui) { return 0; }
midi_control_ui = new MidiControlUI (*this);
midi_control_ui->run ();
return 0;