- void write( const MidiByteArray & );
-
- /// write a sysex message
- void write_sysex( const MidiByteArray & mba );
- void write_sysex( MIDI::byte msg );
-
- // return the correct sysex header for this port
- virtual const MidiByteArray & sysex_hdr() const = 0;
-
- MIDI::Port & port() { return _port; }
- const MIDI::Port & port() const { return _port; }
-
- // all control notofications are sent from here
- sigc::signal<void, SurfacePort &, Control &, const ControlState &> control_event;
-
- // emitted just before the port goes into initialisation
- // where it tries to establish that its device is connected
- sigc::signal<void> init_event;
-
- // emitted when the port completes initialisation successfully
- sigc::signal<void> active_event;
-
- // emitted when the port goes inactive (ie a read or write failed)
- sigc::signal<void> inactive_event;
-
- // the port number - master is 0, extenders are 1,2,3,4
- virtual int number() const { return _number; }
-
- // number of strips handled by this port. Usually 8.
- virtual int strips() const = 0;
-
- virtual bool active() const { return _active; }
- virtual void active( bool yn ) { _active = yn; }
-
-private:
- MIDI::Port & _port;
- int _number;
- bool _active;
-
- Glib::RecMutex _rwlock;
-};
-
-std::ostream & operator << ( std::ostream & , const SurfacePort & port );
+ int write (const MidiByteArray&);
+
+ MIDI::Port& input_port() const { return *_input_port; }
+ MIDI::Port& output_port() const { return *_output_port; }
+
+ ARDOUR::Port& input() const { return *_async_in; }
+ ARDOUR::Port& output() const { return *_async_out; }
+
+ std::string input_name() const;
+ std::string output_name() const;
+
+ void reconnect ();