D9978: [Notifications] Put history into a ListView
Kai Uwe Broulik
noreply at phabricator.kde.org
Fri Jan 19 08:55:48 UTC 2018
broulik created this revision.
broulik added reviewers: Plasma, davidedmundson.
Restricted Application added a project: Plasma.
Restricted Application added a subscriber: plasma-devel.
broulik requested review of this revision.
REVISION SUMMARY
Notification uses Repeaters for everything. While this is acceptable for jobs and notifications, of which there are few, the history can turn into a very long list of items. Using a ListView solves memory consumption by creating delegates only as needed.
Since regular notifications and notification history are quite entangled with each other, I had to configure the ListView from within the Notifications loader. To keep code changes as little as possible, the rest of the UI is just moved into the ListView header item.
While this is quite an invasive patch for a feature frozen version it's the least invasive approach I could find and is quite an important memory leak fix for an LTS.
BUG: 389132
FIXED-IN: 5.12.0
CHANGELOG: Fixed memory leak when there are a lot of items in notification history
TEST PLAN
Looks just like before
F5663539: Screenshot_20180119_093731.png <https://phabricator.kde.org/F5663539>
- Spawned a gazillion notifications, verified that RAM consumption doesn't go through the roof.
- Copied some files, could observe job status at the top of notifications, expanding details and canceling the job worked. Scrolling down did not result in the job delegate being destroyed.
- Spawned a persistent notification, it showed up above the history
- Dismissing persistenet notification in the popup by clicking X button worked fine
- Dismissing history item by clicking X button worked fine
- Interactive screenshot preview worked just fine when in the history
- Disabled history, history was cleared
- Disabled job progress, jobs weren't shown anymore
REPOSITORY
R120 Plasma Workspace
REVISION DETAIL
https://phabricator.kde.org/D9978
AFFECTED FILES
applets/notifications/package/contents/ui/NotificationDelegate.qml
applets/notifications/package/contents/ui/Notifications.qml
applets/notifications/package/contents/ui/main.qml
To: broulik, #plasma, davidedmundson
Cc: plasma-devel, ZrenBot, progwolff, lesliezhai, ali-mohamed, jensreuterberg, abetts, sebas, apol, mart
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.kde.org/pipermail/plasma-devel/attachments/20180119/9a625db3/attachment.html>
More information about the Plasma-devel
mailing list