diff options
author | Paul Davis <paul@linuxaudiosystems.com> | 2009-06-09 20:21:19 +0000 |
---|---|---|
committer | Paul Davis <paul@linuxaudiosystems.com> | 2009-06-09 20:21:19 +0000 |
commit | e6eb059576eefd9a26c177627ae7dd3ba2feb727 (patch) | |
tree | 536ce6ee456f2306bb0346a51ede0a4aa64a8e63 /libs/ardour/ardour/send.h | |
parent | 9bd274bfdee62c9cc0e5752d2a72027d2c732cd0 (diff) |
the big Route structure refactor. !!!! THIS WILL ***NOT LOAD*** PRIOR 3.0 or 2.X SESSIONS !!!! BREAKAGE IS EXPECTED !!!! IF YOU HAVE AND NEED A WORKING 3.0 DO **NOT** UPDATE. !!!! otherwise, update and enjoy the steadily emerging joys of this major reworking of ardour internals
git-svn-id: svn://localhost/ardour2/branches/3.0@5137 d708f5d6-7413-0410-9779-e7cbd77b26cf
Diffstat (limited to 'libs/ardour/ardour/send.h')
-rw-r--r-- | libs/ardour/ardour/send.h | 26 |
1 files changed, 19 insertions, 7 deletions
diff --git a/libs/ardour/ardour/send.h b/libs/ardour/ardour/send.h index b47263b547..302f512c9c 100644 --- a/libs/ardour/ardour/send.h +++ b/libs/ardour/ardour/send.h @@ -23,40 +23,52 @@ #include <sigc++/signal.h> #include <string> - #include "pbd/stateful.h" + #include "ardour/ardour.h" #include "ardour/audioengine.h" #include "ardour/delivery.h" namespace ARDOUR { +class PeakMeter; +class Amp; + class Send : public Delivery { public: - Send (Session&); - Send (Session&, const XMLNode&); + Send (Session&, boost::shared_ptr<MuteMaster>); + Send (Session&, boost::shared_ptr<MuteMaster>, const XMLNode&); virtual ~Send (); uint32_t bit_slot() const { return _bitslot; } - - void activate() {} - void deactivate () {} + boost::shared_ptr<Amp> amp() const { return _amp; } + boost::shared_ptr<PeakMeter> meter() const { return _meter; } + + bool metering() const { return _metering; } + void set_metering (bool yn) { _metering = yn; } + XMLNode& state(bool full); XMLNode& get_state(void); int set_state(const XMLNode& node); uint32_t pans_required() const { return _configured_input.n_audio(); } + void run_in_place (BufferSet& bufs, sframes_t start_frame, sframes_t end_frame, nframes_t nframes); + bool can_support_io_configuration (const ChanCount& in, ChanCount& out) const; - bool configure_io (ChanCount in, ChanCount out); bool set_name (const std::string& str); static uint32_t how_many_sends(); static void make_unique (XMLNode &, Session &); + protected: + bool _metering; + boost::shared_ptr<Amp> _amp; + boost::shared_ptr<PeakMeter> _meter; + private: /* disallow copy construction */ Send (const Send&); |