Listen for signals instead of polling
rockerbacon opened this issue · 2 comments
I took a quick look at the code and it seems that the extension frequently polls the windows and applies the updates. I was curious if there was any specific reason for doing it like that instead of listening for the app's windows-changed
signal, for example.
One difference I can notice between this extension and auto-move-windows - which does use the aforementioned signal - is that that extension moves windows very quickly, before they're visible. With smart-auto-move, the windows sometimes flicker on the currently active workspace before being moved to their proper location.
I haven't modified the code to confirm whether the polling is the cause but I strongly suspect that it is.
this was actually how smart-auto-move was originally implemented: 00c189e
however, due to a limitation with the window-changed
signal handler, it is not actually possible to manipulate window properties inside of the callback, so it was necessary to workaround this by returning control to the main loop and then moving the window in another context.
from the linked changelist:
there is a fixed delay of 4000ms between when a window is created and when smart-auto-move restores its position. this is due to a limitation of the
windows-changed
signal. changing a window's frame rect inside of this handler does not actually move the window, so it instead needs to happen in the Mainloop. rather than using a fixed delay before restoring a window, it may be possible to poll the window's frame rect to determine if it is ready to be moved. this may be as simple as checking if the rect is currently set to all0
values.
that said, it may be worth re-evaluating this approach, as there are some bugs and issues with the time based approach, such as #31