[Linux] maximizing and restoring the Notes window freezes / hangs the application
moritz1000 opened this issue ยท 14 comments
I am using Arch Linux & KDE.
Recording.Notes.mp4
Steps to reproduce:
- Maximize Notes
- Restore Notes to the original size
-> Freeze / Hang
-> Can't interact with the window anymore / type something
You need to kill the application and restart it in order to use it again.
It does not matter whether I am using the "use native window frame" option or not.
Hi, thanks for reporting. This is a known issue but we forgot to create an issue for this.
The problem is somewhere in the newest Qt version (6.5), because the problem does not appear on Qt 6.4.3. We created a bug report here: https://bugreports.qt.io/browse/QTBUG-115459.
An alternative for you is to use the appimage instead, until this bug is fixed.
An alternative for you is to use the appimage instead, until this bug is fixed.
Thank you for the workaround.
I guess this should be another bug report but I just want to point out that your AppImage is not playing nicely with AppImageLauncher.
I use AppImageLauncher with all my other AppImages without any problems.
In the case of Notes I had to uninstall AppImageLauncher & restart my system in order for the Notes AppImage to launch.
EDIT: Can't reproduce since I can't get AppImageLauncher to work again, broke it while troubleshooting. The last release of AppImageLauncher was Sep 29, 2020 so maybe that's the problem.
@moritz1000 Can you please open a new issue for this problem?
This one also affects Windows, by the way.
Another alternative to Linux users is to use the Flatpak version, which still uses Qt 6.4.
But yeah, this is a pretty annoying one. :(
I think I found a consistent way to trigger/prevent the freezing.
Steps to force the app to freeze:
-
Exit Notes
-
Open
Settings.ini
with a text editor -
Replace the entire
windowGeometry
line by this:windowGeometry=@ByteArray(\x1\xd9\xd0\xcb\0\x3\0\0\0\0\x1\x96\0\0\0\xa3\0\0\x5\xe7\0\0\x3u\0\0\x1\x96\0\0\0\xc0\0\0\x5\xe7\0\0\x3u\0\0\0\0\0\0\0\0\a\x80\0\0\x1\x96\0\0\0\xc0\0\0\x5\xe7\0\0\x3u)
-
Save the file
-
Open Notes
-
Select/Create a note that's not empty
-
Maximizing/restoring the window should freeze the app
Steps to prevent the app from freezing:
-
Exit Notes
-
Open
Settings.ini
with a text editor -
Replace the entire
windowGeometry
line by this:windowGeometry=@ByteArray(\x1\xd9\xd0\xcb\0\x3\0\0\0\0\x1#\0\0\0\xe5\0\0\x6\"\0\0\x3\x96\0\0\x1#\0\0\x1\x2\0\0\x6\"\0\0\x3\x96\0\0\0\0\0\0\0\0\a\x80\0\0\x1#\0\0\x1\x2\0\0\x6\"\0\0\x3\x96)
-
Save the file
-
Open Notes
-
Select/Create a note that's not empty.
-
Maximizing/restoring the window should not freeze the app
I haven't looked into what these values mean yet, but these steps have worked on my Linux machine, but it'd be good to get another confirmation on this... Additionally, and unfortunately, I still haven't found a way to reproduce this with a minimal example so we can report it to Qt devs. =(
If you're going to test this, just remember to do it with a Qt 6.5.x build. This is not reproducible with any of the official binaries we release, since they still use Qt 6.4.x.
I haven't tested this yet, have you tried printing the window geometry to see if there's anything unusual with the problematic one?
No yet, no. I'll definitely look into that though - unless someone beats me to it.
I forgot to post an update on this, but in short:
I reported this upstream, and I also managed to create a minimal, reproducible example that triggers the bug only with Qt 6.5+, but unfortunately there hasn't been an official follow up yet.
Instead of waiting on upstream, perhaps we can find a workaround in our code base instead...
If someone wants to give this a look, essentially, the app freezes in CustomDocument::setDocumentPadding()
, after calling QAbstractScrollArea::setViewportMargins()
.
The call stack looks basically like this:
Weird... I can't reproduce this on Windows 10 with Qt 6.5.2 MinGW 64bit.
EDIT: nor with Qt 6.6.1 on Windows 10.
@nuttyartist Did you try reproducing it with default settings? And with actual text inside the textEdit
widget?
Also, can you try reproducing it with this small project?
Just build it as usual (cmake -B build && cmake --build build
), run the program, and simply maximize and unmaximize the window.
It should freeze after that...
Did you try reproducing it with default settings? And with actual text inside the textEdit widget?
Yes, straight from master. And yes, with some text.
Also, can you try reproducing it with this small project?
Yes, this one hangs.
Weird.
bug.mp4
Good news: This bug has been fixed in Qt 6.6.3!
I'll leave this open until 6.6.3 is released, which should be at the end of February, and then we can upgrade our official packages to use that version.
EDIT: Qt 6.6 release plan: https://wiki.qt.io/Qt_6.6_Release
Qt 6.6.3 has been out for quite a while now, and since the v2.2.1 binaries we distribute still use Qt 6.4 (where this issue is not present), I think we can close this.