diff options
author | Petr Mrázek <peterix@gmail.com> | 2014-07-08 08:42:48 +0200 |
---|---|---|
committer | Petr Mrázek <peterix@gmail.com> | 2014-07-08 08:42:48 +0200 |
commit | 9b3ae29a361b4d89897c34750ea170d4433b93be (patch) | |
tree | 8918f9ec0bd051e234ccbc822ebd001e1bc2f084 | |
parent | 19278c853b8ee940240e14e9d9c7cbe52cb760af (diff) | |
download | MultiMC-9b3ae29a361b4d89897c34750ea170d4433b93be.tar MultiMC-9b3ae29a361b4d89897c34750ea170d4433b93be.tar.gz MultiMC-9b3ae29a361b4d89897c34750ea170d4433b93be.tar.lz MultiMC-9b3ae29a361b4d89897c34750ea170d4433b93be.tar.xz MultiMC-9b3ae29a361b4d89897c34750ea170d4433b93be.zip |
Make the FTB packs a set instead of a list.
-rw-r--r-- | logic/InstanceList.cpp | 6 | ||||
-rw-r--r-- | logic/InstanceList.h | 11 |
2 files changed, 13 insertions, 4 deletions
diff --git a/logic/InstanceList.cpp b/logic/InstanceList.cpp index 5a988fd3..8a68c334 100644 --- a/logic/InstanceList.cpp +++ b/logic/InstanceList.cpp @@ -283,9 +283,9 @@ void InstanceList::loadGroupList(QMap<QString, QString> &groupMap) } } -QList<FTBRecord> InstanceList::discoverFTBInstances() +QSet<FTBRecord> InstanceList::discoverFTBInstances() { - QList<FTBRecord> records; + QSet<FTBRecord> records; QDir dir = QDir(MMC->settings()->get("FTBLauncherDataRoot").toString()); QDir dataDir = QDir(MMC->settings()->get("FTBRoot").toString()); if (!dataDir.exists()) @@ -333,7 +333,7 @@ QList<FTBRecord> InstanceList::discoverFTBInstances() record.logo = attrs.value("logo").toString(); record.mcVersion = attrs.value("mcVersion").toString(); record.description = attrs.value("description").toString(); - records.append(record); + records.insert(record); } break; } diff --git a/logic/InstanceList.h b/logic/InstanceList.h index f0bbb7ec..b88a080e 100644 --- a/logic/InstanceList.h +++ b/logic/InstanceList.h @@ -36,14 +36,23 @@ struct FTBRecord QString description; QString instanceDir; QString templateDir; + bool operator ==(const FTBRecord other) const + { + return instanceDir == other.instanceDir; + } }; +inline uint qHash(FTBRecord record) +{ + return qHash(record.instanceDir); +} + class InstanceList : public QAbstractListModel { Q_OBJECT private: void loadGroupList(QMap<QString, QString> &groupList); - QList<FTBRecord> discoverFTBInstances(); + QSet<FTBRecord> discoverFTBInstances(); void loadFTBInstances(QMap<QString, QString> &groupMap, QList<InstancePtr> & tempList); private |