diff options
| author | Gordon Sim <gsim@apache.org> | 2012-07-09 12:13:52 +0000 |
|---|---|---|
| committer | Gordon Sim <gsim@apache.org> | 2012-07-09 12:13:52 +0000 |
| commit | 6ef06439a82b324697369b791d13c7182e6af160 (patch) | |
| tree | e8a513e8f5f6ea35cc3db2d94c6330ef00388574 /cpp | |
| parent | 6a106bea43d8719b3926ea14066b40ea7e3884a4 (diff) | |
| download | qpid-python-6ef06439a82b324697369b791d13c7182e6af160.tar.gz | |
QPID-3757: clean up demux when subscription manager is destroyed
git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk/qpid@1359099 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp')
| -rw-r--r-- | cpp/src/qpid/client/SubscriptionManagerImpl.cpp | 10 | ||||
| -rw-r--r-- | cpp/src/qpid/client/SubscriptionManagerImpl.h | 3 |
2 files changed, 12 insertions, 1 deletions
diff --git a/cpp/src/qpid/client/SubscriptionManagerImpl.cpp b/cpp/src/qpid/client/SubscriptionManagerImpl.cpp index a558d90be8..7dead112e5 100644 --- a/cpp/src/qpid/client/SubscriptionManagerImpl.cpp +++ b/cpp/src/qpid/client/SubscriptionManagerImpl.cpp @@ -39,6 +39,16 @@ SubscriptionManagerImpl::SubscriptionManagerImpl(const Session& s) : dispatcher(s), session(s), autoStop(true) {} +SubscriptionManagerImpl::~SubscriptionManagerImpl() +{ + sys::Mutex::ScopedLock l(lock); + for (std::map<std::string, Subscription>::iterator i = subscriptions.begin(); i != subscriptions.end(); ++i) { + boost::intrusive_ptr<SubscriptionImpl> s = PrivateImplRef<Subscription>::get(i->second); + if (s) s->cancelDiversion(); + } + subscriptions.clear(); +} + Subscription SubscriptionManagerImpl::subscribe( MessageListener& listener, const std::string& q, const SubscriptionSettings& ss, const std::string& n) { diff --git a/cpp/src/qpid/client/SubscriptionManagerImpl.h b/cpp/src/qpid/client/SubscriptionManagerImpl.h index 6376a05c45..64d922e387 100644 --- a/cpp/src/qpid/client/SubscriptionManagerImpl.h +++ b/cpp/src/qpid/client/SubscriptionManagerImpl.h @@ -99,7 +99,8 @@ class SubscriptionManagerImpl : public sys::Runnable, public RefCounted public: /** Create a new SubscriptionManagerImpl associated with a session */ SubscriptionManagerImpl(const Session& session); - + ~SubscriptionManagerImpl(); + /** * Subscribe a MessagesListener to receive messages from queue. * |
