diff options
author | Paul Davis <paul@linuxaudiosystems.com> | 2018-07-05 13:34:47 -0400 |
---|---|---|
committer | Paul Davis <paul@linuxaudiosystems.com> | 2018-07-05 13:45:17 -0400 |
commit | 027d0efc2d949d7d5b1bb83560d17ffca5ba60d5 (patch) | |
tree | a9e63ef246e13730e68fdd2954af20a82f4176a8 /libs/ardour/smf_source.cc | |
parent | 1a25672239d66ac53f91f0bcbed1955f0c959931 (diff) |
catch various libsmf errors rethrown as exceptions
Diffstat (limited to 'libs/ardour/smf_source.cc')
-rw-r--r-- | libs/ardour/smf_source.cc | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/libs/ardour/smf_source.cc b/libs/ardour/smf_source.cc index 1c994b6eb3..7da864161b 100644 --- a/libs/ardour/smf_source.cc +++ b/libs/ardour/smf_source.cc @@ -548,6 +548,7 @@ SMFSource::mark_midi_streaming_write_completed (const Lock& lm, Evoral::Sequence MidiSource::mark_midi_streaming_write_completed (lm, stuck_notes_option, when); if (!writable()) { + cerr << "not writable\n"; warning << string_compose ("attempt to write to unwritable SMF file %1", _path) << endmsg; return; } @@ -556,7 +557,11 @@ SMFSource::mark_midi_streaming_write_completed (const Lock& lm, Evoral::Sequence _model->set_edited(false); } - Evoral::SMF::end_write (_path); + try { + Evoral::SMF::end_write (_path); + } catch (std::exception & e) { + error << string_compose (_("Exception while writing %1, file may be corrupt/unusable"), _path) << endmsg; + } /* data in the file now, not removable */ |