X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fardour%2Fmidi_state_tracker.h;h=f6acb88f238428812849fe13fe904156a8275024;hb=e5c607123588b318f28022488d74790fc1b7bebe;hp=a058121da8559b4f8daa60a72416c640a84113d8;hpb=07be98b3410ac70b3c4451592fb88def678611ef;p=ardour.git diff --git a/libs/ardour/ardour/midi_state_tracker.h b/libs/ardour/ardour/midi_state_tracker.h index a058121da8..f6acb88f23 100644 --- a/libs/ardour/ardour/midi_state_tracker.h +++ b/libs/ardour/ardour/midi_state_tracker.h @@ -21,11 +21,14 @@ #define __ardour_midi_state_tracker_h__ #include - #include "ardour/midi_buffer.h" -namespace ARDOUR { +namespace Evoral { +template class EventSink; +} +namespace ARDOUR { +class MidiSource; /** Tracks played notes, so they can be resolved in potential stuck note * situations (e.g. looping, transport stop, etc). @@ -36,14 +39,24 @@ public: MidiStateTracker(); void track (const MidiBuffer::iterator& from, const MidiBuffer::iterator& to, bool& looped); - void resolve_notes (MidiBuffer& buffer, nframes64_t time); + void add (uint8_t note, uint8_t chn); + void remove (uint8_t note, uint8_t chn); + void resolve_notes (MidiBuffer& buffer, framepos_t time); + void resolve_notes (Evoral::EventSink& buffer, framepos_t time); + void resolve_notes (MidiSource& src, Evoral::MusicalTime time); void dump (std::ostream&); void reset (); + bool empty() const { return _on == 0; } + uint16_t on() const { return _on; } + bool active (uint8_t note, uint8_t channel) { + return _active_notes[(channel*128)+note] > 0; + } private: void track_note_onoffs(const Evoral::MIDIEvent& event); - uint8_t _active_notes[128*16]; + uint8_t _active_notes[128*16]; + uint16_t _on; };