From dea329a6277f8f68300809c64268edfcd0cd0fd7 Mon Sep 17 00:00:00 2001 From: Gordon Sim Date: Fri, 9 Aug 2013 12:33:23 +0000 Subject: QPID-5053: release exclusive queue ownership when session ends (clear the set _after_ iterating over it!) git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk@1512283 13f79535-47bb-0310-9956-ffa450edef68 --- qpid/cpp/src/qpid/broker/amqp/Session.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'qpid/cpp/src') diff --git a/qpid/cpp/src/qpid/broker/amqp/Session.cpp b/qpid/cpp/src/qpid/broker/amqp/Session.cpp index cb154d6b70..cd1c21c40e 100644 --- a/qpid/cpp/src/qpid/broker/amqp/Session.cpp +++ b/qpid/cpp/src/qpid/broker/amqp/Session.cpp @@ -507,7 +507,6 @@ bool Session::dispatch() void Session::close() { - exclusiveQueues.clear(); for (OutgoingLinks::iterator i = outgoing.begin(); i != outgoing.end(); ++i) { i->second->detached(); } @@ -520,6 +519,7 @@ void Session::close() for (std::set< boost::shared_ptr >::const_iterator i = exclusiveQueues.begin(); i != exclusiveQueues.end(); ++i) { (*i)->releaseExclusiveOwnership(); } + exclusiveQueues.clear(); qpid::sys::Mutex::ScopedLock l(lock); deleted = true; } -- cgit v1.2.1