major redesign of MIDI port heirarchy and management (part 2)
[ardour.git] / libs / midi++2 / mmc.cc
index 0a71463721ff47e638aa8807fca1a874b233d091..b93dc0f260503bb5e84088683caa1296ba2cdaa7 100644 (file)
@@ -27,9 +27,7 @@
 
 #include "midi++/mmc.h"
 #include "midi++/port.h"
-#include "midi++/jack_midi_port.h"
 #include "midi++/parser.h"
-#include "midi++/manager.h"
 
 using namespace std;
 using namespace MIDI;
@@ -197,16 +195,21 @@ static void build_mmc_cmd_map ()
        mmc_cmd_map.insert (newpair);
 }
 
-
-MachineControl::MachineControl (Manager* m, ARDOUR::PortEngine& pengine)
+MachineControl::MachineControl ()
 {
        build_mmc_cmd_map ();
 
        _receive_device_id = 0x7f;
        _send_device_id = 0x7f;
+}
+
+void
+MachineControl::set_ports (MIDI::Port* ip, MIDI::Port* op)
+{
+       port_connections.drop_connections ();
 
-       _input_port = m->add_port (new JackMIDIPort ("MMC in", Port::IsInput, pengine));
-       _output_port = m->add_port (new JackMIDIPort ("MMC out", Port::IsOutput, pengine));
+       _input_port = ip;
+       _output_port = op;
 
        _input_port->parser()->mmc.connect_same_thread (port_connections, boost::bind (&MachineControl::process_mmc_message, this, _1, _2, _3));
        _input_port->parser()->start.connect_same_thread (port_connections, boost::bind (&MachineControl::spp_start, this));