summaryrefslogtreecommitdiff
path: root/cpp/src/qpid/broker
diff options
context:
space:
mode:
Diffstat (limited to 'cpp/src/qpid/broker')
-rw-r--r--cpp/src/qpid/broker/BrokerQueue.cpp2
-rw-r--r--cpp/src/qpid/broker/BrokerQueue.h10
2 files changed, 9 insertions, 3 deletions
diff --git a/cpp/src/qpid/broker/BrokerQueue.cpp b/cpp/src/qpid/broker/BrokerQueue.cpp
index 706179fb52..5ff9f950eb 100644
--- a/cpp/src/qpid/broker/BrokerQueue.cpp
+++ b/cpp/src/qpid/broker/BrokerQueue.cpp
@@ -50,7 +50,7 @@ Queue::Queue(const string& _name, bool _autodelete,
exclusive(0),
persistenceId(0),
serializer(false),
- dispatchCallback(boost::bind(&Queue::dispatch, this))
+ dispatchCallback(*this)
{
}
diff --git a/cpp/src/qpid/broker/BrokerQueue.h b/cpp/src/qpid/broker/BrokerQueue.h
index 35aa954c1e..962c11d8ee 100644
--- a/cpp/src/qpid/broker/BrokerQueue.h
+++ b/cpp/src/qpid/broker/BrokerQueue.h
@@ -60,6 +60,12 @@ namespace qpid {
typedef std::vector<Consumer*> Consumers;
typedef std::deque<Message::shared_ptr> Messages;
+ struct DispatchFunctor {
+ Queue& queue;
+ DispatchFunctor(Queue& q) : queue(q) {}
+ void operator()() { queue.dispatch(); }
+ };
+
const string name;
const bool autodelete;
MessageStore* const store;
@@ -75,8 +81,8 @@ namespace qpid {
std::auto_ptr<QueuePolicy> policy;
QueueBindings bindings;
boost::shared_ptr<Exchange> alternateExchange;
- qpid::sys::Serializer serializer;
- qpid::sys::Serializer::Task dispatchCallback;
+ qpid::sys::Serializer<DispatchFunctor> serializer;
+ DispatchFunctor dispatchCallback;
void pop();
void push(Message::shared_ptr& msg);