QIcon::fromTheme(): add support for absolute paths.

This allows methods that return an icon name, to sometimes also
return an icon full path (e.g. because the icon was dynamically generated
and stored into a local cache on disk)

Change-Id: Ib01c3955f4b64236463846241d9814b2d0686634
Reviewed-by: Olivier Goffart (Woboq GmbH) <ogoffart@woboq.com>
This commit is contained in:
David Faure 2016-02-05 12:22:26 +01:00
parent e8ed29d679
commit bbc830ce3e
2 changed files with 7 additions and 0 deletions

View File

@ -51,6 +51,7 @@
#include "qvariant.h" #include "qvariant.h"
#include "qcache.h" #include "qcache.h"
#include "qdebug.h" #include "qdebug.h"
#include "qdir.h"
#include "qpalette.h" #include "qpalette.h"
#include "qmath.h" #include "qmath.h"
@ -1171,6 +1172,8 @@ QIcon QIcon::fromTheme(const QString &name)
if (qtIconCache()->contains(name)) { if (qtIconCache()->contains(name)) {
icon = *qtIconCache()->object(name); icon = *qtIconCache()->object(name);
} else if (QDir::isAbsolutePath(name)) {
return QIcon(name);
} else { } else {
QPlatformTheme * const platformTheme = QGuiApplicationPrivate::platformTheme(); QPlatformTheme * const platformTheme = QGuiApplicationPrivate::platformTheme();
bool hasUserTheme = QIconLoader::instance()->hasUserTheme(); bool hasUserTheme = QIconLoader::instance()->hasUserTheme();

View File

@ -642,6 +642,10 @@ void tst_QIcon::fromTheme()
QIcon::setThemeName(""); QIcon::setThemeName("");
abIcon = QIcon::fromTheme("address-book-new"); abIcon = QIcon::fromTheme("address-book-new");
QVERIFY(abIcon.isNull()); QVERIFY(abIcon.isNull());
// Passing a full path to fromTheme is not very useful, but should work anyway
QIcon fullPathIcon = QIcon::fromTheme(m_pngImageFileName);
QVERIFY(!fullPathIcon.isNull());
} }
void tst_QIcon::fromThemeCache() void tst_QIcon::fromThemeCache()