#include "ardour/ardour.h"
#include "ardour/io_processor.h"
+#include "ardour/delivery.h"
+#include "ardour/libardour_visibility.h"
#include "ardour/types.h"
class XMLNode;
/** Port inserts: send output to a Jack port, pick up input at a Jack port
*/
-class PortInsert : public IOProcessor
+class LIBARDOUR_API PortInsert : public IOProcessor
{
- public:
+public:
PortInsert (Session&, boost::shared_ptr<Pannable>, boost::shared_ptr<MuteMaster> mm);
- PortInsert (Session&, const std::string&, uint32_t bitslot,
- boost::shared_ptr<Pannable>, boost::shared_ptr<MuteMaster> mm);
~PortInsert ();
- XMLNode& state(bool full);
- XMLNode& get_state(void);
int set_state (const XMLNode&, int version);
- void run (BufferSet& bufs, framepos_t start_frame, framepos_t end_frame, pframes_t nframes, bool);
+ void run (BufferSet& bufs, samplepos_t start_sample, samplepos_t end_sample, double speed, pframes_t nframes, bool);
- framecnt_t signal_latency () const;
+ void flush_buffers (samplecnt_t nframes) {
+ _out->flush_buffers (nframes);
+ }
+
+ samplecnt_t signal_latency () const;
bool set_name (const std::string& name);
- 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 activate ();
void deactivate ();
+ void set_pre_fader (bool);
+
uint32_t bit_slot() const { return _bitslot; }
void start_latency_detection ();
void stop_latency_detection ();
MTDM* mtdm () const { return _mtdm; }
- void set_measured_latency (framecnt_t);
- framecnt_t latency () const;
+ void set_measured_latency (samplecnt_t);
+ samplecnt_t latency () const;
- static void make_unique (XMLNode &);
static std::string name_and_id_new_insert (Session&, uint32_t&);
- private:
+protected:
+ XMLNode& state ();
+private:
/* disallow copy construction */
PortInsert (const PortInsert&);
uint32_t _bitslot;
MTDM* _mtdm;
bool _latency_detect;
- framecnt_t _latency_flush_frames;
- framecnt_t _measured_latency;
+ samplecnt_t _latency_flush_samples;
+ samplecnt_t _measured_latency;
};
} // namespace ARDOUR