From a57cf443edbe3d86aaf449225df3d5defe48bc9a Mon Sep 17 00:00:00 2001 From: Max Kellermann Date: Tue, 22 Nov 2022 21:36:44 +0100 Subject: [PATCH] event/Loop: set "again" in AddDefer() only if HAVE_THREADED_EVENT_LOOP Only AddDefer()/AddIdle() calls from within DeferEvents are relevant. --- src/event/Loop.cxx | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/src/event/Loop.cxx b/src/event/Loop.cxx index 143de568e..5a83ba9a6 100644 --- a/src/event/Loop.cxx +++ b/src/event/Loop.cxx @@ -188,7 +188,12 @@ EventLoop::AddDefer(DeferEvent &e) noexcept #endif defer.push_back(e); + +#ifdef HAVE_THREADED_EVENT_LOOP + /* setting this flag here is only relevant if we've been + called by a DeferEvent */ again = true; +#endif } void @@ -197,7 +202,12 @@ EventLoop::AddIdle(DeferEvent &e) noexcept assert(IsInside()); idle.push_back(e); + +#ifdef HAVE_THREADED_EVENT_LOOP + /* setting this flag here is only relevant if we've been + called by a DeferEvent */ again = true; +#endif } void