Revert "Fix occasional MIDI read crash."
authorDavid Robillard <d@drobilla.net>
Tue, 30 Dec 2014 18:03:22 +0000 (13:03 -0500)
committerDavid Robillard <d@drobilla.net>
Tue, 30 Dec 2014 18:03:22 +0000 (13:03 -0500)
This reverts commit ec947ff8fd2cf229284f757b8bd6b0f96cbd6383.

libs/ardour/midi_source.cc

index c63a262a53c0fe4bdd2f17fb2c41eee5fa14b3a5..1b1cf20c68b34b528cf7978ca86b762c77712221 100644 (file)
@@ -200,10 +200,11 @@ MidiSource::midi_read (const Lock&                        lm,
 
        if (_model) {
                // Find appropriate model iterator
-               Evoral::Sequence<Evoral::MusicalTime>::const_iterator i = _model_iter;
+               Evoral::Sequence<Evoral::MusicalTime>::const_iterator& i = _model_iter;
                if (_last_read_end == 0 || start != _last_read_end || !_model_iter_valid) {
                        // Cached iterator is invalid, search for the first event past start
-                       i = _model->begin(converter.from(start), false, filtered);
+                       i                 = _model->begin(converter.from(start), false, filtered);
+                       _model_iter_valid = true;
                }
 
                _last_read_end = start + cnt;
@@ -229,8 +230,6 @@ MidiSource::midi_read (const Lock&                        lm,
                                break;
                        }
                }
-               _model_iter       = i;
-               _model_iter_valid = true;
                return cnt;
        } else {
                return read_unlocked (lm, dst, source_start, start, cnt, tracker);