1// excerpts from http://code.google.com/p/muduo/
2//
3// Use of this source code is governed by a BSD-style license
4// that can be found in the License file.
5//
6// Author: Shuo Chen (chenshuo at chenshuo dot com)
7
8#ifndef MUDUO_NET_TIMERQUEUE_H
9#define MUDUO_NET_TIMERQUEUE_H
10
11#include <set>
12#include <vector>
13
14#include <boost/noncopyable.hpp>
15
16#include "datetime/Timestamp.h"
17#include "thread/Mutex.h"
18#include "Callbacks.h"
19#include "Channel.h"
20
21namespace muduo
22{
23
24class EventLoop;
25class Timer;
26class TimerId;
27
28///
29/// A best efforts timer queue.
30/// No guarantee that the callback will be on time.
31///
32class TimerQueue : boost::noncopyable
33{
34 public:
35  TimerQueue(EventLoop* loop);
36  ~TimerQueue();
37
38  ///
39  /// Schedules the callback to be run at given time,
40  /// repeats if @c interval > 0.0.
41  ///
42  /// Must be thread safe. Usually be called from other threads.
43  TimerId addTimer(const TimerCallback& cb,
44                   Timestamp when,
45                   double interval);
46
47  // void cancel(TimerId timerId);
48
49 private:
50
51  // FIXME: use unique_ptr<Timer> instead of raw pointers.
52  typedef std::pair<Timestamp, Timer*> Entry;
53  typedef std::set<Entry> TimerList;
54
55  void addTimerInLoop(Timer* timer);
56  // called when timerfd alarms
57  void handleRead();
58  // move out all expired timers
59  std::vector<Entry> getExpired(Timestamp now);
60  void reset(const std::vector<Entry>& expired, Timestamp now);
61
62  bool insert(Timer* timer);
63
64  EventLoop* loop_;
65  const int timerfd_;
66  Channel timerfdChannel_;
67  // Timer list sorted by expiration
68  TimerList timers_;
69};
70
71}
72#endif  // MUDUO_NET_TIMERQUEUE_H
73