Consult QIcon::fallbackThemeName() even when theme name is empty
We still need to consult fallbackThemeName() when computing the parent list for an individual theme, as the Freedesktop Theme Icon spec mandates that the "hicolor" theme comes last, but we no longer need to do explicit fallback to fallbackThemeName() if a theme is not found. Pick-to: 6.5 6.6 Change-Id: I6c0b5a45d8258c5b6eaa761402944a735b1606ba Reviewed-by: Axel Spoerl <axel.spoerl@qt.io>
This commit is contained in:
parent
dde45bcefb
commit
addde7843f
@ -438,9 +438,8 @@ QThemeIconInfo QIconLoader::findIconHelper(const QString &themeName,
|
|||||||
if (!theme.isValid()) {
|
if (!theme.isValid()) {
|
||||||
theme = QIconTheme(themeName);
|
theme = QIconTheme(themeName);
|
||||||
if (!theme.isValid()) {
|
if (!theme.isValid()) {
|
||||||
qCDebug(lcIconLoader) << "Theme" << themeName << "not found;"
|
qCDebug(lcIconLoader) << "Theme" << themeName << "not found";
|
||||||
<< "trying fallback theme" << fallbackThemeName();
|
return info;
|
||||||
theme = QIconTheme(fallbackThemeName());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -582,10 +581,12 @@ QThemeIconInfo QIconLoader::loadIcon(const QString &name) const
|
|||||||
qCDebug(lcIconLoader) << "Loading icon" << name;
|
qCDebug(lcIconLoader) << "Loading icon" << name;
|
||||||
|
|
||||||
QThemeIconInfo iconInfo;
|
QThemeIconInfo iconInfo;
|
||||||
if (!themeName().isEmpty()) {
|
QStringList visitedThemes;
|
||||||
QStringList visited;
|
if (!themeName().isEmpty())
|
||||||
iconInfo = findIconHelper(themeName(), name, visited);
|
iconInfo = findIconHelper(themeName(), name, visitedThemes);
|
||||||
}
|
|
||||||
|
if (iconInfo.entries.empty() && !fallbackThemeName().isEmpty())
|
||||||
|
iconInfo = findIconHelper(fallbackThemeName(), name, visitedThemes);
|
||||||
|
|
||||||
if (iconInfo.entries.empty())
|
if (iconInfo.entries.empty())
|
||||||
iconInfo = lookupFallbackIcon(name);
|
iconInfo = lookupFallbackIcon(name);
|
||||||
|
@ -732,6 +732,10 @@ void tst_QIcon::fromTheme()
|
|||||||
// named system icon theme.
|
// named system icon theme.
|
||||||
QIcon::setThemeName(""); // Reset user-theme
|
QIcon::setThemeName(""); // Reset user-theme
|
||||||
if (QIcon::themeName().isEmpty()) {
|
if (QIcon::themeName().isEmpty()) {
|
||||||
|
// Test icon from fallback theme even when theme name is empty
|
||||||
|
QIcon::setFallbackThemeName("fallbacktheme");
|
||||||
|
QVERIFY(!QIcon::fromTheme("edit-cut").isNull());
|
||||||
|
|
||||||
// Test icon from fallback path even when theme name is empty
|
// Test icon from fallback path even when theme name is empty
|
||||||
fallbackIcon = QIcon::fromTheme("red");
|
fallbackIcon = QIcon::fromTheme("red");
|
||||||
QVERIFY(!fallbackIcon.isNull());
|
QVERIFY(!fallbackIcon.isNull());
|
||||||
|
Loading…
Reference in New Issue
Block a user