X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fardour%2Finternal_send.h;h=8a85fc0f68972703385ac0a73e5efb3b0d4f6709;hb=a4a87f56e9dc8e2351101439aeea7a87064fa146;hp=9bfbc4c659e150df8a2d1dc34ba06ab0f10faf9e;hpb=c0e6f8e4c324c3f44613949b59acd9e864ab263d;p=ardour.git diff --git a/libs/ardour/ardour/internal_send.h b/libs/ardour/ardour/internal_send.h index 9bfbc4c659..8a85fc0f68 100644 --- a/libs/ardour/ardour/internal_send.h +++ b/libs/ardour/ardour/internal_send.h @@ -28,7 +28,7 @@ namespace ARDOUR { class LIBARDOUR_API InternalSend : public Send { public: - InternalSend (Session&, boost::shared_ptr, boost::shared_ptr, boost::shared_ptr send_to, Delivery::Role role); + 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; @@ -40,12 +40,13 @@ class LIBARDOUR_API InternalSend : public Send int set_state(const XMLNode& node, int version); void cycle_start (pframes_t); - void run (BufferSet& bufs, framepos_t start_frame, framepos_t end_frame, pframes_t nframes, bool); + void run (BufferSet& bufs, framepos_t start_frame, framepos_t end_frame, double speed, pframes_t nframes, bool); bool feeds (boost::shared_ptr other) const; bool can_support_io_configuration (const ChanCount& in, ChanCount& out); bool configure_io (ChanCount in, ChanCount out); 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; } @@ -53,6 +54,9 @@ class LIBARDOUR_API InternalSend : public Send 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; @@ -60,11 +64,15 @@ class LIBARDOUR_API InternalSend : public Send private: BufferSet mixbufs; + boost::shared_ptr _send_from; boost::shared_ptr _send_to; + bool _allow_feedback; PBD::ID _send_to_id; 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 ();