summaryrefslogtreecommitdiff
path: root/qpid/cpp
diff options
context:
space:
mode:
authorGordon Sim <gsim@apache.org>2013-08-09 17:03:16 +0000
committerGordon Sim <gsim@apache.org>2013-08-09 17:03:16 +0000
commit4d074fa039bc3626d204a97f778542bea4dbab30 (patch)
tree82da9bc0a92062b22548f5f2285ac136e4bbabd3 /qpid/cpp
parent401257c9a44873a76c321681f5e40b058bc6f43e (diff)
downloadqpid-python-4d074fa039bc3626d204a97f778542bea4dbab30.tar.gz
QPID-5053: release exclusive queue ownership when session ends (merged from r1512283)
git-svn-id: https://svn.apache.org/repos/asf/qpid/branches/0.24@1512396 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'qpid/cpp')
-rw-r--r--qpid/cpp/src/qpid/broker/amqp/Session.cpp2
1 files changed, 1 insertions, 1 deletions
diff --git a/qpid/cpp/src/qpid/broker/amqp/Session.cpp b/qpid/cpp/src/qpid/broker/amqp/Session.cpp
index b93afcf269..d989e947aa 100644
--- a/qpid/cpp/src/qpid/broker/amqp/Session.cpp
+++ b/qpid/cpp/src/qpid/broker/amqp/Session.cpp
@@ -503,7 +503,6 @@ bool Session::dispatch()
void Session::close()
{
- exclusiveQueues.clear();
for (OutgoingLinks::iterator i = outgoing.begin(); i != outgoing.end(); ++i) {
i->second->detached();
}
@@ -516,6 +515,7 @@ void Session::close()
for (std::set< boost::shared_ptr<Queue> >::const_iterator i = exclusiveQueues.begin(); i != exclusiveQueues.end(); ++i) {
(*i)->releaseExclusiveOwnership();
}
+ exclusiveQueues.clear();
qpid::sys::Mutex::ScopedLock l(lock);
deleted = true;
}