summaryrefslogtreecommitdiffstats
path: root/src/server/events
diff options
context:
space:
mode:
Diffstat (limited to 'src/server/events')
-rw-r--r--src/server/events/Disconnect.cpp2
-rw-r--r--src/server/events/DisconnectAll.cpp52
-rw-r--r--src/server/events/DisconnectAll.hpp2
3 files changed, 26 insertions, 30 deletions
diff --git a/src/server/events/Disconnect.cpp b/src/server/events/Disconnect.cpp
index c089fb11..5a6d53e8 100644
--- a/src/server/events/Disconnect.cpp
+++ b/src/server/events/Disconnect.cpp
@@ -108,8 +108,6 @@ Disconnect::Impl::Impl(Engine& e,
}
}
}
-
- _connection->pending_disconnection(true);
}
void
diff --git a/src/server/events/DisconnectAll.cpp b/src/server/events/DisconnectAll.cpp
index f355575a..b6ec3c4b 100644
--- a/src/server/events/DisconnectAll.cpp
+++ b/src/server/events/DisconnectAll.cpp
@@ -15,6 +15,8 @@
* 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
+#include <set>
+
#include <boost/format.hpp>
#include <glibmm/thread.h>
@@ -76,27 +78,6 @@ DisconnectAll::~DisconnectAll()
}
void
-DisconnectAll::maybe_remove_connection(ConnectionImpl* c)
-{
- if (c->pending_disconnection())
- return;
-
- OutputPort* src = dynamic_cast<OutputPort*>(c->src_port());
- InputPort* dst = dynamic_cast<InputPort*>(c->dst_port());
-
- if (_node) {
- if (src->parent_node() == _node || dst->parent_node() == _node) {
- _impls.push_back(new Disconnect::Impl(_engine, _parent, src, dst));
- }
- } else {
- assert(_port);
- if (src == _port || dst == _port) {
- _impls.push_back(new Disconnect::Impl(_engine, _parent, src, dst));
- }
- }
-}
-
-void
DisconnectAll::pre_process()
{
Glib::RWLock::WriterLock lock(_engine.engine_store()->lock(), Glib::NOT_LOCK);
@@ -134,12 +115,31 @@ DisconnectAll::pre_process()
assert((_node || _port) && !(_node && _port));
}
+ // Find set of connections to remove
+ std::set<ConnectionImpl*> to_remove;
for (Patch::Connections::const_iterator i = _parent->connections().begin();
- i != _parent->connections().end();) {
- Patch::Connections::const_iterator next = i;
- ++next;
- maybe_remove_connection((ConnectionImpl*)i->second.get());
- i = next;
+ i != _parent->connections().end(); ++i) {
+ ConnectionImpl* const c = (ConnectionImpl*)i->second.get();
+ if (_node) {
+ if (c->src_port()->parent_node() == _node
+ || c->dst_port()->parent_node() == _node) {
+ to_remove.insert(c);
+ }
+ } else {
+ assert(_port);
+ if (c->src_port() == _port || c->dst_port() == _port) {
+ to_remove.insert(c);
+ }
+ }
+ }
+
+ // Create disconnect events (which erases from _parent->connections())
+ for (std::set<ConnectionImpl*>::const_iterator i = to_remove.begin();
+ i != to_remove.end(); ++i) {
+ _impls.push_back(new Disconnect::Impl(
+ _engine, _parent,
+ dynamic_cast<OutputPort*>((*i)->src_port()),
+ dynamic_cast<InputPort*>((*i)->dst_port())));
}
if (!_deleting && _parent->enabled())
diff --git a/src/server/events/DisconnectAll.hpp b/src/server/events/DisconnectAll.hpp
index d53d1114..e3b23df6 100644
--- a/src/server/events/DisconnectAll.hpp
+++ b/src/server/events/DisconnectAll.hpp
@@ -70,8 +70,6 @@ private:
OBJECT_NOT_FOUND,
};
- void maybe_remove_connection(ConnectionImpl* c);
-
Raul::Path _parent_path;
Raul::Path _path;
PatchImpl* _parent;