summaryrefslogtreecommitdiff
path: root/cpp/src/qpid/cluster/UpdateClient.cpp
diff options
context:
space:
mode:
authorAlan Conway <aconway@apache.org>2010-11-22 16:15:06 +0000
committerAlan Conway <aconway@apache.org>2010-11-22 16:15:06 +0000
commit0f86c796ccb052fa6c5f807f480a1feabec643f8 (patch)
tree0d5d5613220e01ef99ff6ca79f9ff9a1898fa822 /cpp/src/qpid/cluster/UpdateClient.cpp
parent17401b1293bcd090ee1a675665ba30fcfac76d5b (diff)
downloadqpid-python-0f86c796ccb052fa6c5f807f480a1feabec643f8.tar.gz
QPID-2956: cluster broker exits with "error deliveryRecord no update message."
The following sequence of events was causing a broker joining the cluster to shutdown: - a client acquires or browses a message with TTL set. - the message expires. - a new broker joins before the client has acknowledged the message. git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk/qpid@1037763 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/src/qpid/cluster/UpdateClient.cpp')
-rw-r--r--cpp/src/qpid/cluster/UpdateClient.cpp6
1 files changed, 3 insertions, 3 deletions
diff --git a/cpp/src/qpid/cluster/UpdateClient.cpp b/cpp/src/qpid/cluster/UpdateClient.cpp
index 54c5fa0bcc..bc1b812a94 100644
--- a/cpp/src/qpid/cluster/UpdateClient.cpp
+++ b/cpp/src/qpid/cluster/UpdateClient.cpp
@@ -272,8 +272,7 @@ class MessageUpdater {
// Send the expiry ID if necessary.
if (message.payload->getProperties<DeliveryProperties>()->getTtl()) {
boost::optional<uint64_t> expiryId = expiry.getId(*message.payload);
- if (!expiryId) return; // Message already expired, don't replicate.
- ClusterConnectionProxy(session).expiryId(*expiryId);
+ ClusterConnectionProxy(session).expiryId(expiryId?*expiryId:0);
}
// We can't send a broker::Message via the normal client API,
@@ -408,7 +407,8 @@ void UpdateClient::updateSession(broker::SessionHandler& sh) {
QPID_LOG(debug, updaterId << " updating unacknowledged messages.");
broker::DeliveryRecords& drs = ss->getSemanticState().getUnacked();
- std::for_each(drs.begin(), drs.end(), boost::bind(&UpdateClient::updateUnacked, this, _1));
+ std::for_each(drs.begin(), drs.end(),
+ boost::bind(&UpdateClient::updateUnacked, this, _1));
updateTxState(ss->getSemanticState()); // Tx transaction state.