Tweak colouring in the processor list.
[ardour.git] / libs / ardour / ardour / midi_track.h
index a4054e6b00aac5bc657b14c9daf0a7a90618e6d6..3c742bd3cece5173fbdf770ac88aa92caa588a65 100644 (file)
@@ -22,6 +22,7 @@
 
 #include "ardour/track.h"
 #include "ardour/midi_ring_buffer.h"
+#include "ardour/midi_state_tracker.h"
 
 namespace ARDOUR
 {
@@ -30,36 +31,40 @@ class Session;
 class MidiDiskstream;
 class MidiPlaylist;
 class RouteGroup;
+class SMFSource;       
 
 class MidiTrack : public Track
 {
 public:
        MidiTrack (Session&, string name, Route::Flag f = Route::Flag (0), TrackMode m = Normal);
-       MidiTrack (Session&, const XMLNode&);
        ~MidiTrack ();
 
-       int roll (nframes_t nframes, sframes_t start_frame, sframes_t end_frame,
-                       int declick, bool can_record, bool rec_monitors_input);
+       int roll (pframes_t nframes, framepos_t start_frame, framepos_t end_frame,
+                  int declick, bool can_record, bool rec_monitors_input, bool& need_butler);
 
-       void handle_transport_stopped (bool abort, bool did_locate, bool flush_processors);
+       void realtime_handle_transport_stopped ();
 
-       boost::shared_ptr<MidiDiskstream> midi_diskstream() const;
+       void use_new_diskstream ();
+        void set_diskstream (boost::shared_ptr<Diskstream>);
+       void set_record_enabled (bool yn, void *src);
 
-       int use_diskstream (string name);
-       int use_diskstream (const PBD::ID& id);
+       DataType data_type () const {
+               return DataType::MIDI;
+       }
 
-       void set_latency_delay (nframes_t);
+       void set_latency_delay (framecnt_t);
 
-       int export_stuff (BufferSet& bufs, nframes_t nframes, sframes_t end_frame);
+       int export_stuff (BufferSet& bufs, framecnt_t nframes, framepos_t end_frame);
 
-       void freeze (InterThreadInfo&);
+       void freeze_me (InterThreadInfo&);
        void unfreeze ();
-
+        
        boost::shared_ptr<Region> bounce (InterThreadInfo&);
-       boost::shared_ptr<Region>  bounce_range (
-                       nframes_t start, nframes_t end, InterThreadInfo&, bool enable_processing);
+       boost::shared_ptr<Region> bounce_range (
+                       framepos_t start, framepos_t end, InterThreadInfo&, bool enable_processing
+               );
 
-       int set_state(const XMLNode& node);
+       int set_state(const XMLNode&, int version);
 
        void midi_panic(void);
        bool write_immediate_event(size_t size, const uint8_t* buf);
@@ -67,12 +72,12 @@ public:
        /** A control that will send "immediate" events to a MIDI track when twiddled */
        struct MidiControl : public AutomationControl {
                MidiControl(MidiTrack* route, const Evoral::Parameter& param,
-                               boost::shared_ptr<AutomationList> al = boost::shared_ptr<AutomationList>())
+                           boost::shared_ptr<AutomationList> al = boost::shared_ptr<AutomationList>())
                        : AutomationControl (route->session(), param, al)
                        , _route (route)
                {}
 
-               void set_value (float val);
+               void set_value (double val);
 
                MidiTrack* _route;
        };
@@ -82,7 +87,9 @@ public:
 
        bool step_editing() const { return _step_editing; }
        void set_step_editing (bool yn);
-       MidiRingBuffer<nframes_t>& step_edit_ring_buffer() { return _step_edit_ring_buffer; }
+       MidiRingBuffer<framepos_t>& step_edit_ring_buffer() { return _step_edit_ring_buffer; }
+
+        PBD::Signal1<void,bool> StepEditStatusChange;
 
        uint8_t default_channel() const { return _default_channel; }
        void set_default_channel (uint8_t chn);
@@ -90,31 +97,44 @@ public:
        bool midi_thru() const { return _midi_thru; }
        void set_midi_thru (bool yn);
 
+       boost::shared_ptr<SMFSource> write_source (uint32_t n = 0);
+       void set_channel_mode (ChannelMode, uint16_t);
+       ChannelMode get_channel_mode ();
+       uint16_t get_channel_mask ();
+       boost::shared_ptr<MidiPlaylist> midi_playlist ();
+
+       bool bounceable () const {
+               return false;
+       }
+       
+       PBD::Signal2<void, boost::shared_ptr<MidiBuffer>, boost::weak_ptr<MidiSource> > DataRecorded;
+
 protected:
        XMLNode& state (bool full);
-
-       int _set_state (const XMLNode&, bool call_base);
+       
+       int _set_state (const XMLNode&, int, bool call_base);
 
 private:
-       void write_out_of_band_data (
-                       BufferSet& bufs, sframes_t start_frame, sframes_t end_frame, nframes_t nframes);
+       boost::shared_ptr<MidiDiskstream> midi_diskstream () const;
+
+       void write_out_of_band_data (BufferSet& bufs, framepos_t start_frame, framepos_t end_frame, framecnt_t nframes);
 
-       int set_diskstream (boost::shared_ptr<MidiDiskstream> ds);
-       void use_new_diskstream ();
        void set_state_part_two ();
        void set_state_part_three ();
 
-       MidiRingBuffer<nframes_t> _immediate_events;
-       MidiRingBuffer<nframes_t> _step_edit_ring_buffer;
+       MidiRingBuffer<framepos_t> _immediate_events;
+       MidiRingBuffer<framepos_t> _step_edit_ring_buffer;
        NoteMode                  _note_mode;
        bool                      _step_editing;
        uint8_t                   _default_channel;
        bool                      _midi_thru;
 
-
-       int no_roll (nframes_t nframes, sframes_t start_frame, sframes_t end_frame,
+       int no_roll (pframes_t nframes, framepos_t start_frame, framepos_t end_frame,
                        bool state_changing, bool can_record, bool rec_monitors_input);
-       void push_midi_input_to_step_edit_ringbuffer (nframes_t nframes);
+       void push_midi_input_to_step_edit_ringbuffer (framecnt_t nframes);
+
+       void diskstream_data_recorded (boost::shared_ptr<MidiBuffer>, boost::weak_ptr<MidiSource>);
+       PBD::ScopedConnection _diskstream_data_recorded_connection;
 };
 
 } /* namespace ARDOUR*/