SWING_TIMER_STOP not firing after some SWING_TIMER_UPDATE events
hypernormalisation opened this issue ยท 1 comments
As in title. attack speed changes can in some situations prevent the SWING_TIMER_STOP event firing.
Attached is a video where my addon is printing out the library's callbacks to the chat, and you can see that when my DST procs, we get the SWING_TIMER_UPDATE event without any stop event afterwards.
2022-10-01.04-10-37.mp4
Tracked this down to the code at Lines 267-272:
https://github.com/Ralgathor/LibClassicSwingTimerAPI/blob/main/LibClassicSwingTimerAPI.lua#L267
Every time an attack speed update gets triggered, the code is cancelling the mainhand/offhand timers, even when the attack speeds have not changed, which is sometimes happening in my testing when UNIT_ATTACK_SPEED has fired.
Taking the code to cancel the timers inside the code block that checks for a non-expired swing and an attack speed change should solve this.
I'll open a pull request.