summaryrefslogtreecommitdiff
path: root/qpid/cpp/broker/src/Message.cpp
diff options
context:
space:
mode:
authorGordon Sim <gsim@apache.org>2006-09-27 16:44:02 +0000
committerGordon Sim <gsim@apache.org>2006-09-27 16:44:02 +0000
commitcb3fe168a5c4c0c91b5d32ff28b176d57c8eb870 (patch)
treea97bbaf09bc54bd91bb0026c4b504cdbed9f3c3e /qpid/cpp/broker/src/Message.cpp
parentb65e020ec427ab77bcb6d6aac8b56662140abc9f (diff)
downloadqpid-python-cb3fe168a5c4c0c91b5d32ff28b176d57c8eb870.tar.gz
Moved ack tests to basic class, added test for requeueing on recovery.
Implemented requeuing on recovery. git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk@450504 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'qpid/cpp/broker/src/Message.cpp')
-rw-r--r--qpid/cpp/broker/src/Message.cpp9
1 files changed, 7 insertions, 2 deletions
diff --git a/qpid/cpp/broker/src/Message.cpp b/qpid/cpp/broker/src/Message.cpp
index 7afcd97934..8ebe40410a 100644
--- a/qpid/cpp/broker/src/Message.cpp
+++ b/qpid/cpp/broker/src/Message.cpp
@@ -32,7 +32,8 @@ Message::Message(const ConnectionToken* const _publisher,
exchange(_exchange),
routingKey(_routingKey),
mandatory(_mandatory),
- immediate(_immediate){
+ immediate(_immediate),
+ redelivered(false){
}
@@ -51,11 +52,15 @@ bool Message::isComplete(){
return header.get() && (header->getContentSize() == contentSize());
}
+void Message::redeliver(){
+ redelivered = true;
+}
+
void Message::deliver(OutputHandler* out, int channel,
string& consumerTag, u_int64_t deliveryTag,
u_int32_t framesize){
- out->send(new AMQFrame(channel, new BasicDeliverBody(consumerTag, deliveryTag, false, exchange, routingKey)));
+ out->send(new AMQFrame(channel, new BasicDeliverBody(consumerTag, deliveryTag, redelivered, exchange, routingKey)));
AMQBody::shared_ptr headerBody = static_pointer_cast<AMQBody, AMQHeaderBody>(header);
out->send(new AMQFrame(channel, headerBody));
for(content_iterator i = content.begin(); i != content.end(); i++){