+
+typedef std::pair<double, Timer*> TimerQelt;
+static boost::heap::fibonacci_heap<TimerQelt, boost::heap::compare<xbt::HeapComparator<TimerQelt>>> simix_timers;
+
+/** @brief Timer datatype */
+class Timer {
+ double date = 0.0;
+
+public:
+ decltype(simix_timers)::handle_type handle_;
+
+ Timer(double date, simgrid::xbt::Task<void()> callback) : date(date), callback(std::move(callback)) {}
+
+ simgrid::xbt::Task<void()> callback;
+ double get_date() { return date; }
+ void remove();
+
+ template <class F> static inline Timer* set(double date, F callback)
+ {
+ return set(date, simgrid::xbt::Task<void()>(std::move(callback)));
+ }
+
+ template <class R, class T> static inline Timer* set(double date, R (*callback)(T*), T* arg)
+ {
+ return set(date, [callback, arg]() { callback(arg); });
+ }
+
+ static Timer* set(double date, void (*callback)(void*), void* arg);
+ static Timer* set(double date, simgrid::xbt::Task<void()> callback);
+ static double next() { return simix_timers.empty() ? -1.0 : simix_timers.top().first; }
+};
+
+} // namespace simix
+} // namespace simgrid