diff options
author | Trial97 <alexandru.tripon97@gmail.com> | 2023-07-28 01:15:21 +0300 |
---|---|---|
committer | Trial97 <alexandru.tripon97@gmail.com> | 2023-07-28 01:20:05 +0300 |
commit | 7e58b965b770ab75c14f2265b7bd7ded081c66b5 (patch) | |
tree | e0f15642e591bc87be380922a869f7c4d4251987 /launcher/icons/IconUtils.cpp | |
parent | 1ca7e5efe946d24f3898c8623ff1af3ef9dd96e6 (diff) | |
download | PrismLauncher-7e58b965b770ab75c14f2265b7bd7ded081c66b5.tar.gz PrismLauncher-7e58b965b770ab75c14f2265b7bd7ded081c66b5.tar.bz2 PrismLauncher-7e58b965b770ab75c14f2265b7bd7ded081c66b5.zip |
refactor icon list
Signed-off-by: Trial97 <alexandru.tripon97@gmail.com>
Diffstat (limited to 'launcher/icons/IconUtils.cpp')
-rw-r--r-- | launcher/icons/IconUtils.cpp | 39 |
1 files changed, 10 insertions, 29 deletions
diff --git a/launcher/icons/IconUtils.cpp b/launcher/icons/IconUtils.cpp index 39830bc2..99c38f47 100644 --- a/launcher/icons/IconUtils.cpp +++ b/launcher/icons/IconUtils.cpp @@ -38,17 +38,14 @@ #include <QDirIterator> #include "FileSystem.h" -#include <array> - namespace { -std::array<const char*, 6> validIconExtensions = { { "svg", "png", "ico", "gif", "jpg", "jpeg" } }; +static const QStringList validIconExtensions = { { "svg", "png", "ico", "gif", "jpg", "jpeg" } }; } namespace IconUtils { QString findBestIconIn(const QString& folder, const QString& iconKey) { - int best_found = validIconExtensions.size(); QString best_filename; QDirIterator it(folder, QDir::NoDotAndDotDot | QDir::Files, QDirIterator::NoIteratorFlags); @@ -56,36 +53,20 @@ QString findBestIconIn(const QString& folder, const QString& iconKey) it.next(); auto fileInfo = it.fileInfo(); - if (fileInfo.completeBaseName() != iconKey) - continue; - - auto extension = fileInfo.suffix(); - - for (int i = 0; i < best_found; i++) { - if (extension == validIconExtensions[i]) { - best_found = i; - qDebug() << i << " : " << fileInfo.fileName(); - best_filename = fileInfo.fileName(); - } - } + if (fileInfo.completeBaseName() == iconKey && isIconSuffix(fileInfo.suffix())) + return fileInfo.absoluteFilePath(); } - return FS::PathCombine(folder, best_filename); + return {}; } QString getIconFilter() { - QString out; - QTextStream stream(&out); - stream << '('; - for (size_t i = 0; i < validIconExtensions.size() - 1; i++) { - if (i > 0) { - stream << " "; - } - stream << "*." << validIconExtensions[i]; - } - stream << " *." << validIconExtensions[validIconExtensions.size() - 1]; - stream << ')'; - return out; + return "(*." + validIconExtensions.join(" *.") + ")"; +} + +bool isIconSuffix(QString suffix) +{ + return validIconExtensions.contains(suffix); } } // namespace IconUtils |