summaryrefslogtreecommitdiff
path: root/cpp/src/qpid/broker/Message.cpp
diff options
context:
space:
mode:
authorGordon Sim <gsim@apache.org>2007-12-14 11:24:15 +0000
committerGordon Sim <gsim@apache.org>2007-12-14 11:24:15 +0000
commit7556017af46c7ddae2fcbdccbdee07b5fa7892bc (patch)
tree6e8fa33cff2ff2a04ccf931138bb7d970fc8088c /cpp/src/qpid/broker/Message.cpp
parent777df5f4bcea34e918f4087ddc06f182bec5d5bc (diff)
downloadqpid-python-7556017af46c7ddae2fcbdccbdee07b5fa7892bc.tar.gz
Only release content for durable queues.
git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk/qpid@604169 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/src/qpid/broker/Message.cpp')
-rw-r--r--cpp/src/qpid/broker/Message.cpp20
1 files changed, 11 insertions, 9 deletions
diff --git a/cpp/src/qpid/broker/Message.cpp b/cpp/src/qpid/broker/Message.cpp
index cff834c765..e01a553207 100644
--- a/cpp/src/qpid/broker/Message.cpp
+++ b/cpp/src/qpid/broker/Message.cpp
@@ -145,16 +145,18 @@ void Message::decodeContent(framing::Buffer& buffer)
void Message::releaseContent(MessageStore* _store)
{
- if (!store){
- store = _store;
- }
- if (!getPersistenceId()) {
- intrusive_ptr<PersistableMessage> pmsg(this);
- store->stage(pmsg);
+ if (!store) {
+ store = _store;
+ }
+ if (store) {
+ if (!getPersistenceId()) {
+ intrusive_ptr<PersistableMessage> pmsg(this);
+ store->stage(pmsg);
+ }
+ //remove any content frames from the frameset
+ frames.remove(TypeFilter<CONTENT_BODY>());
+ setContentReleased();
}
- //remove any content frames from the frameset
- frames.remove(TypeFilter<CONTENT_BODY>());
- setContentReleased();
}
void Message::sendContent(Queue& queue, framing::FrameHandler& out, uint16_t maxFrameSize) const