X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fardour%2Finternal_send.h;h=71d8049cae2e8830e3ce92af7c3d34feb1f6e487;hb=6d49e245035fe3b078b5e58825d81f20bce9511d;hp=a06bf399065a8c646712813d78a6c702662795b6;hpb=8c9749e42faf7808034ed8b7afce4a2fe6dc6f33;p=ardour.git diff --git a/libs/ardour/ardour/internal_send.h b/libs/ardour/ardour/internal_send.h index a06bf39906..71d8049cae 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 = Delivery::Aux, bool ignore_bitslot = false); + 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; @@ -46,6 +46,7 @@ class LIBARDOUR_API InternalSend : public Send 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; } @@ -60,11 +61,14 @@ class LIBARDOUR_API InternalSend : public Send private: BufferSet mixbufs; + boost::shared_ptr _send_from; boost::shared_ptr _send_to; 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 ();