#ifndef __ardour_port_h__
#define __ardour_port_h__
+#include "libardour-config.h"
+
#include <set>
#include <string>
#include <vector>
#include "pbd/signals.h"
#include "ardour/data_type.h"
+#include "ardour/port_engine.h"
#include "ardour/types.h"
namespace ARDOUR {
class Port : public boost::noncopyable
{
public:
- enum Flags {
- IsInput = JackPortIsInput,
- IsOutput = JackPortIsOutput,
- };
-
virtual ~Port ();
- static void set_buffer_size (pframes_t sz) {
- _buffer_size = sz;
- }
- static void set_connecting_blocked( bool yn ) {
+ static void set_connecting_blocked( bool yn ) {
_connecting_blocked = yn;
}
- static bool connecting_blocked() {
+ static bool connecting_blocked() {
return _connecting_blocked;
}
int set_name (std::string const &);
/** @return flags */
- Flags flags () const {
+ PortFlags flags () const {
return _flags;
}
virtual int connect (Port *);
int disconnect (Port *);
- void ensure_monitor_input (bool);
+ void request_input_monitoring (bool);
+ void ensure_input_monitoring (bool);
bool monitoring_input () const;
- framecnt_t total_latency () const;
int reestablish ();
int reconnect ();
- void request_monitor_input (bool);
- void set_latency (framecnt_t);
-
-#ifdef HAVE_JACK_NEW_LATENCY
- void get_connected_latency_range (jack_latency_range_t& range, bool playback) const;
- void set_latency_range (jack_latency_range_t& range, bool playback) const;
-#endif
- virtual void reset ();
+ bool last_monitor() const { return _last_monitor; }
+ void set_last_monitor (bool yn) { _last_monitor = yn; }
+
+ PortEngine::PortHandle port_handle() { return _port_handle; }
- /** @return the size of the raw buffer (bytes) for duration @a nframes (audio frames) */
- virtual size_t raw_buffer_size (pframes_t nframes) const = 0;
+ void get_connected_latency_range (jack_latency_range_t& range, bool playback) const;
+
+ void set_private_latency_range (jack_latency_range_t& range, bool playback);
+ const jack_latency_range_t& private_latency_range (bool playback) const;
+
+ void set_public_latency_range (jack_latency_range_t& range, bool playback) const;
+ jack_latency_range_t public_latency_range (bool playback) const;
+
+ virtual void reset ();
virtual DataType type () const = 0;
- virtual void cycle_start (pframes_t) = 0;
+ virtual void cycle_start (pframes_t);
virtual void cycle_end (pframes_t) = 0;
virtual void cycle_split () = 0;
- virtual Buffer& get_buffer (framecnt_t nframes) = 0;
- virtual void flush_buffers (pframes_t nframes, framepos_t /*time*/) {}
+ virtual Buffer& get_buffer (pframes_t nframes) = 0;
+ virtual void flush_buffers (pframes_t /*nframes*/) {}
virtual void transport_stopped () {}
+ virtual void realtime_locate () {}
- bool physically_connected () const;
-
- static void set_engine (AudioEngine *);
+ bool physically_connected () const;
PBD::Signal1<void,bool> MonitorInputChanged;
+ static PBD::Signal2<void,boost::shared_ptr<Port>,boost::shared_ptr<Port> > PostDisconnect;
+ static PBD::Signal0<void> PortDrop;
-
- static framecnt_t port_offset() { return _port_offset; }
-
- static void set_port_offset (framecnt_t off) {
- _port_offset = off;
+ static void set_cycle_framecnt (pframes_t n) {
+ _cycle_nframes = n;
+ }
+ static framecnt_t port_offset() { return _global_port_buffer_offset; }
+ static void set_global_port_buffer_offset (pframes_t off) {
+ _global_port_buffer_offset = off;
}
-
- static void increment_port_offset (framecnt_t n) {
- _port_offset += n;
+ static void increment_global_port_buffer_offset (pframes_t n) {
+ _global_port_buffer_offset += n;
}
+ virtual void increment_port_buffer_offset (pframes_t n);
+
protected:
- Port (std::string const &, DataType, Flags);
+ Port (std::string const &, DataType, PortFlags);
- jack_port_t* _jack_port; ///< JACK port
+ PortEngine::PortHandle _port_handle;
- static pframes_t _buffer_size;
static bool _connecting_blocked;
- static framecnt_t _port_offset;
-
- static AudioEngine* _engine; ///< the AudioEngine
-
-private:
- friend class AudioEngine;
+ static pframes_t _global_port_buffer_offset; /* access only from process() tree */
+ static pframes_t _cycle_nframes; /* access only from process() tree */
- void recompute_total_latency () const;
+ framecnt_t _port_buffer_offset; /* access only from process() tree */
- /* XXX */
- bool _last_monitor;
+ jack_latency_range_t _private_playback_latency;
+ jack_latency_range_t _private_capture_latency;
+private:
std::string _name; ///< port short name
- Flags _flags; ///< flags
+ PortFlags _flags; ///< flags
+ bool _last_monitor;
/** ports that we are connected to, kept so that we can
- reconnect to JACK when required */
+ reconnect to the backend when required
+ */
std::set<std::string> _connections;
+ void drop ();
+ PBD::ScopedConnection drop_connection;
};
}