AmaranthineCodices / chrysanthemum

A content filtration bot for Discord.
3 stars 2 forks source link

Fix hellish cache deadlock #28

Closed AmaranthineCodices closed 2 years ago

AmaranthineCodices commented 2 years ago

For a while now Chrysanthemum has been plagued by a deadlock in message edit filtering. I've only now had the time to sit down and figure out what's going on. Essentially, Chrysanthemum, after filtering a message edit, locks up completely, sometimes. The sequence of events looks something like:

The fix is to clone data out of the cache, so that we don't hold a reference to it for very long. This is unfortunate for efficiency reasons, but we can live with it.