X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fuisupport%2Ficon.cpp;h=9a6a52887b6a66f3404fac7bee9f812bc4525450;hp=3694a3a20649851afd1974fca11be2b54cc9f2ee;hb=c27d5bfbe80bfeb583a25404f4ccee4b70b010e0;hpb=b99ff5e5d79924cffe794574cab7c92ad99cc2a2 diff --git a/src/uisupport/icon.cpp b/src/uisupport/icon.cpp index 3694a3a2..9a6a5288 100644 --- a/src/uisupport/icon.cpp +++ b/src/uisupport/icon.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-08 by the Quassel IRC Team * + * Copyright (C) 2005-2018 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -15,27 +15,73 @@ * You should have received a copy of the GNU General Public License * * along with this program; if not, write to the * * Free Software Foundation, Inc., * - * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * ***************************************************************************/ #include "icon.h" -#include "iconloader.h" -Icon::Icon() : QIcon() { +#include + +#include + +namespace icon { + +namespace { + +void printWarning(const QString &iconName, const QString &extra = {}) +{ + static std::set warnedAbout; + if (warnedAbout.insert(iconName).second) { + qWarning() << "Missing icon:" << iconName << qPrintable(extra); + } +} } -Icon::Icon(const QString &name) : QIcon() { - addPixmap(IconLoader::global()->loadIcon(name, IconLoader::Desktop)); + +QIcon get(const QString &iconName, const QString &fallbackPath) +{ + return get(std::vector{iconName}, fallbackPath); } -Icon::Icon(const QIcon& copy) : QIcon(copy) { +QIcon get(const std::vector &iconNames, const QString &fallbackPath) +{ + for (auto &&iconName : iconNames) { + // Exact match + if (QIcon::hasThemeIcon(iconName)) { + return QIcon::fromTheme(iconName); + } + } + + for (auto &&iconName : iconNames) { + // Try to get something from the theme anyway (i.e. a more generic fallback) + QIcon fallback = QIcon::fromTheme(iconName); + if (!fallback.availableSizes().isEmpty()) { + printWarning(iconName, QString{"(using fallback: \"%1\")"}.arg(fallback.name())); + return fallback; + } + } + + // Build error string + QStringList requested; + for (auto &&iconName : iconNames) { + requested << iconName; + } + QString missing = "{" + requested.join(", ") + "}"; + + // Nothing from the theme, so try to load from path if given + if (!fallbackPath.isEmpty()) { + QIcon fallback{fallbackPath}; + if (!fallback.availableSizes().isEmpty()) { + printWarning(missing, QString{"(using fallback: \"%1\")"}.arg(fallbackPath)); + return fallback; + } + } + + // Meh. + printWarning(missing); + return {}; } -Icon& Icon::operator=(const Icon &other) { - if (this != &other) { - QIcon::operator=(other); - } - return *this; }