Details
-
Bug
-
Resolution: Done
-
P2: Important
-
5.11.2
-
Mingw-w64 with g++ 8.1
-
-
589f9f179cd0f570db22f15941625d911f6b7721 (qt/qtbase/5.12), 34f1b6b6d (dev), 3b5fcd490 (6.9), 49bf88798 (6.8)
Description
I am using Qt 4 and Qt 5 with Mingw-w64 as compiler. I have subclassed QFileDialog and in the constructor I restore the dialog state like this:
QSettings settings("Organization", "Application"); QVariant state = settings.value("DialogFile"); restoreState(state.toByteArray());
To save the directory when closing I have overwritten the done(int) slot like this:
void DialogFile::done(int returnCode) { QSettings settings("Organization", "Application"); settings.setValue("DialogFile", saveState()); QFileDialog::done(returnCode); }
This has worked well in Qt 4, but since Qt 5 the directory is not correctly restored when I open the file dialog for the first time. There the dialog displays always the working directory of the application. When I navigate to another directory and open a file there, then the correct directory (the last visited directory) will be displayed as soon as I open the file dialog again.
I have used the debugger to find the reason. QFileDialog::restoreState contains suspicious code. It gets "QUrl currentDirectory" from the state that is passed as argument. This directory URL is correct. But then it refuses to use the correct URL, because in the line
setDirectoryUrl(lastVisitedDir()->isEmpty() ? currentDirectory : *lastVisitedDir());
the value of lastVisitedDir() is not empty. It contains the working directory of the application. So the dialog will use the working directory.
Isn't this completely wrong behaviour? If I call a method to restore a given state, then the state should be used and not another variable containing some supposed (but wrong) last visited directory.
I wonder why this issue is not reported much more often. Has it something to do with my compiler (Mingw-w64)?
Benjamin