1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
|
Read visualisations from subdirs
https://bugs.gentoo.org/917064
https://github.com/clementine-player/Clementine/issues/7151
--- a/src/visualisations/projectmpresetmodel.cpp
+++ b/src/visualisations/projectmpresetmodel.cpp
@@ -27,22 +27,26 @@
#endif
#include <QDir>
+#include <QDirIterator>
#include <QtDebug>
+#include <set>
ProjectMPresetModel::ProjectMPresetModel(ProjectMVisualisation* vis,
QObject* parent)
: QAbstractItemModel(parent), vis_(vis) {
// Find presets
- QDir preset_dir(vis_->preset_url());
- QStringList presets(
- preset_dir.entryList(QStringList() << "*.milk"
- << "*.prjm",
+ QDirIterator it(vis_->preset_url(),
+ QStringList() << "*.milk" << "*.prjm",
QDir::Files | QDir::NoDotAndDotDot | QDir::Readable,
- QDir::Name | QDir::IgnoreCase));
+ QDirIterator::Subdirectories);
+ std::set<std::pair<QString, QString>> files;
+ while (it.hasNext()) {
+ it.next();
+ files.insert({it.filePath(), it.fileName()});
+ }
- for (const QString& filename : presets) {
- all_presets_ << Preset(preset_dir.absoluteFilePath(filename), filename,
- false);
+ for (const auto& [filePath, fileName] : files) {
+ all_presets_ << Preset(filePath, fileName, false);
}
}
--- a/src/visualisations/projectmvisualisation.cpp
+++ b/src/visualisations/projectmvisualisation.cpp
@@ -93,7 +93,7 @@ void ProjectMVisualisation::InitProjectM() {
if (!QFile::exists(path)) continue;
// Don't use empty directories
- if (QDir(path).entryList(QDir::Files | QDir::NoDotAndDotDot).isEmpty())
+ if (QDir(path).entryList(QDir::Dirs | QDir::Files | QDir::NoDotAndDotDot).isEmpty())
continue;
preset_path = path;
|