From: Christopher Dykes Date: Tue, 16 Aug 2016 22:44:03 +0000 (-0700) Subject: Use a base hook rather than a member hook for EventBase callbacks X-Git-Tag: v2016.08.22.00~28 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=5d242d14dcca79124ed477b246730353f6f76dc2;p=folly.git Use a base hook rather than a member hook for EventBase callbacks Summary: Using boost intrusive member hooks in complex inheritence heirarchies under MSVC is [unsupported](http://www.boost.org/doc/libs/1_61_0/doc/html/intrusive/usage.html#intrusive.usage.usage_member_hook), and, in combination with a [regression in VS 2015 Update 2](https://connect.microsoft.com/VisualStudio/Feedback/Details/2555433) that is not fixed in Update 3, the async socket tests that use this compile under MSVC, but fail at runtime because the hook pointer ends up pointing at the node's vtable rather than the hook. This just works around the issue by using a base hook instead. Reviewed By: djwatson Differential Revision: D3724521 fbshipit-source-id: a55e36a2e79a15d9943b6090f6194fd480e19074 --- diff --git a/folly/io/async/EventBase.h b/folly/io/async/EventBase.h index 6a508129..7f8aaeb8 100644 --- a/folly/io/async/EventBase.h +++ b/folly/io/async/EventBase.h @@ -136,29 +136,24 @@ class EventBase : private boost::noncopyable, * If a LoopCallback object is destroyed while it is scheduled to be run in * the next loop iteration, it will automatically be cancelled. */ - class LoopCallback { + class LoopCallback + : public boost::intrusive::list_base_hook< + boost::intrusive::link_mode> { public: virtual ~LoopCallback() = default; virtual void runLoopCallback() noexcept = 0; void cancelLoopCallback() { - hook_.unlink(); + unlink(); } bool isLoopCallbackScheduled() const { - return hook_.is_linked(); + return is_linked(); } private: - typedef boost::intrusive::list_member_hook< - boost::intrusive::link_mode > ListHook; - - ListHook hook_; - typedef boost::intrusive::list< LoopCallback, - boost::intrusive::member_hook, boost::intrusive::constant_time_size > List; // EventBase needs access to LoopCallbackList (and therefore to hook_)