23 #ifndef EVENTSCHEDULER_H
24 #define EVENTSCHEDULER_H
29 template<
class This >
33 typedef void (This::*Callback) ();
37 Callback
const m_callback;
40 void event() { (m_this.*m_callback)(); }
43 EventCallback(
const char *
const name, This &_this, Callback callback) :
46 m_callback(callback) {}
59 event_clock_t currentTime;
70 void schedule(
Event &event)
73 Event **scan = &firstEvent;
76 if (*scan == 0 || (*scan)->triggerTime > event.triggerTime)
82 scan = &((*scan)->next);
91 event.triggerTime = (cycles << 1) + currentTime + ((currentTime & 1) ^
phase);
97 event.triggerTime = (cycles << 1) + currentTime;
114 Event &
event = *firstEvent;
115 firstEvent = firstEvent->next;
116 currentTime =
event.triggerTime;
124 return (currentTime + (phase ^ 1)) >> 1;
132 event_phase_t
phase()
const {
return (event_phase_t) (currentTime & 1); }
135 #endif // EVENTSCHEDULER_H
Definition: EventScheduler.h:55
void reset()
Definition: EventScheduler.cpp:26
bool isPending(Event &event) const
Definition: EventScheduler.cpp:47
event_clock_t getTime(event_phase_t phase) const
Definition: EventScheduler.h:122
void clock()
Definition: EventScheduler.h:112
void schedule(Event &event, event_clock_t cycles, event_phase_t phase)
Definition: EventScheduler.h:87
Definition: EventScheduler.h:30
event_phase_t phase() const
Definition: EventScheduler.h:132
void schedule(Event &event, event_clock_t cycles)
Definition: EventScheduler.h:95
Event(const char *const name)
Definition: event.h:71
event_clock_t getTime(event_clock_t clock, event_phase_t phase) const
Definition: EventScheduler.h:127
void cancel(Event &event)
Definition: EventScheduler.cpp:32