diff options
| author | Alan Conway <aconway@apache.org> | 2008-05-27 18:38:06 +0000 |
|---|---|---|
| committer | Alan Conway <aconway@apache.org> | 2008-05-27 18:38:06 +0000 |
| commit | 63f68e2f68cafce3da7ca03113e6eddc38d405b3 (patch) | |
| tree | f16d502dfe64ef9eb2d10a39151630f453d4c810 /cpp/src/qpid/client/SubscriptionManager.cpp | |
| parent | 1ebc196ec0f6128e9f73f3aebb9a30d5436ef5c0 (diff) | |
| download | qpid-python-63f68e2f68cafce3da7ca03113e6eddc38d405b3.tar.gz | |
Tighten up sync-correctness in SubscriptionManager & Dispatcher.
Add a flush to SessionBase_0_10::sync() so it syncs in both directions.
git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk/qpid@660643 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/src/qpid/client/SubscriptionManager.cpp')
| -rw-r--r-- | cpp/src/qpid/client/SubscriptionManager.cpp | 11 |
1 files changed, 6 insertions, 5 deletions
diff --git a/cpp/src/qpid/client/SubscriptionManager.cpp b/cpp/src/qpid/client/SubscriptionManager.cpp index 6036f153f6..3fa75a54ac 100644 --- a/cpp/src/qpid/client/SubscriptionManager.cpp +++ b/cpp/src/qpid/client/SubscriptionManager.cpp @@ -42,7 +42,7 @@ SubscriptionManager::SubscriptionManager(const Session& s) void SubscriptionManager::subscribeInternal( const std::string& q, const std::string& dest) { - async(session).messageSubscribe( // setFlowControl will sync. + session.messageSubscribe( arg::queue=q, arg::destination=dest, arg::acceptMode=acceptMode, arg::acquireMode=acquireMode); setFlowControl(dest, messages, bytes, window); @@ -68,9 +68,10 @@ void SubscriptionManager::subscribe( void SubscriptionManager::setFlowControl( const std::string& dest, uint32_t messages, uint32_t bytes, bool window) { - async(session).messageSetFlowMode(dest, window); - async(session).messageFlow(dest, 0, messages); - session.messageFlow(dest, 1, bytes); // Only need one sync + session.messageSetFlowMode(dest, window); + session.messageFlow(dest, 0, messages); + session.messageFlow(dest, 1, bytes); + session.sync(); } void SubscriptionManager::setFlowControl( @@ -91,8 +92,8 @@ AckPolicy& SubscriptionManager::getAckPolicy() { return autoAck; } void SubscriptionManager::cancel(const std::string dest) { + sync(session).messageCancel(dest); dispatcher.cancel(dest); - session.messageCancel(dest); } void SubscriptionManager::setAutoStop(bool set) { autoStop=set; } |
