-
-
Notifications
You must be signed in to change notification settings - Fork 1.1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[ui] Refactor the access to the list of recent project files #2637
base: develop
Are you sure you want to change the base?
Conversation
Codecov ReportAll modified and coverable lines are covered by tests ✅
Additional details and impacted files@@ Coverage Diff @@
## develop #2637 +/- ##
========================================
Coverage 69.93% 69.93%
========================================
Files 121 121
Lines 7088 7088
========================================
Hits 4957 4957
Misses 2131 2131 ☔ View full report in Codecov by Sentry. |
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.
Great improvement over the existing code.
In addition to the review comments, it could be great to;
- Move all the code modifying the list of recent projects to the Python side - this should not be the responsibility of the UI, but rather of the code that loads projects.
And few extra notes (could be for later PRs):
- Recent project file management is a good candidate for having its own class, rather than living within the MeshroomApp class. That would improve the separation of responsibilities.
- Projects could also be presented by a dataclass rather than a raw dictionary for improved code readability.
f4aa1e8
to
7d13e06
Compare
The property itself only accesses a list instead of reading the QSettings every single time it is called. It is set once during the application's launch with a full reading, and is then updated without performing extra reading operations every time a file is added to or removed from the list.
When the list of recent project files is updated, there is no attempt to retrieve its thumbnail as the update is said to be "minimal". This minimal update is justified by the lack of use for the thumbnails in the Application part of Meshroom. Thumbnails are only useful when displaying the Homepage, hence their retrieval during Meshroom's initialization. There is only a need to update them once we want to display the Homepage again. The Homepage thus requests an update of the thumbnails before setting its model. If there have been some updates to the list of recent project files, the reading of the QSettings is performed again and thumbnails are retrieved whenever it is possible. Otherwise, nothing happens to prevent useless readings.
Instead of doing it directly within the `_getRecentProjectFiles` method, add a function that attempts to retrieve a thumbnail corresponding to an input project file path.
…jects There is no need to read the QSettings again as the content of `self._recentProjectFiles` reflects their content accurately and they do not store any thumbnail-related information. QSettings will now only be read once, upon Meshroom's start.
It is renamed to `_getRecentProjectFilesFromSettings`.
7d13e06
to
6af4af5
Compare
6af4af5
to
59afac3
Compare
Description
This pull request addresses some performance issues that were detected when interacting with the list of recent project files.
It mostly focuses on refactoring the access to the list of recent project files, which involved reading the QSettings every single time the content of the list was to be accessed, and accessing it far too many times.
It also decouples the need for thumbnails between the homepage and the application: while the homepage needs access to thumbnails (if available) to set up the list of recent project files, the application has no use for them. When the list of project files is edited, there is no need to retrieve the corresponding thumbnail (if it exists) unless the current view is the homepage's.
Finally, it prevents the homepage from performing any such request for thumbnails unless it is actually being displayed.
Performance Summary
QSettings used to be read every single time
recentProjectFiles
was called:=> QSettings are now only read once throughout the lifetime of the Meshroom instance.
Features list
Implementation remarks
Prior to this PR, a call to the
recentProjectFiles
property necessarily involved a full reading of the QSettings, which provides for each entry both a path to the project file itself and a path to its thumbnail (if it exists). Upon the launch of Meshroom alone, if there were 40 project files in the QSettings, these QSettings were fully accessed and read 40 times just to set the homepage properly.recentProjectFiles
is now only an accessor to a list that is filled and edited in other calls, and which is initialized with a full reading of the QSettings when Meshroom is started, and never again during the lifetime of the instance. QSettings are thus only read once.From there, any project file that is added or deleted leads to an update of the QSettings, but these settings are not read again to update the content of
recentProjectFiles
:recentProjectFiles
is updated directly within these methods, ensuring it is always accurately reflecting the content of the QSettings.When a project file is added, only the path to the project is added to the QSettings; there is no attempt to retrieve the thumbnail. However, a flag indicating that there may be some thumbnail paths to retrieve will be set.
When the homepage will become the current view again, it will request an update of the thumbnails. If the flag is set (meaning at least a file has been added to the list), all the project files in
recentProjectFiles
will be parsed in an attempt to retrieve their thumbnails. Otherwise (meaning that files have either been deleted or nothing has happened), nothing will happen.