-
Notifications
You must be signed in to change notification settings - Fork 128
Work Files: Fix parenting of save prompt QMessageBox #2784
Work Files: Fix parenting of save prompt QMessageBox #2784
Conversation
- Setting the windowFlags without the original messagebox.windowFlags() was the culprit as to why the messagebox previously wouldn't show when parented. Likely because then it's missing the Dialog window flag and thus would try to embed itself into the parent UI, which you then cannot exec() (cherry picked from commit 290e2b6)
It's a trend. :) Although not as nice as this |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The crash in blender is "occasional" so it is hard to test. I would recommend to keep store it in the attribute, as it won't affect your change.
EDITED:
I don't think it is still an issue but blender is already so broken so why to break it even more? :)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I accidentally approved.
@iLLiCiTiT since the original comment mentioned this:
I felt like the issue originally in blender was purely due to the parent relationship not existing in the first place and thus the messagebox getting garbage collected. (Due to how Blender would process events even if you'd explicitly call Should we maybe just try and see if this now holds up in Blender as is? Maybe with just doing some preliminary testing - because I do recall the original crash was somewhat reproducable. The original implementation of storing the messagebox came from here which also describes that. It also came up here as:
Which should now also be solved with the parenting. Other issues related to crashes in blender all seemed to be related to the Window instead of the Message Box. @simonebarbieri and @Tilix4 any chance you could try and get this to crash in Blender? :) Specifically using the Work Files such that it'd prompt to save the current scene. E.g. currently having an active scene open with unsaved modifications, and then clicking in the workfiles tool to open an existing file? |
I can confirm that it works on windows (even without For me it is worth it to store the dialog into attribute just to make sure it is not garbage collected. It affects nothing. |
- This is NOT done because the original crash was reproducible - but just out of pure legacy reasons for if the error might still occur. It would be worth looking into whether the crash can still be reproduced in recent Blender versions without this logic.
I'd rather avoid keeping around legacy code that we might not need. Anyway, reverted that with this commit bb10520 I did include this in the commit message:
Just so it won't confuse anyone in the future why that got added back in. Let me know if you still want to change something. :) |
Brief description
This makes the save prompt messagebox an actual child to the parent Qt UI element.
Resolves issue
This fixes the save prompt appearing behind the workfiles UI in Fusion.
Description
Original "crash" case
Setting the windowFlags without the original messagebox.windowFlags() was the culprit as to why the messagebox previously wouldn't show when parented. Likely because then it's missing the Dialog window flag and thus would try to embed itself into the parent UI, which you then cannot exec()
Additional Context
(cherry picked from commit 290e2b6)
Testing notes:
I tested in Fusion 17 and Maya 2020 - those worked fine. ✅