- (time, MIDI_CMD_NOTE_OFF, 3, buffer, false);
-
- dst.push_back (noteoff);
- _active_notes[channel * 128 + note]--;
+ (MIDI_CMD_NOTE_OFF, time, 3, buffer, false);
+ dst.push_back (noteoff);
+ _active_notes[note + 128 * channel]--;
+ }
+ }
+ }
+ _on = 0;
+}
+
+void
+MidiStateTracker::resolve_notes (Evoral::EventSink<nframes_t> &dst, nframes64_t time)
+{
+ uint8_t buf[3];
+
+ if (!_on) {
+ return;
+ }
+
+ for (int channel = 0; channel < 16; ++channel) {
+ for (int note = 0; note < 128; ++note) {
+ while (_active_notes[note + 128 * channel]) {
+ buf[0] = MIDI_CMD_NOTE_OFF|channel;
+ buf[1] = note;
+ buf[2] = 0;
+ dst.write (time, EventTypeMap::instance().midi_event_type (buf[0]), 3, buf);
+ _active_notes[note + 128 * channel]--;
+ }
+ }
+ }
+ _on = 0;
+}
+
+void
+MidiStateTracker::resolve_notes (MidiSource& src, Evoral::MusicalTime time)
+{
+ if (!_on) {
+ return;
+ }
+
+ /* NOTE: the src must be locked */
+
+ for (int channel = 0; channel < 16; ++channel) {
+ for (int note = 0; note < 128; ++note) {
+ while (_active_notes[note + 128 * channel]) {
+ Evoral::MIDIEvent<Evoral::MusicalTime> ev ((MIDI_CMD_NOTE_OFF|channel), time, 3, 0, true);
+ ev.set_type (MIDI_CMD_NOTE_OFF);
+ ev.set_channel (channel);
+ ev.set_note (note);
+ ev.set_velocity (0);
+ src.append_event_unlocked_beats (ev);
+ _active_notes[note + 128 * channel]--;
+ /* don't stack events up at the same time
+ */
+ time += 1.0/128.0;