Parsing the version files, part I
This commit is contained in:
parent
e2ee6d6d25
commit
18853ca3fa
@ -32,6 +32,9 @@ include/instversionlist.h
|
|||||||
include/minecraftversion.h
|
include/minecraftversion.h
|
||||||
include/minecraftversionlist.h
|
include/minecraftversionlist.h
|
||||||
|
|
||||||
|
include/library.h
|
||||||
|
include/fullversion.h
|
||||||
|
include/fullversionfactory.h
|
||||||
|
|
||||||
# Tasks
|
# Tasks
|
||||||
include/task.h
|
include/task.h
|
||||||
@ -63,6 +66,9 @@ src/instversionlist.cpp
|
|||||||
src/minecraftversion.cpp
|
src/minecraftversion.cpp
|
||||||
src/minecraftversionlist.cpp
|
src/minecraftversionlist.cpp
|
||||||
|
|
||||||
|
src/library.cpp
|
||||||
|
src/fullversion.cpp
|
||||||
|
src/fullversionfactory.cpp
|
||||||
|
|
||||||
# Tasks
|
# Tasks
|
||||||
src/task.cpp
|
src/task.cpp
|
||||||
|
68
libmultimc/include/fullversion.h
Normal file
68
libmultimc/include/fullversion.h
Normal file
@ -0,0 +1,68 @@
|
|||||||
|
#pragma once
|
||||||
|
#include <QString>
|
||||||
|
#include <QStringList>
|
||||||
|
|
||||||
|
class FullVersion
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
FullVersion()
|
||||||
|
{
|
||||||
|
minimumLauncherVersion = 0xDEADBEEF;
|
||||||
|
isLegacy = false;
|
||||||
|
}
|
||||||
|
// the ID - determines which jar to use! ACTUALLY IMPORTANT!
|
||||||
|
QString id;
|
||||||
|
// do we actually care about parsing this?
|
||||||
|
QString time;
|
||||||
|
// I don't think we do.
|
||||||
|
QString releaseTime;
|
||||||
|
// eh, not caring - "release" or "snapshot"
|
||||||
|
QString type;
|
||||||
|
/*
|
||||||
|
* DEPRECATED: Old versions of the new vanilla launcher used this
|
||||||
|
* ex: "username_session_version"
|
||||||
|
*/
|
||||||
|
QString processArguments;
|
||||||
|
/*
|
||||||
|
* arguments that should be used for launching minecraft
|
||||||
|
*
|
||||||
|
* ex: "--username ${auth_player_name} --session ${auth_session}
|
||||||
|
* --version ${version_name} --gameDir ${game_directory} --assetsDir ${game_assets}"
|
||||||
|
*/
|
||||||
|
QString minecraftArguments;
|
||||||
|
/*
|
||||||
|
* the minimum launcher version required by this version ... current is 4 (at point of writing)
|
||||||
|
*/
|
||||||
|
int minimumLauncherVersion;
|
||||||
|
/*
|
||||||
|
* The main class to load first
|
||||||
|
*/
|
||||||
|
QString mainClass;
|
||||||
|
|
||||||
|
// the list of libs. just the names for now. expand to full-blown strutures!
|
||||||
|
QStringList libraries;
|
||||||
|
|
||||||
|
// is this actually a legacy version? if so, none of the other stuff here will be ever used.
|
||||||
|
// added by FullVersionFactory
|
||||||
|
bool isLegacy;
|
||||||
|
|
||||||
|
/*
|
||||||
|
FIXME: add support for those rules here? Looks like a pile of quick hacks to me though.
|
||||||
|
|
||||||
|
"rules": [
|
||||||
|
{
|
||||||
|
"action": "allow"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"action": "disallow",
|
||||||
|
"os": {
|
||||||
|
"name": "osx",
|
||||||
|
"version": "^10\\.5\\.\\d$"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"incompatibilityReason": "There is a bug in LWJGL which makes it incompatible with OSX 10.5.8. Please go to New Profile and use 1.5.2 for now. Sorry!"
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
// QList<Rule> rules;
|
||||||
|
};
|
23
libmultimc/include/fullversionfactory.h
Normal file
23
libmultimc/include/fullversionfactory.h
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
#pragma once
|
||||||
|
#include <QtCore>
|
||||||
|
|
||||||
|
struct FullVersion;
|
||||||
|
|
||||||
|
class FullVersionFactory
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
enum Error
|
||||||
|
{
|
||||||
|
AllOK, // all parsed OK
|
||||||
|
ParseError, // the file was corrupted somehow
|
||||||
|
UnsupportedVersion // the file was meant for a launcher version we don't support (yet)
|
||||||
|
} m_error;
|
||||||
|
QString error_string;
|
||||||
|
|
||||||
|
public:
|
||||||
|
FullVersionFactory();
|
||||||
|
QSharedPointer<FullVersion> parse(QByteArray data);
|
||||||
|
private:
|
||||||
|
QSharedPointer<FullVersion> parse4(QJsonObject root, QSharedPointer<FullVersion> product);
|
||||||
|
QStringList legacyWhitelist;
|
||||||
|
};
|
18
libmultimc/include/library.h
Normal file
18
libmultimc/include/library.h
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
/* Copyright 2013 MultiMC Contributors
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
|
4
libmultimc/src/fullversion.cpp
Normal file
4
libmultimc/src/fullversion.cpp
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
#include "fullversion.h"
|
||||||
|
|
||||||
|
|
||||||
|
// ECHO, echo, echo, ....
|
113
libmultimc/src/fullversionfactory.cpp
Normal file
113
libmultimc/src/fullversionfactory.cpp
Normal file
@ -0,0 +1,113 @@
|
|||||||
|
#include "fullversionfactory.h"
|
||||||
|
#include "fullversion.h"
|
||||||
|
|
||||||
|
QSharedPointer<FullVersion> FullVersionFactory::parse4(QJsonObject root, QSharedPointer<FullVersion> product)
|
||||||
|
{
|
||||||
|
product->id = root.value("id").toString();
|
||||||
|
|
||||||
|
// if it's on our legacy list, it's legacy
|
||||||
|
if(legacyWhitelist.contains(product->id))
|
||||||
|
product->isLegacy = true;
|
||||||
|
|
||||||
|
product->mainClass = root.value("mainClass").toString();
|
||||||
|
auto procArgsValue = root.value("processArguments");
|
||||||
|
if(procArgsValue.isString())
|
||||||
|
{
|
||||||
|
product->processArguments = procArgsValue.toString();
|
||||||
|
QString toCompare = product->processArguments.toLower();
|
||||||
|
if(toCompare == "legacy")
|
||||||
|
{
|
||||||
|
product->minecraftArguments = " ${auth_player_name} ${auth_session}";
|
||||||
|
product->isLegacy = true;
|
||||||
|
}
|
||||||
|
else if(toCompare == "username_session")
|
||||||
|
{
|
||||||
|
product->minecraftArguments = "--username ${auth_player_name} --session ${auth_session}";
|
||||||
|
}
|
||||||
|
else if(toCompare == "username_session_version")
|
||||||
|
{
|
||||||
|
product->minecraftArguments = "--username ${auth_player_name} --session ${auth_session} --version ${profile_name}";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
auto minecraftArgsValue = root.value("minecraftArguments");
|
||||||
|
if(minecraftArgsValue.isString())
|
||||||
|
{
|
||||||
|
product->minecraftArguments = minecraftArgsValue.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
product->releaseTime = root.value("releaseTime").toString();
|
||||||
|
product->time = root.value("time").toString();
|
||||||
|
|
||||||
|
// Iterate through the list.
|
||||||
|
auto librariesValue = root.value("libraries");
|
||||||
|
if(librariesValue.isArray())
|
||||||
|
{
|
||||||
|
QJsonArray libList = root.value("libraries").toArray();
|
||||||
|
for (auto lib : libList)
|
||||||
|
{
|
||||||
|
if (!lib.isObject())
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
QJsonObject libObj = lib.toObject();
|
||||||
|
|
||||||
|
QString crud = libObj.value("name").toString();
|
||||||
|
product->libraries.append(crud);
|
||||||
|
|
||||||
|
// TODO: improve!
|
||||||
|
/*
|
||||||
|
auto parts = crud.split(':');
|
||||||
|
int zz = parts.size();
|
||||||
|
*/
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return product;
|
||||||
|
}
|
||||||
|
|
||||||
|
QSharedPointer<FullVersion> FullVersionFactory::parse(QByteArray data)
|
||||||
|
{
|
||||||
|
QSharedPointer<FullVersion> readVersion(new FullVersion());
|
||||||
|
|
||||||
|
QJsonParseError jsonError;
|
||||||
|
QJsonDocument jsonDoc = QJsonDocument::fromJson(data, &jsonError);
|
||||||
|
|
||||||
|
if (jsonError.error != QJsonParseError::NoError)
|
||||||
|
{
|
||||||
|
error_string = QString( "Error reading version file :") + " " + jsonError.errorString();
|
||||||
|
m_error = FullVersionFactory::ParseError;
|
||||||
|
return QSharedPointer<FullVersion>();
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!jsonDoc.isObject())
|
||||||
|
{
|
||||||
|
error_string = "Error reading version file.";
|
||||||
|
m_error = FullVersionFactory::ParseError;
|
||||||
|
return QSharedPointer<FullVersion>();
|
||||||
|
}
|
||||||
|
QJsonObject root = jsonDoc.object();
|
||||||
|
|
||||||
|
readVersion->minimumLauncherVersion = root.value("minimumLauncherVersion").toDouble();
|
||||||
|
switch(readVersion->minimumLauncherVersion)
|
||||||
|
{
|
||||||
|
case 1:
|
||||||
|
case 2:
|
||||||
|
case 3:
|
||||||
|
case 4:
|
||||||
|
return parse4(root, readVersion);
|
||||||
|
// ADD MORE HERE :D
|
||||||
|
default:
|
||||||
|
error_string = "Version file was for an unrecognized launcher version. RIP";
|
||||||
|
m_error = FullVersionFactory::UnsupportedVersion;
|
||||||
|
return QSharedPointer<FullVersion>();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FullVersionFactory::FullVersionFactory()
|
||||||
|
{
|
||||||
|
m_error = FullVersionFactory::AllOK;
|
||||||
|
legacyWhitelist.append("1.5.1");
|
||||||
|
legacyWhitelist.append("1.5.2");
|
||||||
|
}
|
@ -25,9 +25,12 @@
|
|||||||
#include <QDebug>
|
#include <QDebug>
|
||||||
|
|
||||||
#include "minecraftversionlist.h"
|
#include "minecraftversionlist.h"
|
||||||
|
#include "fullversionfactory.h"
|
||||||
|
#include <fullversion.h>
|
||||||
|
|
||||||
#include "pathutils.h"
|
#include "pathutils.h"
|
||||||
|
|
||||||
|
|
||||||
GameUpdateTask::GameUpdateTask(const LoginResponse &response, Instance *inst, QObject *parent) :
|
GameUpdateTask::GameUpdateTask(const LoginResponse &response, Instance *inst, QObject *parent) :
|
||||||
Task(parent), m_response(response)
|
Task(parent), m_response(response)
|
||||||
{
|
{
|
||||||
@ -86,78 +89,20 @@ void GameUpdateTask::versionFileFinished()
|
|||||||
{
|
{
|
||||||
JobPtr firstJob = specificVersionDownloadJob->getFirstJob();
|
JobPtr firstJob = specificVersionDownloadJob->getFirstJob();
|
||||||
auto DlJob = firstJob.dynamicCast<DownloadJob>();
|
auto DlJob = firstJob.dynamicCast<DownloadJob>();
|
||||||
QJsonParseError jsonError;
|
FullVersionFactory parser;
|
||||||
QJsonDocument jsonDoc = QJsonDocument::fromJson(DlJob->m_data, &jsonError);
|
auto version = parser.parse(DlJob->m_data);
|
||||||
|
|
||||||
if (jsonError.error != QJsonParseError::NoError)
|
if(!version)
|
||||||
{
|
{
|
||||||
error(QString( "Error reading version file :") + " " + jsonError.errorString());
|
error(parser.error_string);
|
||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!jsonDoc.isObject())
|
if(version->isLegacy)
|
||||||
{
|
|
||||||
error("Error reading version file.");
|
|
||||||
exit(0);
|
|
||||||
}
|
|
||||||
QJsonObject root = jsonDoc.object();
|
|
||||||
|
|
||||||
/*
|
|
||||||
* FIXME: this distinction is pretty weak. The only other option
|
|
||||||
* is to have a list of all the legacy versions.
|
|
||||||
*/
|
|
||||||
QString args = root.value("processArguments").toString("legacy");
|
|
||||||
if(args == "legacy")
|
|
||||||
{
|
{
|
||||||
getLegacyJar();
|
getLegacyJar();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
/*
|
|
||||||
// Iterate through the list.
|
|
||||||
QJsonObject groupList = root.value("libraries").toObject();
|
|
||||||
|
|
||||||
for (QJsonObject::iterator iter = groupList.begin();
|
|
||||||
iter != groupList.end(); iter++)
|
|
||||||
{
|
|
||||||
QString groupName = iter.key();
|
|
||||||
|
|
||||||
// If not an object, complain and skip to the next one.
|
|
||||||
if (!iter.value().isObject())
|
|
||||||
{
|
|
||||||
qWarning(QString("Group '%1' in the group list should "
|
|
||||||
"be an object.").arg(groupName).toUtf8());
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
QJsonObject groupObj = iter.value().toObject();
|
|
||||||
|
|
||||||
// Create the group object.
|
|
||||||
InstanceGroup *group = new InstanceGroup(groupName, this);
|
|
||||||
groups.push_back(group);
|
|
||||||
|
|
||||||
// If 'hidden' isn't a bool value, just assume it's false.
|
|
||||||
if (groupObj.value("hidden").isBool() && groupObj.value("hidden").toBool())
|
|
||||||
{
|
|
||||||
group->setHidden(groupObj.value("hidden").toBool());
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!groupObj.value("instances").isArray())
|
|
||||||
{
|
|
||||||
qWarning(QString("Group '%1' in the group list is invalid. "
|
|
||||||
"It should contain an array "
|
|
||||||
"called 'instances'.").arg(groupName).toUtf8());
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Iterate through the list of instances in the group.
|
|
||||||
QJsonArray instancesArray = groupObj.value("instances").toArray();
|
|
||||||
|
|
||||||
for (QJsonArray::iterator iter2 = instancesArray.begin();
|
|
||||||
iter2 != instancesArray.end(); iter2++)
|
|
||||||
{
|
|
||||||
groupMap[(*iter2).toString()] = groupName;
|
|
||||||
}
|
|
||||||
}*/
|
|
||||||
|
|
||||||
// save the version file in $instanceId/version.json and versions/$version/$version.json
|
// save the version file in $instanceId/version.json and versions/$version/$version.json
|
||||||
QString version_id = targetVersion->descriptor();
|
QString version_id = targetVersion->descriptor();
|
||||||
|
18
libmultimc/src/library.cpp
Normal file
18
libmultimc/src/library.cpp
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
/* Copyright 2013 MultiMC Contributors
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "include/library.h"
|
||||||
|
|
||||||
|
// default url for lib: https://s3.amazonaws.com/Minecraft.Download/libraries/
|
Loading…
x
Reference in New Issue
Block a user