summaryrefslogtreecommitdiff
path: root/cpp/src/qpid/cluster/MemberHandler.cpp
diff options
context:
space:
mode:
authorAlan Conway <aconway@apache.org>2008-09-26 19:22:00 +0000
committerAlan Conway <aconway@apache.org>2008-09-26 19:22:00 +0000
commit44366590caa13db09e55e2c853bd66b363558fa7 (patch)
treee6ecd10c956fee5f5e865670911ea9ef46e1ed76 /cpp/src/qpid/cluster/MemberHandler.cpp
parentb22dd47558cc11572d080ac25808012092dda597 (diff)
downloadqpid-python-44366590caa13db09e55e2c853bd66b363558fa7.tar.gz
cluster:]
- call updateMemberStats() exactly once for each change in cluster membership. - fix spurious replication of catch-up connection close events. Removed unused client/MessageQueue.h git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk/qpid@699456 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/src/qpid/cluster/MemberHandler.cpp')
-rw-r--r--cpp/src/qpid/cluster/MemberHandler.cpp11
1 files changed, 5 insertions, 6 deletions
diff --git a/cpp/src/qpid/cluster/MemberHandler.cpp b/cpp/src/qpid/cluster/MemberHandler.cpp
index 53a1d13a4d..5f02754443 100644
--- a/cpp/src/qpid/cluster/MemberHandler.cpp
+++ b/cpp/src/qpid/cluster/MemberHandler.cpp
@@ -52,10 +52,8 @@ void MemberHandler::deliver(Event& e) {
cluster.connectionEventQueue.push(e);
}
-void MemberHandler::update(const MemberId&, const framing::FieldTable& , uint64_t) {
- Mutex::ScopedLock l(cluster.lock);
- cluster.updateMemberStats();
-}
+// Updates are for new joiners.
+void MemberHandler::update(const MemberId&, const framing::FieldTable& , uint64_t) {}
void MemberHandler::dumpRequest(const MemberId& dumpee, const std::string& urlStr) {
Mutex::ScopedLock l(cluster.lock);
@@ -75,8 +73,9 @@ void MemberHandler::dumpRequest(const MemberId& dumpee, const std::string& urlSt
boost::bind(&MemberHandler::dumpError, this, _1)));
}
-void MemberHandler::ready(const MemberId& id, const std::string& url) {
- cluster.map.ready(id, Url(url));
+void MemberHandler::ready(const MemberId& id, const std::string& urlStr) {
+ if (cluster.map.ready(id, Url(urlStr)))
+ cluster.updateMemberStats();
}