diff options
author | Petr Mrázek <peterix@gmail.com> | 2016-11-09 01:22:02 +0100 |
---|---|---|
committer | Petr Mrázek <peterix@gmail.com> | 2016-11-09 01:22:02 +0100 |
commit | b6f133f579d77d4fa8d403448dd951563cda1a22 (patch) | |
tree | def67e5b0522e66ba160bfc3477a67b83ac52be7 | |
parent | 01649f761d4839bd7a6f471f7f79acc02654676b (diff) | |
download | MultiMC-b6f133f579d77d4fa8d403448dd951563cda1a22.tar MultiMC-b6f133f579d77d4fa8d403448dd951563cda1a22.tar.gz MultiMC-b6f133f579d77d4fa8d403448dd951563cda1a22.tar.lz MultiMC-b6f133f579d77d4fa8d403448dd951563cda1a22.tar.xz MultiMC-b6f133f579d77d4fa8d403448dd951563cda1a22.zip |
GH-1713 fix FTB loading crashes
-rw-r--r-- | api/logic/InstanceList.cpp | 5 | ||||
-rw-r--r-- | api/logic/minecraft/ftb/FTBInstanceProvider.cpp | 16 | ||||
-rw-r--r-- | application/MultiMC.cpp | 2 |
3 files changed, 11 insertions, 12 deletions
diff --git a/api/logic/InstanceList.cpp b/api/logic/InstanceList.cpp index 9bdcc113..2c1e9e06 100644 --- a/api/logic/InstanceList.cpp +++ b/api/logic/InstanceList.cpp @@ -159,7 +159,10 @@ InstanceList::InstListError InstanceList::loadList(bool complete) else { InstancePtr instPtr = provider->loadInstance(id); - newList.append(instPtr); + if(instPtr) + { + newList.append(instPtr); + } } } }; diff --git a/api/logic/minecraft/ftb/FTBInstanceProvider.cpp b/api/logic/minecraft/ftb/FTBInstanceProvider.cpp index a583c039..1321ea1b 100644 --- a/api/logic/minecraft/ftb/FTBInstanceProvider.cpp +++ b/api/logic/minecraft/ftb/FTBInstanceProvider.cpp @@ -236,15 +236,6 @@ InstancePtr FTBInstanceProvider::createInstance(const FTBRecord & record) const qDebug() << "Converting " << record.name << " as new."; - auto mcVersion = std::dynamic_pointer_cast<MinecraftVersion>(ENV.getVersion("net.minecraft", record.mcVersion)); - if (!mcVersion) - { - qCritical() << "Can't load instance " << record.instanceDir - << " because minecraft version " << record.mcVersion - << " can't be resolved."; - return nullptr; - } - if (!rootDir.exists() && !rootDir.mkpath(".")) { qCritical() << "Can't create instance folder" << record.instanceDir; @@ -254,7 +245,9 @@ InstancePtr FTBInstanceProvider::createInstance(const FTBRecord & record) const auto m_settings = std::make_shared<INISettingsObject>(FS::PathCombine(record.instanceDir, "instance.cfg")); m_settings->registerSetting("InstanceType", "Legacy"); - if (mcVersion->usesLegacyLauncher()) + // all legacy versions are built in. therefore we can do this even if we don't have ALL the versions Mojang has on their servers. + auto mcVersion = std::dynamic_pointer_cast<MinecraftVersion>(ENV.getVersion("net.minecraft", record.mcVersion)); + if (mcVersion && mcVersion->usesLegacyLauncher()) { m_settings->set("InstanceType", "LegacyFTB"); inst.reset(new LegacyFTBInstance(m_globalSettings, m_settings, record.instanceDir)); @@ -264,10 +257,11 @@ InstancePtr FTBInstanceProvider::createInstance(const FTBRecord & record) const m_settings->set("InstanceType", "OneSixFTB"); inst.reset(new OneSixFTBInstance(m_globalSettings, m_settings, record.instanceDir)); } + // initialize { SettingsObject::Lock lock(inst->settings()); - inst->setIntendedVersionId(mcVersion->descriptor()); + inst->setIntendedVersionId(record.mcVersion); inst->init(); inst->setGroupInitial("FTB"); inst->setName(record.name); diff --git a/application/MultiMC.cpp b/application/MultiMC.cpp index 334c51fc..2cc934f1 100644 --- a/application/MultiMC.cpp +++ b/application/MultiMC.cpp @@ -258,6 +258,8 @@ MultiMC::MultiMC(int &argc, char **argv) : QApplication(argc, argv) initIcons(); initThemes(); + // make sure we have at least some minecraft versions before we init instances + minecraftlist(); initInstances(); initAccounts(); initNetwork(); |