summaryrefslogtreecommitdiff
path: root/libs/ardour/midi_state_tracker.cc
diff options
context:
space:
mode:
authorPaul Davis <paul@linuxaudiosystems.com>2009-10-24 13:26:56 +0000
committerPaul Davis <paul@linuxaudiosystems.com>2009-10-24 13:26:56 +0000
commitf8fe64a91e7ae7f6ac761e8ae16a485ed70fb994 (patch)
tree7b2942e9bdbb4f1b52d53640b62411c8da9d4e0b /libs/ardour/midi_state_tracker.cc
parentdbc75e074912fc3647899711e838d4e5b675e175 (diff)
(FULL commit) start of a nominal debug tracing system, with 64 bits available for flags; track notes by region in MidiPlaylist, and resolve them if they are left hanging at region boundaries. note: MIDI playback is still not working 100% though its better now.
git-svn-id: svn://localhost/ardour2/branches/3.0@5903 d708f5d6-7413-0410-9779-e7cbd77b26cf
Diffstat (limited to 'libs/ardour/midi_state_tracker.cc')
-rw-r--r--libs/ardour/midi_state_tracker.cc43
1 files changed, 31 insertions, 12 deletions
diff --git a/libs/ardour/midi_state_tracker.cc b/libs/ardour/midi_state_tracker.cc
index 0ddafc3fed..03ac16ca87 100644
--- a/libs/ardour/midi_state_tracker.cc
+++ b/libs/ardour/midi_state_tracker.cc
@@ -35,17 +35,16 @@ void
MidiStateTracker::reset ()
{
memset (_active_notes, 0, sizeof (_active_notes));
+ _on = 0;
}
void
MidiStateTracker::track_note_onoffs (const Evoral::MIDIEvent<MidiBuffer::TimeType>& event)
{
if (event.is_note_on()) {
- _active_notes [event.note() + 128 * event.channel()]++;
+ add (event.note(), event.channel());
} else if (event.is_note_off()){
- if (_active_notes[event.note() + 128 * event.channel()]) {
- _active_notes [event.note() + 128 * event.channel()]--;
- }
+ remove (event.note(), event.channel());
}
}
@@ -53,13 +52,23 @@ void
MidiStateTracker::add (uint8_t note, uint8_t chn)
{
++_active_notes[note + 128 * chn];
+ ++_on;
}
void
MidiStateTracker::remove (uint8_t note, uint8_t chn)
{
- if (_active_notes[note + 128 * chn]) {
- --_active_notes[note + 128 * chn];
+ switch (_active_notes[note + 128 * chn]) {
+ case 0:
+ break;
+ case 1:
+ --_on;
+ _active_notes [note + 128 * chn] = 0;
+ break;
+ default:
+ --_active_notes [note + 128 * chn];
+ break;
+
}
}
@@ -82,35 +91,45 @@ MidiStateTracker::track (const MidiBuffer::iterator &from, const MidiBuffer::ite
void
MidiStateTracker::resolve_notes (MidiBuffer &dst, nframes64_t time)
{
+ if (!_on) {
+ return;
+ }
+
for (int channel = 0; channel < 16; ++channel) {
for (int note = 0; note < 128; ++note) {
- while (_active_notes[channel * 128 + note]) {
+ while (_active_notes[note + 128 * channel]) {
uint8_t buffer[3] = { MIDI_CMD_NOTE_OFF | channel, note, 0 };
Evoral::MIDIEvent<MidiBuffer::TimeType> noteoff
(time, MIDI_CMD_NOTE_OFF, 3, buffer, false);
dst.push_back (noteoff);
-
- _active_notes[channel * 128 + note]--;
+ _active_notes[note + 128 * channel]--;
}
}
}
+ _on = 0;
}
void
-MidiStateTracker::resolve_notes (MidiRingBuffer<nframes_t> &dst, nframes64_t time)
+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[channel * 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[channel * 128 + note]--;
+ _active_notes[note + 128 * channel]--;
}
}
}
+ _on = 0;
}
void