X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fardour%2Fexport_channel.h;h=8f4d8fc27cf3e47dd8bfe459c9af8d247ed125aa;hb=e5a181c323243a03338f5a9934a5df254986370d;hp=f3244095a3125cdb55b0aaee78bb54ee5d6aada1;hpb=9884773eea9764b6dacd3ade6a1d49cf389fe398;p=ardour.git diff --git a/libs/ardour/ardour/export_channel.h b/libs/ardour/ardour/export_channel.h index f3244095a3..8f4d8fc27c 100644 --- a/libs/ardour/ardour/export_channel.h +++ b/libs/ardour/ardour/export_channel.h @@ -22,11 +22,13 @@ #define __ardour_export_channel_h__ #include +#include #include #include #include "pbd/signals.h" +#include "pbd/ringbuffer.h" #include "ardour/buffer_set.h" #include "ardour/export_pointers.h" @@ -40,15 +42,15 @@ class AudioRegion; class CapturingProcessor; /// Export channel base class interface for different source types -class ExportChannel : public boost::less_than_comparable +class LIBARDOUR_API ExportChannel : public boost::less_than_comparable { public: virtual ~ExportChannel () {} - virtual void set_max_buffer_size(framecnt_t) { } + virtual void set_max_buffer_size(samplecnt_t) { } - virtual void read (Sample const *& data, framecnt_t frames) const = 0; + virtual void read (Sample const *& data, samplecnt_t samples) const = 0; virtual bool empty () const = 0; /// Adds state to node passed @@ -62,15 +64,17 @@ class ExportChannel : public boost::less_than_comparable }; /// Basic export channel that reads from AudioPorts -class PortExportChannel : public ExportChannel +class LIBARDOUR_API PortExportChannel : public ExportChannel { public: typedef std::set > PortSet; PortExportChannel (); - void set_max_buffer_size(framecnt_t frames); + ~PortExportChannel (); - void read (Sample const *& data, framecnt_t frames) const; + void set_max_buffer_size(samplecnt_t samples); + + void read (Sample const *& data, samplecnt_t samples) const; bool empty () const { return ports.empty(); } void get_state (XMLNode * node) const; @@ -83,13 +87,14 @@ class PortExportChannel : public ExportChannel private: PortSet ports; - boost::scoped_array buffer; - framecnt_t buffer_size; + samplecnt_t _buffer_size; + boost::scoped_array _buffer; + std::list > > _delaylines; }; /// Handles RegionExportChannels and does actual reading from region -class RegionExportChannelFactory +class LIBARDOUR_API RegionExportChannelFactory { public: enum Type { @@ -103,23 +108,23 @@ class RegionExportChannelFactory ~RegionExportChannelFactory (); ExportChannelPtr create (uint32_t channel); - void read (uint32_t channel, Sample const *& data, framecnt_t frames_to_read); + void read (uint32_t channel, Sample const *& data, samplecnt_t samples_to_read); private: - int new_cycle_started (framecnt_t) { buffers_up_to_date = false; return 0; } - void update_buffers (framecnt_t frames); + int new_cycle_started (samplecnt_t) { buffers_up_to_date = false; return 0; } + void update_buffers (samplecnt_t samples); AudioRegion const & region; AudioTrack & track; Type type; - framecnt_t frames_per_cycle; + samplecnt_t samples_per_cycle; size_t n_channels; BufferSet buffers; bool buffers_up_to_date; - framecnt_t region_start; - framecnt_t position; + samplecnt_t region_start; + samplecnt_t position; boost::scoped_array mixdown_buffer; boost::scoped_array gain_buffer; @@ -128,12 +133,12 @@ class RegionExportChannelFactory }; /// Export channel that reads from region channel -class RegionExportChannel : public ExportChannel +class LIBARDOUR_API RegionExportChannel : public ExportChannel { friend class RegionExportChannelFactory; public: - void read (Sample const *& data, framecnt_t frames_to_read) const { factory.read (channel, data, frames_to_read); } + void read (Sample const *& data, samplecnt_t samples_to_read) const { factory.read (channel, data, samples_to_read); } void get_state (XMLNode * /*node*/) const {}; void set_state (XMLNode * /*node*/, Session & /*session*/) {}; bool empty () const { return false; } @@ -152,7 +157,7 @@ class RegionExportChannel : public ExportChannel }; /// Export channel for exporting from different positions in a route -class RouteExportChannel : public ExportChannel +class LIBARDOUR_API RouteExportChannel : public ExportChannel { class ProcessorRemover; // fwd declaration @@ -164,9 +169,9 @@ class RouteExportChannel : public ExportChannel static void create_from_route(std::list & result, boost::shared_ptr route); public: // ExportChannel interface - void set_max_buffer_size(framecnt_t frames); + void set_max_buffer_size(samplecnt_t samples); - void read (Sample const *& data, framecnt_t frames) const; + void read (Sample const *& data, samplecnt_t samples) const; bool empty () const { return false; } void get_state (XMLNode * node) const;