[Differential] [Request, 31 lines] D4362: RFC: [AppletQuickItem] Cache QQmlComponent used for settings QtQuick Controls 1 style

Kai Uwe Broulik noreply at phabricator.kde.org
Tue Jan 31 10:38:00 UTC 2017


broulik created this revision.
broulik added a reviewer: Plasma.
broulik set the repository for this revision to R242 Plasma Framework (Library).
Restricted Application added projects: Plasma, Frameworks.
Restricted Application added subscribers: Frameworks, plasma-devel.

REVISION SUMMARY
  Plasma spends roughly 0.5ms per applet just compiling this component (QQmlComponent creation), so cache it away.
  All applets did share the same QQmlEngine here but I don't think this can be trusted, hence store the components in a QHash per engine.
  While at it, turn the Item into a QtObject to reduce overhead since we just want the Component.onCompleted to be executed and that's it.
  
  Before: 41 calls (18ms in total)
  After: 41 calls (1.9ms in total)

TEST PLAN
  Verified that a QtQuick Controls 1 Button still uses the Plasma theme.
  
  The QObject::destroyed I use to remove the component from the hash again is never executed, even on kquitapp plasmashell.

REPOSITORY
  R242 Plasma Framework (Library)

REVISION DETAIL
  https://phabricator.kde.org/D4362

AFFECTED FILES
  src/plasmaquick/appletquickitem.cpp
  src/plasmaquick/private/appletquickitem_p.h

EMAIL PREFERENCES
  https://phabricator.kde.org/settings/panel/emailpreferences/

To: broulik, #plasma
Cc: plasma-devel, #frameworks, lesliezhai, ali-mohamed, jensreuterberg, abetts, sebas
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.kde.org/pipermail/plasma-devel/attachments/20170131/d171b244/attachment.html>


More information about the Plasma-devel mailing list