X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fardour%2Fmidi_diskstream.h;h=45f01763d8a1ff7e5145ae68ab2ef1419272d1d2;hb=331bfef416b502c63a0498270a2bdcf7777f9fe0;hp=fea758d6220b054e250f08ef92fd1906a347dc0c;hpb=2588b1cac9a50353c65c671ee2a5efe569b96c36;p=ardour.git diff --git a/libs/ardour/ardour/midi_diskstream.h b/libs/ardour/ardour/midi_diskstream.h index fea758d622..45f01763d8 100644 --- a/libs/ardour/ardour/midi_diskstream.h +++ b/libs/ardour/ardour/midi_diskstream.h @@ -38,6 +38,7 @@ #include "ardour/diskstream.h" #include "ardour/midi_buffer.h" #include "ardour/utils.h" +#include "ardour/interpolation.h" struct tm; @@ -65,12 +66,13 @@ class LIBARDOUR_API MidiDiskstream : public Diskstream float playback_buffer_load() const; float capture_buffer_load() const; - void get_playback (MidiBuffer& dst, framecnt_t); - void flush_playback (framepos_t, framepos_t); + void flush_playback (framepos_t, framepos_t); void set_record_enabled (bool yn); - + void set_record_safe (bool yn); + void reset_tracker (); + void resolve_tracker (Evoral::EventSink& buffer, framepos_t time); boost::shared_ptr midi_playlist (); @@ -125,21 +127,22 @@ class LIBARDOUR_API MidiDiskstream : public Diskstream protected: friend class MidiTrack; friend class Auditioner; + int seek (framepos_t which_sample, bool complete_refill = false); + int _do_refill_with_alloc (bool one_chunk_only); + int process (BufferSet&, framepos_t transport_frame, pframes_t nframes, framecnt_t &, bool need_diskstream); + frameoffset_t calculate_playback_distance (pframes_t nframes); + bool commit (framecnt_t nframes); - int process (BufferSet&, framepos_t transport_frame, pframes_t nframes, framecnt_t &, bool need_diskstream); - frameoffset_t calculate_playback_distance (pframes_t nframes); - bool commit (framecnt_t nframes); static framecnt_t midi_readahead; private: + void get_playback (MidiBuffer& dst, framecnt_t); /* The two central butler operations */ int do_flush (RunContext context, bool force = false); int do_refill (); - int do_refill_with_alloc(); - int read (framepos_t& start, framecnt_t cnt, bool reversed); void finish_capture (); @@ -167,7 +170,7 @@ class LIBARDOUR_API MidiDiskstream : public Diskstream bool prep_record_enable (); bool prep_record_disable (); - + MidiRingBuffer* _playback_buf; MidiRingBuffer* _capture_buf; boost::weak_ptr _source_port; @@ -184,6 +187,8 @@ class LIBARDOUR_API MidiDiskstream : public Diskstream */ MidiBuffer _gui_feed_buffer; mutable Glib::Threads::Mutex _gui_feed_buffer_mutex; + + CubicMidiInterpolation interpolation; }; }; /* namespace ARDOUR */