X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fardour%2Fsend.h;h=002397f0cd139ac3500ee9a2f636f0c854982272;hb=f756dc69f41c6950f5c573401ebbd767be493f01;hp=8b39d12727e61cb2efeee40ac848c18444dc58f4;hpb=f6fdd8dcbf41f864e9f0cc32dabe81fe3533ddfe;p=ardour.git diff --git a/libs/ardour/ardour/send.h b/libs/ardour/ardour/send.h index 8b39d12727..002397f0cd 100644 --- a/libs/ardour/ardour/send.h +++ b/libs/ardour/ardour/send.h @@ -25,19 +25,19 @@ #include "pbd/stateful.h" #include "ardour/ardour.h" -#include "ardour/audioengine.h" #include "ardour/delivery.h" +#include "ardour/delayline.h" namespace ARDOUR { class PeakMeter; class Amp; +class GainControl; -class Send : public Delivery +class LIBARDOUR_API Send : public Delivery { public: - Send (Session&, boost::shared_ptr, Delivery::Role r = Delivery::Send); - Send (Session&, boost::shared_ptr, const XMLNode&, int version = 3000, Delivery::Role r = Delivery::Send); + Send (Session&, boost::shared_ptr pannable, boost::shared_ptr, Delivery::Role r = Delivery::Send, bool ignore_bitslot = false); virtual ~Send (); uint32_t bit_slot() const { return _bitslot; } @@ -46,39 +46,60 @@ class Send : public Delivery boost::shared_ptr amp() const { return _amp; } boost::shared_ptr meter() const { return _meter; } + boost::shared_ptr gain_control() const { return _gain_control; } bool metering() const { return _metering; } void set_metering (bool yn) { _metering = yn; } - XMLNode& state(bool full); - XMLNode& get_state(void); + XMLNode& state (bool full); + XMLNode& get_state (); int set_state(const XMLNode&, int version); + PBD::Signal0 SelfDestruct; + void set_remove_on_disconnect (bool b) { _remove_on_disconnect = b; } + bool remove_on_disconnect () const { return _remove_on_disconnect; } + uint32_t pans_required() const { return _configured_input.n_audio(); } - void run (BufferSet& bufs, sframes_t start_frame, sframes_t end_frame, nframes_t nframes, bool); + void run (BufferSet& bufs, framepos_t start_frame, framepos_t end_frame, double speed, pframes_t nframes, bool); - bool can_support_io_configuration (const ChanCount& in, ChanCount& out) const; + bool can_support_io_configuration (const ChanCount& in, ChanCount& out); bool configure_io (ChanCount in, ChanCount out); + /* latency compensation */ + void set_delay_in (framecnt_t); + void set_delay_out (framecnt_t); + framecnt_t get_delay_in () const { return _delay_in; } + framecnt_t get_delay_out () const { return _delay_out; } + void activate (); void deactivate (); bool set_name (const std::string& str); static uint32_t how_many_sends(); - static void make_unique (XMLNode &, Session &); + static std::string name_and_id_new_send (Session&, Delivery::Role r, uint32_t&, bool); protected: bool _metering; + boost::shared_ptr _gain_control; boost::shared_ptr _amp; boost::shared_ptr _meter; + boost::shared_ptr _delayline; private: /* disallow copy construction */ Send (const Send&); + void panshell_changed (); + void snd_output_changed (IOChange, void*); + + int set_state_2X (XMLNode const &, int); uint32_t _bitslot; + + framecnt_t _delay_in; + framecnt_t _delay_out; + bool _remove_on_disconnect; }; } // namespace ARDOUR