Rewrote MidiRingBuffer to more efficiently pack data (flat pack stamps, sizes, and...
[ardour.git] / libs / ardour / ardour / midi_source.h
index f1ede9c842d65538d97da3d93b4a3ae4b8d98f2b..dec9536c741c84f2eebe222fe61f0ae9aa503524 100644 (file)
@@ -30,6 +30,7 @@
 
 #include <ardour/source.h>
 #include <ardour/ardour.h>
+#include <ardour/buffer.h>
 #include <pbd/stateful.h>
 #include <pbd/xml++.h>
 
@@ -43,12 +44,12 @@ class MidiRingBuffer;
 class MidiSource : public Source
 {
   public:
-       MidiSource (string name);
-       MidiSource (const XMLNode&);
+       MidiSource (Session& session, string name);
+       MidiSource (Session& session, const XMLNode&);
        virtual ~MidiSource ();
-
-       virtual jack_nframes_t read (MidiRingBuffer& dst, jack_nframes_t start, jack_nframes_t cnt) const;
-       virtual jack_nframes_t write (MidiRingBuffer& src, jack_nframes_t cnt);
+       
+       virtual nframes_t read (MidiRingBuffer& dst, nframes_t start, nframes_t cnt, nframes_t stamp_offset) const;
+       virtual nframes_t write (MidiRingBuffer& src, nframes_t cnt);
 
        virtual void mark_for_remove() = 0;
        virtual void mark_streaming_write_completed () {}
@@ -62,16 +63,14 @@ class MidiSource : public Source
        static sigc::signal<void,MidiSource*> MidiSourceCreated;
               
        // The MIDI equivalent to "peaks"
-       static int  start_view_data_thread ();
-       static void stop_view_data_thread ();
-       mutable sigc::signal<void,jack_nframes_t,jack_nframes_t> ViewDataRangeReady;
+       mutable sigc::signal<void,boost::shared_ptr<MidiBuffer>,nframes_t,nframes_t> ViewDataRangeReady;
        
        XMLNode& get_state ();
        int set_state (const XMLNode&);
 
   protected:
-       virtual jack_nframes_t read_unlocked (MidiRingBuffer& dst, jack_nframes_t start, jack_nframes_t cnt) const = 0;
-       virtual jack_nframes_t write_unlocked (MidiRingBuffer& dst, jack_nframes_t cnt) = 0;
+       virtual nframes_t read_unlocked (MidiRingBuffer& dst, nframes_t start, nframes_t cnt, nframes_t stamp_offset) const = 0;
+       virtual nframes_t write_unlocked (MidiRingBuffer& dst, nframes_t cnt) = 0;
        
        mutable Glib::Mutex _lock;
        string              _captured_for;