summaryrefslogtreecommitdiff
path: root/cpp/src/qpid/cluster/Decoder.cpp
diff options
context:
space:
mode:
authorGordon Sim <gsim@apache.org>2009-03-24 14:07:25 +0000
committerGordon Sim <gsim@apache.org>2009-03-24 14:07:25 +0000
commit001d11d9e53ee2f9217bba412e5c7db141e0db11 (patch)
tree896de4b2fc2df2d3f4e3ed8e30072603ca4ed176 /cpp/src/qpid/cluster/Decoder.cpp
parente2c93f78c54c600f894b3540f0679463c5e4837a (diff)
downloadqpid-python-001d11d9e53ee2f9217bba412e5c7db141e0db11.tar.gz
QPID-1771: fix as applied to branch as r757807.
git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk/qpid@757808 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/src/qpid/cluster/Decoder.cpp')
-rw-r--r--cpp/src/qpid/cluster/Decoder.cpp5
1 files changed, 3 insertions, 2 deletions
diff --git a/cpp/src/qpid/cluster/Decoder.cpp b/cpp/src/qpid/cluster/Decoder.cpp
index 4de586d89f..b337ef43f4 100644
--- a/cpp/src/qpid/cluster/Decoder.cpp
+++ b/cpp/src/qpid/cluster/Decoder.cpp
@@ -47,12 +47,13 @@ void Decoder::decode(const EventHeader& eh, const char* data) {
// We must give 1 unit read credit per event.
// This event does not complete any frames so
// send an empty frame with the read credit.
- process(EventFrame(EventHeader(), framing::AMQFrame(), 1));
+ process(EventFrame(eh, framing::AMQFrame(), 1));
}
}
void Decoder::process(const EventFrame& ef) {
- if (ef.frame.getMethod() && ef.frame.getMethod()->isA<framing::ClusterConnectionDeliverCloseBody>())
+ //need to check that this is not the empty frame mentioned above
+ if (ef.frame.getBody() && ef.frame.getMethod() && ef.frame.getMethod()->isA<framing::ClusterConnectionDeliverCloseBody>())
map.erase(ef.connectionId);
callback(ef);
}