X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fardour%2Fmidi_diskstream.h;h=45f01763d8a1ff7e5145ae68ab2ef1419272d1d2;hb=74a604d261b1ecb0f20ee0c69aef7648da3a1d86;hp=661070858184fbad6f4e2a9570747d62cf8b9704;hpb=90220998af4f9683d696b511a09b34034e799093;p=ardour.git diff --git a/libs/ardour/ardour/midi_diskstream.h b/libs/ardour/ardour/midi_diskstream.h index 6610708581..45f01763d8 100644 --- a/libs/ardour/ardour/midi_diskstream.h +++ b/libs/ardour/ardour/midi_diskstream.h @@ -66,12 +66,11 @@ 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 set_record_enabled (bool yn); void set_record_safe (bool yn); - + void reset_tracker (); void resolve_tracker (Evoral::EventSink& buffer, framepos_t time); @@ -128,23 +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 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); 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 (); @@ -172,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;