X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fardour%2Fmidi_state_tracker.h;h=669093142227270ab7736ba1edd213b450b4d181;hb=67ba18d15430f3e639d97a8a30717d7ff009bec1;hp=f6acb88f238428812849fe13fe904156a8275024;hpb=73192bc1a7ea55fa1864dc3826845b15c00dd2ec;p=ardour.git diff --git a/libs/ardour/ardour/midi_state_tracker.h b/libs/ardour/ardour/midi_state_tracker.h index f6acb88f23..6690931422 100644 --- a/libs/ardour/ardour/midi_state_tracker.h +++ b/libs/ardour/ardour/midi_state_tracker.h @@ -20,7 +20,8 @@ #ifndef __ardour_midi_state_tracker_h__ #define __ardour_midi_state_tracker_h__ -#include +#include + #include "ardour/midi_buffer.h" namespace Evoral { @@ -28,33 +29,38 @@ 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 track (const MidiBuffer::const_iterator& from, const MidiBuffer::const_iterator& to); + void track (const uint8_t* evbuf); 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 resolve_notes (MidiSource& src, const Glib::Threads::Mutex::Lock& lock, Evoral::Beats 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; - } + bool active (uint8_t note, uint8_t channel) { + return _active_notes[(channel*128)+note] > 0; + } -private: - void track_note_onoffs(const Evoral::MIDIEvent& event); + template + void track (const Evoral::Event