summaryrefslogtreecommitdiff
path: root/libs/ardour/ardour/midi_state_tracker.h
diff options
context:
space:
mode:
authorPaul Davis <paul@linuxaudiosystems.com>2009-10-19 17:05:22 +0000
committerPaul Davis <paul@linuxaudiosystems.com>2009-10-19 17:05:22 +0000
commit539a692b0e9d249cab75a2d1c255f8cbef8bcf6b (patch)
tree9c40db2f5651a57bd90e034c8750209915db2363 /libs/ardour/ardour/midi_state_tracker.h
parenta86b994c683b981c395f829082abef67add2424a (diff)
track notes at the region level in MidiPlaylist; resolve them (deliver note offs) if a note spans the end of the region
git-svn-id: svn://localhost/ardour2/branches/3.0@5804 d708f5d6-7413-0410-9779-e7cbd77b26cf
Diffstat (limited to 'libs/ardour/ardour/midi_state_tracker.h')
-rw-r--r--libs/ardour/ardour/midi_state_tracker.h5
1 files changed, 4 insertions, 1 deletions
diff --git a/libs/ardour/ardour/midi_state_tracker.h b/libs/ardour/ardour/midi_state_tracker.h
index a058121da8..7b95772cac 100644
--- a/libs/ardour/ardour/midi_state_tracker.h
+++ b/libs/ardour/ardour/midi_state_tracker.h
@@ -21,11 +21,11 @@
#define __ardour_midi_state_tracker_h__
#include <bitset>
-
#include "ardour/midi_buffer.h"
namespace ARDOUR {
+template <typename T> class MidiRingBuffer;
/** Tracks played notes, so they can be resolved in potential stuck note
* situations (e.g. looping, transport stop, etc).
@@ -36,7 +36,10 @@ public:
MidiStateTracker();
void track (const MidiBuffer::iterator& from, const MidiBuffer::iterator& to, bool& looped);
+ void add (uint8_t note, uint8_t chn);
+ void remove (uint8_t note, uint8_t chn);
void resolve_notes (MidiBuffer& buffer, nframes64_t time);
+ void resolve_notes (MidiRingBuffer<nframes_t>& buffer, nframes64_t time);
void dump (std::ostream&);
void reset ();