X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fardour%2Fmidi_state_tracker.h;h=046e77f38c83bbd9973a92d0924fb7dba26c0ff9;hb=c96ec968c7bb4b1d7c358f522a49b0685c022920;hp=f5a44788dba3a26ac54b3620d06f5c125a09a0ee;hpb=bb9cc45cd22af67ac275a5e73accbe14fee664d8;p=ardour.git diff --git a/libs/ardour/ardour/midi_state_tracker.h b/libs/ardour/ardour/midi_state_tracker.h index f5a44788db..046e77f38c 100644 --- a/libs/ardour/ardour/midi_state_tracker.h +++ b/libs/ardour/ardour/midi_state_tracker.h @@ -20,30 +20,43 @@ #ifndef __ardour_midi_state_tracker_h__ #define __ardour_midi_state_tracker_h__ -#include - #include "ardour/midi_buffer.h" +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). */ -class MidiStateTracker +class LIBARDOUR_API MidiStateTracker { public: MidiStateTracker(); - void track (const MidiBuffer::iterator& from, const MidiBuffer::iterator& to, bool& looped); - void resolve_notes (MidiBuffer& buffer, nframes_t time); + void track (const MidiBuffer::iterator& from, const MidiBuffer::iterator& to); + 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; };