diff options
author | Gordon Sim <gsim@apache.org> | 2009-01-23 14:08:42 +0000 |
---|---|---|
committer | Gordon Sim <gsim@apache.org> | 2009-01-23 14:08:42 +0000 |
commit | 2deb4832b4894bb2a5123daaffd54d6da652fae3 (patch) | |
tree | 94e4274601cb9eb8c70b6ddd73dd100ccca436ca /cpp/src/qpid/client/SubscriptionManager.cpp | |
parent | d7ce27f7cc96894f149e5c20c03b306b80636727 (diff) | |
download | qpid-python-2deb4832b4894bb2a5123daaffd54d6da652fae3.tar.gz |
QPID-1613: Ensure that the rule registered with the demuxer for LocalQueue subscriptions is removed when they are cancelled.
git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk/qpid@737028 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/src/qpid/client/SubscriptionManager.cpp')
-rw-r--r-- | cpp/src/qpid/client/SubscriptionManager.cpp | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/cpp/src/qpid/client/SubscriptionManager.cpp b/cpp/src/qpid/client/SubscriptionManager.cpp index c91ae178ac..f9d0ecbf80 100644 --- a/cpp/src/qpid/client/SubscriptionManager.cpp +++ b/cpp/src/qpid/client/SubscriptionManager.cpp @@ -53,8 +53,8 @@ Subscription SubscriptionManager::subscribe( LocalQueue& lq, const std::string& q, const SubscriptionSettings& ss, const std::string& n) { std::string name=n.empty() ? q:n; - lq.queue=session.getExecution().getDemux().add(name, ByTransferDest(name)); boost::intrusive_ptr<SubscriptionImpl> si = new SubscriptionImpl(*this, q, ss, name, 0); + lq.queue=si->divert(); si->subscribe(); lq.subscription = Subscription(si.get()); return subscriptions[name] = lq.subscription; @@ -74,8 +74,14 @@ Subscription SubscriptionManager::subscribe( void SubscriptionManager::cancel(const std::string& dest) { - sync(session).messageCancel(dest); - dispatcher.cancel(dest); + std::map<std::string, Subscription>::iterator i = subscriptions.find(dest); + if (i != subscriptions.end()) { + sync(session).messageCancel(dest); + dispatcher.cancel(dest); + Subscription s = i->second; + if (s.isValid()) subscriptions[dest].impl->cancelDiversion(); + subscriptions.erase(dest); + } } void SubscriptionManager::setAutoStop(bool set) { autoStop=set; } |