}
// The CobTimeout object was allocated on the heap by runAfterDelay(),
- // so delete it now that it has fired.
- delete this;
-}
-
-void EventBase::CobTimeout::callbackCanceled() noexcept {
- // The CobTimeout object was allocated on the heap by runAfterDelay(),
- // so delete it now that it has been canceled.
+ // so delete it now that the it has fired.
delete this;
}
}
VLOG(5) << "EventBase(): Created.";
initNotificationQueue();
- wheelTimer_ = HHWheelTimer::UniquePtr(new HHWheelTimer(this));
RequestContext::saveContext();
}
throw std::invalid_argument("EventBase(): event base cannot be nullptr");
}
initNotificationQueue();
- wheelTimer_ = HHWheelTimer::UniquePtr(new HHWheelTimer(this));
RequestContext::saveContext();
}
// (Note that we don't fire them. The caller is responsible for cleaning up
// its own data structures if it destroys the EventBase with unfired events
// remaining.)
- wheelTimer_->cancelAll();
+ while (!pendingCobTimeouts_.empty()) {
+ CobTimeout* timeout = &pendingCobTimeouts_.front();
+ delete timeout;
+ }
while (!runBeforeLoopCallbacks_.empty()) {
delete &runBeforeLoopCallbacks_.front();
bool EventBase::tryRunAfterDelay(const Cob& cob,
int milliseconds,
TimeoutManager::InternalEnum in) {
- // A previous implementation could fail, and the API is retained for
- // backwards compatibility.
- wheelTimer_->scheduleTimeout(
- new CobTimeout(cob),
- std::chrono::milliseconds(milliseconds));
+ CobTimeout* timeout = new CobTimeout(this, cob, in);
+ if (!timeout->scheduleTimeout(milliseconds)) {
+ delete timeout;
+ return false;
+ }
+ pendingCobTimeouts_.push_back(*timeout);
return true;
}
#include <glog/logging.h>
#include <folly/io/async/AsyncTimeout.h>
-#include <folly/io/async/HHWheelTimer.h>
#include <folly/io/async/TimeoutManager.h>
#include <folly/io/async/Request.h>
#include <folly/Executor.h>
// small object used as a callback arg with enough info to execute the
// appropriate client-provided Cob
- class CobTimeout : public HHWheelTimer::Callback {
+ class CobTimeout : public AsyncTimeout {
public:
- explicit CobTimeout(const Cob& c) : cob_(c) {}
+ CobTimeout(EventBase* b, const Cob& c, TimeoutManager::InternalEnum in)
+ : AsyncTimeout(b, in), cob_(c) {}
- void timeoutExpired() noexcept override;
-
- void callbackCanceled() noexcept override;
+ virtual void timeoutExpired() noexcept;
private:
Cob cob_;
+
+ public:
+ typedef boost::intrusive::list_member_hook<
+ boost::intrusive::link_mode<boost::intrusive::auto_unlink> > ListHook;
+
+ ListHook hook;
+
+ typedef boost::intrusive::list<
+ CobTimeout,
+ boost::intrusive::member_hook<CobTimeout, ListHook, &CobTimeout::hook>,
+ boost::intrusive::constant_time_size<false> > List;
};
typedef LoopCallback::List LoopCallbackList;
void initNotificationQueue();
- HHWheelTimer::UniquePtr wheelTimer_;
+ CobTimeout::List pendingCobTimeouts_;
LoopCallbackList loopCallbacks_;
LoopCallbackList runBeforeLoopCallbacks_;