diff options
author | Nat Goodspeed <nat@lindenlab.com> | 2024-05-03 09:27:16 -0400 |
---|---|---|
committer | Nat Goodspeed <nat@lindenlab.com> | 2024-05-03 09:27:16 -0400 |
commit | 922277764d41e96a1c41291272bb70e3a1b8c677 (patch) | |
tree | f1a3aed9d658b4e26bf9c1d18e0bb19531e7649e /indra/llui/llf32uictrl.cpp | |
parent | 5e64fd06a6281eb4b7cc0e30b3d8dae62c264603 (diff) |
Prevent LLLater from thrashing on LLCallbackList.
If there is exactly one doPeriodically() entry on LLLater, the mQueue entry is
deleted before Periodic::operator()() is called. If Periodic's callable
returns false, it reinstates itself on mQueue for a future time. That's okay,
because the test for mQueue.empty(), and the consequent disconnect from
LLCallbackList, happens only after that Periodic call returns.
But at the moment Periodic reinstates itself on mQueue, mQueue happens to be
empty. That alerts doAtTime2() to register itself on LLCallbackList -- even
though at that moment it's already registered.
Semantically that's okay because assigning to the LLLater's
LLCallbackList::temp_handle_t should implicitly disconnect the previous
connection. But it's pointless to create a new connection and disconnect the
old one every time we call that lone Periodic.
Add a test for mLive.connected(); that way if we already have an
LLCallbackList connection, we retain it instead of replacing it with a new
one.
Diffstat (limited to 'indra/llui/llf32uictrl.cpp')
0 files changed, 0 insertions, 0 deletions