Optimize automation-event process splitting
[ardour.git] / libs / ardour / midi_stretch.cc
index 0e75cdca1d25a02acf03a5a1fb788fb69b3a4f90..d7facbb0f185dd2becfff035ad41be304465ef47 100644 (file)
@@ -26,7 +26,7 @@
 #include "ardour/midi_stretch.h"
 #include "ardour/types.h"
 
-#include "i18n.h"
+#include "pbd/i18n.h"
 
 using namespace std;
 using namespace ARDOUR;
@@ -76,7 +76,10 @@ MidiStretch::run (boost::shared_ptr<Region> r, Progress*)
                return -1;
 
        boost::shared_ptr<MidiSource> src = region->midi_source(0);
-       src->load_model(Glib::Threads::Mutex::Lock(src->mutex()));
+       {
+               Source::Lock lock(src->mutex());
+               src->load_model(lock);
+       }
 
        boost::shared_ptr<MidiModel> old_model = src->model();
 
@@ -105,14 +108,14 @@ MidiStretch::run (boost::shared_ptr<Region> r, Progress*)
                new_model->append(ev, Evoral::next_event_id());
        }
 
-       new_model->end_write (Evoral::Sequence<Evoral::MusicalTime>::DeleteStuckNotes);
+       new_model->end_write (Evoral::Sequence<Temporal::Beats>::DeleteStuckNotes);
        new_model->set_edited (true);
 
        new_src->copy_interpolation_from (src);
 
        const int ret = finish (region, nsrcs, new_name);
-
-       results[0]->set_length((framecnt_t) floor (r->length() * _request.time_fraction));
+       /* non-musical */
+       results[0]->set_length((samplecnt_t) floor (r->length() * _request.time_fraction), 0);
 
        return ret;
 }