summaryrefslogtreecommitdiff
path: root/libs/midi++2
diff options
context:
space:
mode:
authorCarl Hetherington <carl@carlh.net>2011-09-26 20:35:16 +0000
committerCarl Hetherington <carl@carlh.net>2011-09-26 20:35:16 +0000
commita7dc433498d712b908c429761a4c3f9ea24ce440 (patch)
treec64400e690144c9136102fdf72160f2011d2fbb7 /libs/midi++2
parentd6112f121313f6db8353e32c1339f84cd1e59608 (diff)
Delete MIDI port objects when the MackieControlProtocol is torn down, so that it can be recreated without attempting to create duplicate JACK port names. Should fix #3886.
git-svn-id: svn://localhost/ardour2/branches/3.0@10129 d708f5d6-7413-0410-9779-e7cbd77b26cf
Diffstat (limited to 'libs/midi++2')
-rw-r--r--libs/midi++2/manager.cc10
-rw-r--r--libs/midi++2/midi++/manager.h1
2 files changed, 11 insertions, 0 deletions
diff --git a/libs/midi++2/manager.cc b/libs/midi++2/manager.cc
index 8aa89c7a99..b411a1ddad 100644
--- a/libs/midi++2/manager.cc
+++ b/libs/midi++2/manager.cc
@@ -77,6 +77,16 @@ Manager::add_port (Port* p)
}
void
+Manager::remove_port (Port* p)
+{
+ RCUWriter<PortList> writer (_ports);
+ boost::shared_ptr<PortList> pw = writer.get_copy ();
+ pw->remove (p);
+
+ PortsChanged (); /* EMIT SIGNAL */
+}
+
+void
Manager::cycle_start (pframes_t nframes)
{
boost::shared_ptr<PortList> pr = _ports.reader ();
diff --git a/libs/midi++2/midi++/manager.h b/libs/midi++2/midi++/manager.h
index 75b0cb4864..ecfd7a0111 100644
--- a/libs/midi++2/midi++/manager.h
+++ b/libs/midi++2/midi++/manager.h
@@ -59,6 +59,7 @@ class Manager {
Port *midi_clock_output_port() const { return _midi_clock_output_port; }
Port* add_port (Port *);
+ void remove_port (Port *);
Port* port (std::string const &);