diff options
Diffstat (limited to 'cpp/src/qpid/broker/QueueCleaner.cpp')
-rw-r--r-- | cpp/src/qpid/broker/QueueCleaner.cpp | 18 |
1 files changed, 17 insertions, 1 deletions
diff --git a/cpp/src/qpid/broker/QueueCleaner.cpp b/cpp/src/qpid/broker/QueueCleaner.cpp index c80fe89035..ed98468490 100644 --- a/cpp/src/qpid/broker/QueueCleaner.cpp +++ b/cpp/src/qpid/broker/QueueCleaner.cpp @@ -46,9 +46,25 @@ void QueueCleaner::Task::fire() parent.fired(); } +namespace { +struct CollectQueues +{ + std::vector<Queue::shared_ptr>* queues; + CollectQueues(std::vector<Queue::shared_ptr>* q) : queues(q) {} + void operator()(Queue::shared_ptr q) + { + queues->push_back(q); + } +}; +} + void QueueCleaner::fired() { - queues.eachQueue(boost::bind(&Queue::purgeExpired, _1)); + //collect copy of list of queues to avoid holding registry lock while we perform purge + std::vector<Queue::shared_ptr> copy; + CollectQueues collect(©); + queues.eachQueue(collect); + std::for_each(copy.begin(), copy.end(), boost::bind(&Queue::purgeExpired, _1)); task->setupNextFire(); timer.add(task); } |