X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=libs%2Fardour%2Fardour%2Finternal_send.h;h=8547f73b08ce4c404205ee56f79db15ca85b206d;hb=5fa05b403ca21a6573d07b921dc14f0769dc9fc7;hp=ac184a69bf6b18f7c939cb2e2c89ac38018f1c5f;hpb=47b8fa21699e58f733f0ecb879193092f93c93d8;p=ardour.git diff --git a/libs/ardour/ardour/internal_send.h b/libs/ardour/ardour/internal_send.h index ac184a69bf..8547f73b08 100644 --- a/libs/ardour/ardour/internal_send.h +++ b/libs/ardour/ardour/internal_send.h @@ -25,39 +25,61 @@ namespace ARDOUR { -class InternalSend : public Send +class LIBARDOUR_API InternalSend : public Send { - public: - InternalSend (Session&, boost::shared_ptr, boost::shared_ptr send_to, Delivery::Role role); - InternalSend (Session&, boost::shared_ptr, const XMLNode&); +public: + InternalSend (Session&, boost::shared_ptr, boost::shared_ptr, boost::shared_ptr send_from, boost::shared_ptr send_to, Delivery::Role role = Delivery::Aux, bool ignore_bitslot = false); virtual ~InternalSend (); std::string display_name() const; bool set_name (const std::string&); bool visible() const; - XMLNode& state(bool full); - XMLNode& get_state(void); int set_state(const XMLNode& node, int version); - - void run (BufferSet& bufs, sframes_t start_frame, sframes_t end_frame, nframes_t nframes, bool); + + void cycle_start (pframes_t); + void run (BufferSet& bufs, samplepos_t start_sample, samplepos_t end_sample, double speed, pframes_t nframes, bool); bool feeds (boost::shared_ptr other) const; - 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); - void set_block_size (nframes_t); + int set_block_size (pframes_t); + boost::shared_ptr source_route() const { return _send_from; } boost::shared_ptr target_route() const { return _send_to; } + const PBD::ID& target_id() const { return _send_to_id; } + + BufferSet const & get_buffers () const { + return mixbufs; + } + + bool allow_feedback () const { return _allow_feedback;} + void set_allow_feedback (bool yn); + + void set_can_pan (bool yn); + uint32_t pan_outs () const; + + static PBD::Signal1 CycleStart; + +protected: + XMLNode& state(); - private: - BufferSet mixbufs; - BufferSet* target; +private: + BufferSet mixbufs; + boost::shared_ptr _send_from; boost::shared_ptr _send_to; + bool _allow_feedback; PBD::ID _send_to_id; - sigc::connection connect_c; + PBD::ScopedConnection connect_c; + PBD::ScopedConnection source_connection; + PBD::ScopedConnectionList target_connections; + void send_from_going_away (); void send_to_going_away (); + void send_to_property_changed (const PBD::PropertyChange&); int connect_when_legal (); - int set_our_state (XMLNode const &, int); + void init_gain (); + int use_target (boost::shared_ptr); + void target_io_changed (); }; } // namespace ARDOUR