#include "MojangVersionFormat.h" #include "onesix/OneSixVersionFormat.h" #include "MinecraftVersion.h" #include "VersionBuildError.h" #include "Json.h" using namespace Json; static const int CURRENT_MINIMUM_LAUNCHER_VERSION = 14; // FIXME: duplicated in OneSixVersionFormat! static void readString(const QJsonObject &root, const QString &key, QString &variable) { if (root.contains(key)) { variable = requireString(root.value(key)); } } VersionFilePtr MojangVersionFormat::versionFileFromJson(const QJsonDocument &doc, const QString &filename) { VersionFilePtr out(new VersionFile()); if (doc.isEmpty() || doc.isNull()) { throw JSONValidationError(filename + " is empty or null"); } if (!doc.isObject()) { throw JSONValidationError(filename + " is not an object"); } QJsonObject root = doc.object(); out->name = root.value("name").toString(); out->fileId = root.value("fileId").toString(); out->version = root.value("version").toString(); out->mcVersion = root.value("mcVersion").toString(); out->filename = filename; readString(root, "id", out->id); readString(root, "mainClass", out->mainClass); readString(root, "appletClass", out->appletClass); readString(root, "minecraftArguments", out->overwriteMinecraftArguments); readString(root, "type", out->type); readString(root, "assets", out->assets); if (root.contains("minimumLauncherVersion")) { auto minimumLauncherVersion = requireInteger(root.value("minimumLauncherVersion")); if (minimumLauncherVersion > CURRENT_MINIMUM_LAUNCHER_VERSION) { out->addProblem( PROBLEM_WARNING, QObject::tr("The 'minimumLauncherVersion' value of this version (%1) is higher than supported by MultiMC (%2). It might not work properly!") .arg(minimumLauncherVersion) .arg(CURRENT_MINIMUM_LAUNCHER_VERSION)); } } if (root.contains("libraries")) { out->shouldOverwriteLibs = true; for (auto libVal : requireArray(root.value("libraries"))) { auto libObj = requireObject(libVal); auto lib = OneSixVersionFormat::libraryFromJson(libObj, filename); out->overwriteLibs.append(lib); } } return out; } /* static QJsonDocument versionFileToJson(VersionFilePtr patch) { QJsonObject root; writeString(root, "id", patch->id); writeString(root, "mainClass", patch->mainClass); writeString(root, "processArguments", patch->processArguments); writeString(root, "minecraftArguments", patch->overwriteMinecraftArguments); writeString(root, "type", patch->type); writeString(root, "assets", patch->assets); writeString(root, "releaseTime", patch->m_releaseTimeString); writeString(root, "time", patch->m_updateTimeString); if (!patch->addLibs.isEmpty()) { QJsonArray array; for (auto value: patch->addLibs) { array.append(OneSixVersionFormat::libraryToJson(value.get())); } root.insert("libraries", array); } // write the contents to a json document. { QJsonDocument out; out.setObject(root); return out; } } static QJsonDocument minecraftVersionToJson(MinecraftVersionPtr patch) { if(patch->m_versionSource == Local && patch->getVersionFile()) { return MojangVersionFormat::profilePatchToJson(patch->getVersionFile()); } else { throw VersionIncomplete(QObject::tr("Can't write incomplete/builtin Minecraft version %1").arg(patch->name())); } } QJsonDocument MojangVersionFormat::profilePatchToJson(const ProfilePatchPtr &patch) { auto vfile = std::dynamic_pointer_cast(patch); if(vfile) { return versionFileToJson(vfile); } auto mversion = std::dynamic_pointer_cast(patch); if(mversion) { return minecraftVersionToJson(mversion); } throw VersionIncomplete(QObject::tr("Unhandled object type while processing %1").arg(patch->getPatchName())); } */