00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021 #ifndef _Dispatcher_
00022 #define _Dispatcher_
00023
00024 #include <map>
00025 #include <memory>
00026 #include <string>
00027 #include <boost/shared_ptr.hpp>
00028 #include "qpid/client/Session.h"
00029 #include "qpid/sys/Mutex.h"
00030 #include "qpid/sys/Runnable.h"
00031 #include "qpid/sys/Thread.h"
00032 #include "MessageListener.h"
00033 #include "AckPolicy.h"
00034
00035 namespace qpid {
00036 namespace client {
00037
00039 class Subscriber : public MessageListener
00040 {
00041 AsyncSession session;
00042 MessageListener* const listener;
00043 AckPolicy autoAck;
00044
00045 public:
00046 typedef boost::shared_ptr<Subscriber> shared_ptr;
00047 Subscriber(const Session& session, MessageListener* listener, AckPolicy);
00048 void received(Message& msg);
00049
00050 };
00051
00053 typedef framing::Handler<framing::FrameSet> FrameSetHandler;
00054
00056 class Dispatcher : public sys::Runnable
00057 {
00058 typedef std::map<std::string, Subscriber::shared_ptr> Listeners;
00059 sys::Mutex lock;
00060 sys::Thread worker;
00061 Session session;
00062 Demux::QueuePtr queue;
00063 bool running;
00064 bool autoStop;
00065 Listeners listeners;
00066 Subscriber::shared_ptr defaultListener;
00067 std::auto_ptr<FrameSetHandler> handler;
00068
00069 Subscriber::shared_ptr find(const std::string& name);
00070 bool isStopped();
00071
00072 boost::function<void ()> failoverHandler;
00073
00074 public:
00075 Dispatcher(const Session& session, const std::string& queue = "");
00076
00077 void start();
00078 void run();
00079 void stop();
00080 void setAutoStop(bool b);
00081
00082 void registerFailoverHandler ( boost::function<void ()> fh )
00083 {
00084 failoverHandler = fh;
00085 }
00086
00087 void listen(MessageListener* listener, AckPolicy autoAck=AckPolicy());
00088 void listen(const std::string& destination, MessageListener* listener, AckPolicy autoAck=AckPolicy());
00089 void cancel(const std::string& destination);
00090 };
00091
00092 }}
00093
00094 #endif