summaryrefslogtreecommitdiff
path: root/trunk/qpid/cpp/src/qpid/broker/DeliveryRecord.h
diff options
context:
space:
mode:
Diffstat (limited to 'trunk/qpid/cpp/src/qpid/broker/DeliveryRecord.h')
-rw-r--r--trunk/qpid/cpp/src/qpid/broker/DeliveryRecord.h118
1 files changed, 0 insertions, 118 deletions
diff --git a/trunk/qpid/cpp/src/qpid/broker/DeliveryRecord.h b/trunk/qpid/cpp/src/qpid/broker/DeliveryRecord.h
deleted file mode 100644
index 78dc99e3c6..0000000000
--- a/trunk/qpid/cpp/src/qpid/broker/DeliveryRecord.h
+++ /dev/null
@@ -1,118 +0,0 @@
-/*
- *
- * Licensed to the Apache Software Foundation (ASF) under one
- * or more contributor license agreements. See the NOTICE file
- * distributed with this work for additional information
- * regarding copyright ownership. The ASF licenses this file
- * to you under the Apache License, Version 2.0 (the
- * "License"); you may not use this file except in compliance
- * with the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing,
- * software distributed under the License is distributed on an
- * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
- * KIND, either express or implied. See the License for the
- * specific language governing permissions and limitations
- * under the License.
- *
- */
-#ifndef _DeliveryRecord_
-#define _DeliveryRecord_
-
-#include <algorithm>
-#include <list>
-#include <vector>
-#include <ostream>
-#include "qpid/framing/SequenceSet.h"
-#include "Queue.h"
-#include "Consumer.h"
-#include "DeliveryId.h"
-#include "DeliveryToken.h"
-#include "Message.h"
-#include "Prefetch.h"
-
-namespace qpid {
-namespace broker {
-class SemanticState;
-
-/**
- * Record of a delivery for which an ack is outstanding.
- */
-class DeliveryRecord{
- QueuedMessage msg;
- mutable Queue::shared_ptr queue;
- const std::string tag;
- DeliveryToken::shared_ptr token;
- DeliveryId id;
- bool acquired;
- const bool pull;
- bool cancelled;
- const uint32_t credit;
- const uint64_t size;
-
- bool completed;
- bool ended;
-
- public:
- DeliveryRecord(const QueuedMessage& msg, Queue::shared_ptr queue, const std::string tag, DeliveryToken::shared_ptr token,
- const DeliveryId id, bool acquired, bool confirmed = false);
- DeliveryRecord(const QueuedMessage& msg, Queue::shared_ptr queue, const DeliveryId id);
-
- bool matches(DeliveryId tag) const;
- bool matchOrAfter(DeliveryId tag) const;
- bool after(DeliveryId tag) const;
- bool coveredBy(const framing::SequenceSet* const range) const;
-
- void dequeue(TransactionContext* ctxt = 0) const;
- void requeue() const;
- void release(bool setRedelivered);
- void reject();
- void cancel(const std::string& tag);
- void redeliver(SemanticState* const);
- void acquire(DeliveryIds& results);
- void complete();
- void accept(TransactionContext* ctxt);
- void setEnded();
-
- bool isAcquired() const { return acquired; }
- bool isComplete() const { return completed; }
- bool isRedundant() const { return ended && completed; }
-
- uint32_t getCredit() const;
- void addTo(Prefetch&) const;
- void subtractFrom(Prefetch&) const;
- const std::string& getTag() const { return tag; }
- bool isPull() const { return pull; }
- friend bool operator<(const DeliveryRecord&, const DeliveryRecord&);
- friend std::ostream& operator<<(std::ostream&, const DeliveryRecord&);
-};
-
-typedef std::list<DeliveryRecord> DeliveryRecords;
-typedef std::list<DeliveryRecord>::iterator ack_iterator;
-
-struct AckRange
-{
- ack_iterator start;
- ack_iterator end;
- AckRange(ack_iterator _start, ack_iterator _end) : start(_start), end(_end) {}
-};
-
-struct AcquireFunctor
-{
- DeliveryIds& results;
-
- AcquireFunctor(DeliveryIds& _results) : results(_results) {}
-
- void operator()(DeliveryRecord& record)
- {
- record.acquire(results);
- }
-};
-
-}
-}
-
-
-#endif