summaryrefslogtreecommitdiffstats
path: root/logic/OneSixInstance.cpp
diff options
context:
space:
mode:
authorJan Dalheimer <jan@dalheimer.de>2014-01-27 19:20:07 +0100
committerJan Dalheimer <jan@dalheimer.de>2014-01-27 19:20:07 +0100
commitf9ea3dbfdea0db5626a6afadcfd599a5f53d8abd (patch)
treee02cbc9b4f290a7ea4fe37cd2996f6a8f2595177 /logic/OneSixInstance.cpp
parent966f9d1206fee51641c9ae844323f85316a59b1d (diff)
downloadMultiMC-f9ea3dbfdea0db5626a6afadcfd599a5f53d8abd.tar
MultiMC-f9ea3dbfdea0db5626a6afadcfd599a5f53d8abd.tar.gz
MultiMC-f9ea3dbfdea0db5626a6afadcfd599a5f53d8abd.tar.lz
MultiMC-f9ea3dbfdea0db5626a6afadcfd599a5f53d8abd.tar.xz
MultiMC-f9ea3dbfdea0db5626a6afadcfd599a5f53d8abd.zip
Split parsing/applying. Better error logging. Fix crash.
Diffstat (limited to 'logic/OneSixInstance.cpp')
-rw-r--r--logic/OneSixInstance.cpp30
1 files changed, 23 insertions, 7 deletions
diff --git a/logic/OneSixInstance.cpp b/logic/OneSixInstance.cpp
index c43a5187..19d5e112 100644
--- a/logic/OneSixInstance.cpp
+++ b/logic/OneSixInstance.cpp
@@ -35,13 +35,14 @@ OneSixInstance::OneSixInstance(const QString &rootDir, SettingsObject *settings,
d->m_settings->registerSetting("IntendedVersion", "");
d->m_settings->registerSetting("ShouldUpdate", false);
d->version.reset(new OneSixVersion(this, this));
+ d->nonCustomVersion.reset(new OneSixVersion(this, this));
if (QDir(instanceRoot()).exists("version.json"))
{
- reloadFullVersion();
+ reloadVersion();
}
else
{
- clearFullVersion();
+ clearVersion();
}
}
@@ -139,6 +140,10 @@ QStringList OneSixInstance::processMinecraftArgs(MojangAccountPtr account)
I_D(OneSixInstance);
auto version = d->version;
QString args_pattern = version->minecraftArguments;
+ for (auto tweaker : version->tweakers)
+ {
+ args_pattern += " --tweakClass " + tweaker;
+ }
QMap<QString, QString> token_mapping;
// yggdrasil!
@@ -287,7 +292,7 @@ bool OneSixInstance::setIntendedVersionId(QString version)
settings().set("IntendedVersion", version);
setShouldUpdate(true);
QFile::remove(PathCombine(instanceRoot(), "version.json"));
- clearFullVersion();
+ clearVersion();
return true;
}
@@ -323,28 +328,39 @@ QString OneSixInstance::currentVersionId() const
return intendedVersionId();
}
-bool OneSixInstance::reloadFullVersion(QWidget *widgetParent)
+bool OneSixInstance::reloadVersion(QWidget *widgetParent)
{
I_D(OneSixInstance);
bool ret = d->version->reload(widgetParent);
+ if (ret)
+ {
+ ret = d->nonCustomVersion->reload(widgetParent, true);
+ }
emit versionReloaded();
return ret;
}
-void OneSixInstance::clearFullVersion()
+void OneSixInstance::clearVersion()
{
I_D(OneSixInstance);
d->version->clear();
+ d->nonCustomVersion->clear();
emit versionReloaded();
}
-std::shared_ptr<OneSixVersion> OneSixInstance::getFullVersion()
+std::shared_ptr<OneSixVersion> OneSixInstance::getFullVersion() const
{
- I_D(OneSixInstance);
+ I_D(const OneSixInstance);
return d->version;
}
+std::shared_ptr<OneSixVersion> OneSixInstance::getNonCustomVersion() const
+{
+ I_D(const OneSixInstance);
+ return d->nonCustomVersion;
+}
+
QString OneSixInstance::defaultBaseJar() const
{
return "versions/" + intendedVersionId() + "/" + intendedVersionId() + ".jar";