openbox/otk/timerqueue.hh

53 lines
1.3 KiB
C++
Raw Normal View History

// -*- mode: C++; indent-tabs-mode: nil; -*-
#ifndef __timerqueue_hh
#define __timerqueue_hh
#ifndef DOXYGEN_IGNORE
#include "timer.hh"
#include <queue>
#include <vector>
#include <algorithm>
namespace otk {
template <class _Tp, class _Sequence, class _Compare>
class _timer_queue: protected std::priority_queue<_Tp, _Sequence, _Compare> {
public:
typedef std::priority_queue<_Tp, _Sequence, _Compare> _Base;
_timer_queue(): _Base() {}
~_timer_queue() {}
void release(const _Tp& value) {
c.erase(std::remove(c.begin(), c.end(), value), c.end());
// after removing the item we need to make the heap again
std::make_heap(c.begin(), c.end(), comp);
}
bool empty() const { return _Base::empty(); }
size_t size() const { return _Base::size(); }
void push(const _Tp& value) { _Base::push(value); }
void pop() { _Base::pop(); }
const _Tp& top() const { return _Base::top(); }
private:
// no copying!
_timer_queue(const _timer_queue&) {}
_timer_queue& operator=(const _timer_queue&) {}
};
struct TimerLessThan {
bool operator()(const OBTimer* const l, const OBTimer* const r) const {
return *r < *l;
}
};
typedef _timer_queue<OBTimer*,
std::vector<OBTimer*>, TimerLessThan> TimerQueue;
}
#endif // DOXYGEN_IGNORE
#endif // __timerqueue_hh