diff options
| author | Gordon Sim <gsim@apache.org> | 2007-09-06 20:27:33 +0000 |
|---|---|---|
| committer | Gordon Sim <gsim@apache.org> | 2007-09-06 20:27:33 +0000 |
| commit | b33a63b36c659a894143382d0a61efe6a598fcc6 (patch) | |
| tree | 0efc848ae9cc6064d615c6968b1d127e92b231d3 /cpp/src/qpid/client/ExecutionHandler.h | |
| parent | 748698e4b8d5bd0c3ccec4ca898d334c13fc0795 (diff) | |
| download | qpid-python-b33a63b36c659a894143382d0a61efe6a598fcc6.tar.gz | |
Implementation of execution.result on the client side
git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk/qpid@573359 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/src/qpid/client/ExecutionHandler.h')
| -rw-r--r-- | cpp/src/qpid/client/ExecutionHandler.h | 37 |
1 files changed, 25 insertions, 12 deletions
diff --git a/cpp/src/qpid/client/ExecutionHandler.h b/cpp/src/qpid/client/ExecutionHandler.h index f740e14185..a42697e26a 100644 --- a/cpp/src/qpid/client/ExecutionHandler.h +++ b/cpp/src/qpid/client/ExecutionHandler.h @@ -22,28 +22,34 @@ #define _ExecutionHandler_ #include <queue> +#include "qpid/framing/AccumulatedAck.h" #include "qpid/framing/AMQP_ServerOperations.h" #include "qpid/framing/FrameSet.h" +#include "qpid/framing/MethodContent.h" #include "qpid/framing/SequenceNumber.h" #include "BlockingQueue.h" #include "ChainableFrameHandler.h" #include "CompletionTracker.h" #include "Correlator.h" +#include "Execution.h" namespace qpid { namespace client { class ExecutionHandler : private framing::AMQP_ServerOperations::ExecutionHandler, - public ChainableFrameHandler + public ChainableFrameHandler, + public Execution { framing::Window incoming; framing::Window outgoing; framing::FrameSet::shared_ptr arriving; Correlator correlation; CompletionTracker completion; + BlockingQueue<framing::FrameSet::shared_ptr> received; framing::ProtocolVersion version; uint64_t maxFrameSize; + framing::AccumulatedAck completionStatus; void complete(uint32_t mark, const framing::SequenceNumberSet& range); void flush(); @@ -51,22 +57,29 @@ class ExecutionHandler : void result(uint32_t command, const std::string& data); void sync(); + void sendCompletion(); + + void sendContent(const framing::BasicHeaderProperties& headers, const std::string& data); + public: - BlockingQueue<framing::FrameSet::shared_ptr> received; + typedef CompletionTracker::ResultListener ResultListener; ExecutionHandler(uint64_t maxFrameSize = 65536); - void setMaxFrameSize(uint64_t size) { maxFrameSize = size; } - void handle(framing::AMQFrame& frame); - void send(const framing::AMQBody& command, - CompletionTracker::Listener f = CompletionTracker::Listener(), - Correlator::Listener g = Correlator::Listener()); - void sendContent(const framing::AMQBody& command, - const framing::BasicHeaderProperties& headers, const std::string& data, - CompletionTracker::Listener f = CompletionTracker::Listener(), - Correlator::Listener g = Correlator::Listener()); - void sendFlush(); + framing::SequenceNumber send(const framing::AMQBody& command, ResultListener=ResultListener()); + framing::SequenceNumber send(const framing::AMQBody& command, const framing::MethodContent& content, + ResultListener=ResultListener()); + void sendSyncRequest(); + void sendFlushRequest(); + void completed(const framing::SequenceNumber& id, bool cumulative, bool send); + void syncTo(const framing::SequenceNumber& point); + void flushTo(const framing::SequenceNumber& point); + + void setMaxFrameSize(uint64_t size) { maxFrameSize = size; } + Correlator& getCorrelator() { return correlation; } + CompletionTracker& getCompletionTracker() { return completion; } + BlockingQueue<framing::FrameSet::shared_ptr>& getReceived() { return received; } }; }} |
