aboutsummaryrefslogtreecommitdiff
path: root/launcher/icons/IconUtils.cpp
diff options
context:
space:
mode:
authorTrial97 <alexandru.tripon97@gmail.com>2023-07-28 01:15:21 +0300
committerTrial97 <alexandru.tripon97@gmail.com>2023-07-28 01:20:05 +0300
commit7e58b965b770ab75c14f2265b7bd7ded081c66b5 (patch)
treee0f15642e591bc87be380922a869f7c4d4251987 /launcher/icons/IconUtils.cpp
parent1ca7e5efe946d24f3898c8623ff1af3ef9dd96e6 (diff)
downloadPrismLauncher-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.cpp39
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