summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--logic/minecraft/MinecraftVersion.h2
-rw-r--r--logic/minecraft/MinecraftVersionList.cpp2
-rw-r--r--logic/minecraft/MojangVersionFormat.cpp181
-rw-r--r--logic/minecraft/MojangVersionFormat.h8
-rw-r--r--logic/minecraft/ProfilePatch.h5
-rw-r--r--logic/minecraft/VersionFile.h4
-rw-r--r--logic/minecraft/forge/ForgeInstaller.cpp2
-rw-r--r--logic/minecraft/onesix/OneSixProfileStrategy.cpp11
-rw-r--r--logic/minecraft/onesix/OneSixVersionFormat.cpp85
-rw-r--r--logic/minecraft/onesix/OneSixVersionFormat.h2
-rw-r--r--tests/tst_MojangVersionFormat.cpp4
11 files changed, 128 insertions, 178 deletions
diff --git a/logic/minecraft/MinecraftVersion.h b/logic/minecraft/MinecraftVersion.h
index 2c1eb289..1539ffd8 100644
--- a/logic/minecraft/MinecraftVersion.h
+++ b/logic/minecraft/MinecraftVersion.h
@@ -76,7 +76,7 @@ public: /* methods */
return true;
}
- VersionFilePtr getVersionFile();
+ virtual VersionFilePtr getVersionFile() override;
// virtual QJsonDocument toJson(bool saveOrder) override;
diff --git a/logic/minecraft/MinecraftVersionList.cpp b/logic/minecraft/MinecraftVersionList.cpp
index f219c782..62c588d1 100644
--- a/logic/minecraft/MinecraftVersionList.cpp
+++ b/logic/minecraft/MinecraftVersionList.cpp
@@ -508,7 +508,7 @@ void MCVListVersionUpdateTask::json_downloaded()
file->fileId = "net.minecraft";
// now dump the file to disk
- auto doc = OneSixVersionFormat::profilePatchToJson(file, false);
+ auto doc = OneSixVersionFormat::versionFileToJson(file, false);
auto newdata = doc.toBinaryData();
auto id = updatedVersion->descriptor();
QString targetPath = "versions/" + id + "/" + id + ".dat";
diff --git a/logic/minecraft/MojangVersionFormat.cpp b/logic/minecraft/MojangVersionFormat.cpp
index a832e8c7..78447aa8 100644
--- a/logic/minecraft/MojangVersionFormat.cpp
+++ b/logic/minecraft/MojangVersionFormat.cpp
@@ -128,43 +128,47 @@ QJsonObject assetIndexToJson(MojangAssetIndexInfo::Ptr info)
return out;
}
-VersionFilePtr MojangVersionFormat::versionFileFromJson(const QJsonDocument &doc, const QString &filename)
+void MojangVersionFormat::readVersionProperties(const QJsonObject &in, VersionFile *out)
{
- VersionFilePtr out(new VersionFile());
- if (doc.isEmpty() || doc.isNull())
- {
- throw JSONValidationError(filename + " is empty or null");
- }
- if (!doc.isObject())
+ Bits::readString(in, "id", out->id);
+ Bits::readString(in, "mainClass", out->mainClass);
+ Bits::readString(in, "minecraftArguments", out->minecraftArguments);
+ if(out->minecraftArguments.isEmpty())
{
- throw JSONValidationError(filename + " is not an object");
+ QString processArguments;
+ Bits::readString(in, "processArguments", processArguments);
+ QString toCompare = processArguments.toLower();
+ if (toCompare == "legacy")
+ {
+ out->minecraftArguments = " ${auth_player_name} ${auth_session}";
+ }
+ else if (toCompare == "username_session")
+ {
+ out->minecraftArguments = "--username ${auth_player_name} --session ${auth_session}";
+ }
+ else if (toCompare == "username_session_version")
+ {
+ out->minecraftArguments = "--username ${auth_player_name} --session ${auth_session} --version ${profile_name}";
+ }
+ else if (!toCompare.isEmpty())
+ {
+ out->addProblem(PROBLEM_ERROR, QObject::tr("processArguments is set to unknown value '%1'").arg(processArguments));
+ }
}
+ Bits::readString(in, "type", out->type);
- QJsonObject root = doc.object();
-
- out->name = "Minecraft";
- out->fileId = "net.minecraft";
- out->version = root.value("version").toString();
- out->filename = filename;
-
- Bits::readString(root, "id", out->id);
-
- Bits::readString(root, "mainClass", out->mainClass);
- Bits::readString(root, "minecraftArguments", out->minecraftArguments);
- Bits::readString(root, "type", out->type);
-
- if(root.contains("assetIndex"))
+ if(in.contains("assetIndex"))
{
- out->mojangAssetIndex = assetIndexFromJson(requireObject(root, "assetIndex"));
+ out->mojangAssetIndex = assetIndexFromJson(requireObject(in, "assetIndex"));
}
- Bits::readString(root, "assets", out->assets);
+ Bits::readString(in, "assets", out->assets);
- out->m_releaseTime = timeFromS3Time(root.value("releaseTime").toString(""));
- out->m_updateTime = timeFromS3Time(root.value("time").toString(""));
+ out->m_releaseTime = timeFromS3Time(in.value("releaseTime").toString(""));
+ out->m_updateTime = timeFromS3Time(in.value("time").toString(""));
- if (root.contains("minimumLauncherVersion"))
+ if (in.contains("minimumLauncherVersion"))
{
- out->minimumLauncherVersion = requireInteger(root.value("minimumLauncherVersion"));
+ out->minimumLauncherVersion = requireInteger(in.value("minimumLauncherVersion"));
if (out->minimumLauncherVersion > CURRENT_MINIMUM_LAUNCHER_VERSION)
{
out->addProblem(
@@ -174,20 +178,9 @@ VersionFilePtr MojangVersionFormat::versionFileFromJson(const QJsonDocument &doc
.arg(CURRENT_MINIMUM_LAUNCHER_VERSION));
}
}
-
- if (root.contains("libraries"))
- {
- for (auto libVal : requireArray(root.value("libraries")))
- {
- auto libObj = requireObject(libVal);
-
- auto lib = MojangVersionFormat::libraryFromJson(libObj, filename);
- out->libraries.append(lib);
- }
- }
- if(root.contains("downloads"))
+ if(in.contains("downloads"))
{
- auto downloadsObj = requireObject(root, "downloads");
+ auto downloadsObj = requireObject(in, "downloads");
for(auto iter = downloadsObj.begin(); iter != downloadsObj.end(); iter++)
{
auto classifier = iter.key();
@@ -195,79 +188,91 @@ VersionFilePtr MojangVersionFormat::versionFileFromJson(const QJsonDocument &doc
out->mojangDownloads[classifier] = downloadInfoFromJson(classifierObj);
}
}
- return out;
}
-QJsonDocument versionFileToJson(VersionFilePtr patch)
+VersionFilePtr MojangVersionFormat::versionFileFromJson(const QJsonDocument &doc, const QString &filename)
{
- QJsonObject root;
- writeString(root, "id", patch->id);
- writeString(root, "mainClass", patch->mainClass);
- writeString(root, "minecraftArguments", patch->minecraftArguments);
- writeString(root, "type", patch->type);
- writeString(root, "assets", patch->assets);
- writeString(root, "releaseTime", timeToS3Time(patch->m_releaseTime));
- writeString(root, "time", timeToS3Time(patch->m_updateTime));
- if(patch->minimumLauncherVersion != -1)
+ VersionFilePtr out(new VersionFile());
+ if (doc.isEmpty() || doc.isNull())
{
- root.insert("minimumLauncherVersion", patch->minimumLauncherVersion);
+ throw JSONValidationError(filename + " is empty or null");
+ }
+ if (!doc.isObject())
+ {
+ throw JSONValidationError(filename + " is not an object");
}
- if (!patch->libraries.isEmpty())
+ QJsonObject root = doc.object();
+
+ readVersionProperties(root, out.get());
+
+ out->name = "Minecraft";
+ out->fileId = "net.minecraft";
+ out->version = out->id;
+ out->filename = filename;
+
+
+ if (root.contains("libraries"))
{
- QJsonArray array;
- for (auto value: patch->libraries)
+ for (auto libVal : requireArray(root.value("libraries")))
{
- array.append(MojangVersionFormat::libraryToJson(value.get()));
+ auto libObj = requireObject(libVal);
+
+ auto lib = MojangVersionFormat::libraryFromJson(libObj, filename);
+ out->libraries.append(lib);
}
- root.insert("libraries", array);
}
- if(patch->mojangAssetIndex && patch->mojangAssetIndex->known)
+ return out;
+}
+
+void MojangVersionFormat::writeVersionProperties(const VersionFile* in, QJsonObject& out)
+{
+ writeString(out, "id", in->id);
+ writeString(out, "mainClass", in->mainClass);
+ writeString(out, "minecraftArguments", in->minecraftArguments);
+ writeString(out, "type", in->type);
+ writeString(out, "assets", in->assets);
+ writeString(out, "releaseTime", timeToS3Time(in->m_releaseTime));
+ writeString(out, "time", timeToS3Time(in->m_updateTime));
+ if(in->minimumLauncherVersion != -1)
+ {
+ out.insert("minimumLauncherVersion", in->minimumLauncherVersion);
+ }
+ if(in->mojangAssetIndex && in->mojangAssetIndex->known)
{
- root.insert("assetIndex", assetIndexToJson(patch->mojangAssetIndex));
+ out.insert("assetIndex", assetIndexToJson(in->mojangAssetIndex));
}
- if(patch->mojangDownloads.size())
+ if(in->mojangDownloads.size())
{
QJsonObject downloadsOut;
- for(auto iter = patch->mojangDownloads.begin(); iter != patch->mojangDownloads.end(); iter++)
+ for(auto iter = in->mojangDownloads.begin(); iter != in->mojangDownloads.end(); iter++)
{
downloadsOut.insert(iter.key(), downloadInfoToJson(iter.value()));
}
- root.insert("downloads", downloadsOut);
- }
- // write the contents to a json document.
- {
- QJsonDocument out;
- out.setObject(root);
- return out;
+ out.insert("downloads", downloadsOut);
}
}
-static QJsonDocument minecraftVersionToJson(MinecraftVersionPtr patch)
+QJsonDocument MojangVersionFormat::versionFileToJson(const VersionFilePtr &patch)
{
- if(patch->getVersionSource() == Local && patch->getVersionFile())
- {
- return MojangVersionFormat::profilePatchToJson(patch->getVersionFile());
- }
- else
+ QJsonObject root;
+ writeVersionProperties(patch.get(), root);
+ if (!patch->libraries.isEmpty())
{
- throw VersionIncomplete(QObject::tr("Can't write incomplete/builtin Minecraft version %1").arg(patch->name()));
+ QJsonArray array;
+ for (auto value: patch->libraries)
+ {
+ array.append(MojangVersionFormat::libraryToJson(value.get()));
+ }
+ root.insert("libraries", array);
}
-}
-QJsonDocument MojangVersionFormat::profilePatchToJson(const ProfilePatchPtr &patch)
-{
- auto vfile = std::dynamic_pointer_cast<VersionFile>(patch);
- if(vfile)
- {
- return versionFileToJson(vfile);
- }
- auto mversion = std::dynamic_pointer_cast<MinecraftVersion>(patch);
- if(mversion)
+ // write the contents to a json document.
{
- return minecraftVersionToJson(mversion);
+ QJsonDocument out;
+ out.setObject(root);
+ return out;
}
- throw VersionIncomplete(QObject::tr("Unhandled object type while processing %1").arg(patch->getName()));
}
LibraryPtr MojangVersionFormat::libraryFromJson(const QJsonObject &libObj, const QString &filename)
diff --git a/logic/minecraft/MojangVersionFormat.h b/logic/minecraft/MojangVersionFormat.h
index a5a94095..4e141088 100644
--- a/logic/minecraft/MojangVersionFormat.h
+++ b/logic/minecraft/MojangVersionFormat.h
@@ -8,10 +8,16 @@
class MULTIMC_LOGIC_EXPORT MojangVersionFormat
{
+friend class OneSixVersionFormat;
+protected:
+ // does not include libraries
+ static void readVersionProperties(const QJsonObject& in, VersionFile* out);
+ // does not include libraries
+ static void writeVersionProperties(const VersionFile* in, QJsonObject& out);
public:
// version files / profile patches
static VersionFilePtr versionFileFromJson(const QJsonDocument &doc, const QString &filename);
- static QJsonDocument profilePatchToJson(const ProfilePatchPtr &patch);
+ static QJsonDocument versionFileToJson(const VersionFilePtr &patch);
// libraries
static LibraryPtr libraryFromJson(const QJsonObject &libObj, const QString &filename);
diff --git a/logic/minecraft/ProfilePatch.h b/logic/minecraft/ProfilePatch.h
index 56bc58a7..fa2f0a0f 100644
--- a/logic/minecraft/ProfilePatch.h
+++ b/logic/minecraft/ProfilePatch.h
@@ -3,6 +3,7 @@
#include <memory>
#include <QList>
#include <QJsonDocument>
+#include <QDateTime>
#include "JarMod.h"
class MinecraftProfile;
@@ -43,7 +44,7 @@ private:
QString m_description;
};
-class ProfilePatch
+class ProfilePatch : public std::enable_shared_from_this<ProfilePatch>
{
public:
virtual ~ProfilePatch(){};
@@ -73,6 +74,8 @@ public:
virtual VersionSource getVersionSource() = 0;
+ virtual std::shared_ptr<class VersionFile> getVersionFile() = 0;
+
virtual const QList<PatchProblem>& getProblems()
{
return m_problems;
diff --git a/logic/minecraft/VersionFile.h b/logic/minecraft/VersionFile.h
index 49c55646..7627cc96 100644
--- a/logic/minecraft/VersionFile.h
+++ b/logic/minecraft/VersionFile.h
@@ -63,6 +63,10 @@ public: /* methods */
return Local;
}
+ std::shared_ptr<class VersionFile> getVersionFile() override
+ {
+ return std::dynamic_pointer_cast<VersionFile>(shared_from_this());
+ }
virtual bool isCustom() override
{
diff --git a/logic/minecraft/forge/ForgeInstaller.cpp b/logic/minecraft/forge/ForgeInstaller.cpp
index 86ba6176..7957de0e 100644
--- a/logic/minecraft/forge/ForgeInstaller.cpp
+++ b/logic/minecraft/forge/ForgeInstaller.cpp
@@ -275,7 +275,7 @@ bool ForgeInstaller::add(OneSixInstance *to)
<< "for reading:" << file.errorString();
return false;
}
- file.write(OneSixVersionFormat::profilePatchToJson(m_forge_json, true).toJson());
+ file.write(OneSixVersionFormat::versionFileToJson(m_forge_json, true).toJson());
file.commit();
return true;
diff --git a/logic/minecraft/onesix/OneSixProfileStrategy.cpp b/logic/minecraft/onesix/OneSixProfileStrategy.cpp
index 3ae055c0..aaaa9d97 100644
--- a/logic/minecraft/onesix/OneSixProfileStrategy.cpp
+++ b/logic/minecraft/onesix/OneSixProfileStrategy.cpp
@@ -56,7 +56,7 @@ void OneSixProfileStrategy::upgradeDeprecatedFiles()
file->fileId = "net.minecraft";
file->version = file->id;
file->name = "Minecraft";
- auto data = OneSixVersionFormat::profilePatchToJson(file, false).toJson();
+ auto data = OneSixVersionFormat::versionFileToJson(file, false).toJson();
QSaveFile newPatchFile(mcJson);
if(!newPatchFile.open(QIODevice::WriteOnly))
{
@@ -299,7 +299,12 @@ bool OneSixProfileStrategy::customizePatch(ProfilePatchPtr patch)
{
return false;
}
- auto document = OneSixVersionFormat::profilePatchToJson(patch, true);
+ auto vfile = patch->getVersionFile();
+ if(!vfile)
+ {
+ return false;
+ }
+ auto document = OneSixVersionFormat::versionFileToJson(vfile, true);
jsonFile.write(document.toJson());
if(!jsonFile.commit())
{
@@ -402,7 +407,7 @@ bool OneSixProfileStrategy::installJarMods(QStringList filepaths)
<< "for reading:" << file.errorString();
return false;
}
- file.write(OneSixVersionFormat::profilePatchToJson(f, true).toJson());
+ file.write(OneSixVersionFormat::versionFileToJson(f, true).toJson());
file.close();
profile->appendPatch(f);
}
diff --git a/logic/minecraft/onesix/OneSixVersionFormat.cpp b/logic/minecraft/onesix/OneSixVersionFormat.cpp
index e262cecd..d4b372c3 100644
--- a/logic/minecraft/onesix/OneSixVersionFormat.cpp
+++ b/logic/minecraft/onesix/OneSixVersionFormat.cpp
@@ -76,40 +76,10 @@ VersionFilePtr OneSixVersionFormat::versionFileFromJson(const QJsonDocument &doc
out->mcVersion = root.value("mcVersion").toString();
out->filename = filename;
- readString(root, "id", out->id);
+ MojangVersionFormat::readVersionProperties(root, out.get());
- readString(root, "mainClass", out->mainClass);
+ // added for legacy Minecraft window embedding, TODO: remove
readString(root, "appletClass", out->appletClass);
- readString(root, "minecraftArguments", out->minecraftArguments);
- if(out->minecraftArguments.isEmpty())
- {
- QString processArguments;
- readString(root, "processArguments", processArguments);
- QString toCompare = processArguments.toLower();
- if (toCompare == "legacy")
- {
- out->minecraftArguments = " ${auth_player_name} ${auth_session}";
- }
- else if (toCompare == "username_session")
- {
- out->minecraftArguments = "--username ${auth_player_name} --session ${auth_session}";
- }
- else if (toCompare == "username_session_version")
- {
- out->minecraftArguments = "--username ${auth_player_name} --session ${auth_session} --version ${profile_name}";
- }
- else if (!toCompare.isEmpty())
- {
- out->addProblem(PROBLEM_ERROR, QObject::tr("processArguments is set to unknown value '%1'").arg(processArguments));
- }
- }
-
- readString(root, "type", out->type);
-
- out->m_releaseTime = timeFromS3Time(readStringRet(root, "releaseTime"));
- out->m_updateTime = timeFromS3Time(readStringRet(root, "time"));
-
- readString(root, "assets", out->assets);
if (root.contains("+tweakers"))
{
@@ -196,16 +166,7 @@ VersionFilePtr OneSixVersionFormat::versionFileFromJson(const QJsonDocument &doc
return out;
}
-template <typename T>
-struct libraryConversion
-{
- static QJsonObject convert(std::shared_ptr<Library> &value)
- {
- return OneSixVersionFormat::libraryToJson(value.get());
- }
-};
-
-static QJsonDocument versionFileToJson(VersionFilePtr patch, bool saveOrder)
+QJsonDocument OneSixVersionFormat::versionFileToJson(const VersionFilePtr &patch, bool saveOrder)
{
QJsonObject root;
if (saveOrder)
@@ -216,17 +177,10 @@ static QJsonDocument versionFileToJson(VersionFilePtr patch, bool saveOrder)
writeString(root, "fileId", patch->fileId);
writeString(root, "version", patch->version);
writeString(root, "mcVersion", patch->mcVersion);
- writeString(root, "id", patch->id);
- writeString(root, "mainClass", patch->mainClass);
+
+ MojangVersionFormat::writeVersionProperties(patch.get(), root);
+
writeString(root, "appletClass", patch->appletClass);
- writeString(root, "minecraftArguments", patch->minecraftArguments);
- writeString(root, "type", patch->type);
- writeString(root, "assets", patch->assets);
- if (patch->isMinecraftVersion())
- {
- writeString(root, "releaseTime", timeToS3Time(patch->m_releaseTime));
- writeString(root, "time", timeToS3Time(patch->m_updateTime));
- }
writeStringList(root, "+tweakers", patch->addTweakers);
writeStringList(root, "+traits", patch->traits.toList());
if (!patch->libraries.isEmpty())
@@ -255,33 +209,6 @@ static QJsonDocument versionFileToJson(VersionFilePtr patch, bool saveOrder)
}
}
-static QJsonDocument minecraftVersionToJson(MinecraftVersionPtr patch, bool saveOrder)
-{
- if(patch->getVersionSource() == Local && patch->getVersionFile())
- {
- return OneSixVersionFormat::profilePatchToJson(patch->getVersionFile(), saveOrder);
- }
- else
- {
- throw VersionIncomplete(QObject::tr("Can't write incomplete/builtin Minecraft version %1").arg(patch->name()));
- }
-}
-
-QJsonDocument OneSixVersionFormat::profilePatchToJson(const ProfilePatchPtr &patch, bool saveOrder)
-{
- auto vfile = std::dynamic_pointer_cast<VersionFile>(patch);
- if(vfile)
- {
- return versionFileToJson(vfile, saveOrder);
- }
- auto mversion = std::dynamic_pointer_cast<MinecraftVersion>(patch);
- if(mversion)
- {
- return minecraftVersionToJson(mversion, saveOrder);
- }
- throw VersionIncomplete(QObject::tr("Unhandled object type while processing %1").arg(patch->getName()));
-}
-
JarmodPtr OneSixVersionFormat::jarModFromJson(const QJsonObject &libObj, const QString &filename, const QString &originalName)
{
JarmodPtr out(new Jarmod());
diff --git a/logic/minecraft/onesix/OneSixVersionFormat.h b/logic/minecraft/onesix/OneSixVersionFormat.h
index 3011688c..5696e79e 100644
--- a/logic/minecraft/onesix/OneSixVersionFormat.h
+++ b/logic/minecraft/onesix/OneSixVersionFormat.h
@@ -10,7 +10,7 @@ class OneSixVersionFormat
public:
// version files / profile patches
static VersionFilePtr versionFileFromJson(const QJsonDocument &doc, const QString &filename, const bool requireOrder);
- static QJsonDocument profilePatchToJson(const ProfilePatchPtr &patch, bool saveOrder);
+ static QJsonDocument versionFileToJson(const VersionFilePtr &patch, bool saveOrder);
// libraries
static LibraryPtr libraryFromJson(const QJsonObject &libObj, const QString &filename);
diff --git a/tests/tst_MojangVersionFormat.cpp b/tests/tst_MojangVersionFormat.cpp
index a9a3f977..2e7b1cb8 100644
--- a/tests/tst_MojangVersionFormat.cpp
+++ b/tests/tst_MojangVersionFormat.cpp
@@ -33,7 +33,7 @@ slots:
QJsonDocument doc = readJson("tests/data/1.9-simple.json");
auto vfile = MojangVersionFormat::versionFileFromJson(doc, "1.9-simple.json");
- auto doc2 = MojangVersionFormat::profilePatchToJson(vfile);
+ auto doc2 = MojangVersionFormat::versionFileToJson(vfile);
writeJson("1.9-simple-passthorugh.json", doc2);
QCOMPARE(doc, doc2);
}
@@ -43,7 +43,7 @@ slots:
QJsonDocument doc = readJson("tests/data/1.9.json");
auto vfile = MojangVersionFormat::versionFileFromJson(doc, "1.9.json");
- auto doc2 = MojangVersionFormat::profilePatchToJson(vfile);
+ auto doc2 = MojangVersionFormat::versionFileToJson(vfile);
writeJson("1.9-passthorugh.json", doc2);
QCOMPARE(doc, doc2);
}