+#include <midi++/port.h>
+
#include <ardour/route.h>
#include <ardour/session.h>
GenericMidiControlProtocol::GenericMidiControlProtocol (Session& s)
: ControlProtocol (s, _("GenericMIDI"))
{
- _port = 0;
+ _port = s.midi_port();
+ s.MIDI_PortChanged.connect (mem_fun (*this, &GenericMidiControlProtocol::port_change));
+
}
GenericMidiControlProtocol::~GenericMidiControlProtocol ()
{
}
+int
+GenericMidiControlProtocol::set_active (bool yn)
+{
+ /* start delivery/outbound thread */
+ return 0;
+}
+
+void
+GenericMidiControlProtocol::port_change ()
+{
+ _port = session->midi_port ();
+}
+
void
GenericMidiControlProtocol::set_port (MIDI::Port* p)
{
if (_port != 0) {
const int32_t bufsize = 16 * 1024;
+ MIDI::byte buf[bufsize];
int32_t bsize = bufsize;
- MIDI::byte* buf = new MIDI::byte[bufsize];
MIDI::byte* end = buf;
for (list<Route*>::iterator r = routes.begin(); r != routes.end(); ++r) {
- end = (*r)->write_midi_feedback (end, bsize);
+ end = (*r)->write_midi_feedback (end, bsize);
}
if (end == buf) {
- delete [] buf;
return;
}
- session.deliver_midi (_port, buf, (int32_t) (end - buf));
+ _port->write (buf, 0, (int32_t) (end - buf));
//cerr << "MIDI feedback: wrote " << (int32_t) (end - buf) << " to midi port\n";
}
}
-bool
-GenericMidiControlProtocol::active() const
-{
- return _port && send();
-}
-