Work towards liteloader support. Fix creating new instance

This commit is contained in:
Jan Dalheimer 2014-01-22 15:20:48 +01:00
parent d166b48072
commit 0a592ab99b
8 changed files with 123 additions and 84 deletions

View File

@ -96,7 +96,7 @@ void DerpModEditDialog::updateVersionControls()
{ {
bool customVersion = m_inst->versionIsCustom(); bool customVersion = m_inst->versionIsCustom();
ui->forgeBtn->setEnabled(true); ui->forgeBtn->setEnabled(true);
ui->liteloaderBtn->setEnabled(LiteLoaderInstaller(m_inst->intendedVersionId()).canApply()); ui->liteloaderBtn->setEnabled(LiteLoaderInstaller().canApply(m_inst));
ui->customEditorBtn->setEnabled(customVersion); ui->customEditorBtn->setEnabled(customVersion);
} }
@ -165,8 +165,8 @@ void DerpModEditDialog::on_forgeBtn_clicked()
void DerpModEditDialog::on_liteloaderBtn_clicked() void DerpModEditDialog::on_liteloaderBtn_clicked()
{ {
LiteLoaderInstaller liteloader(m_inst->intendedVersionId()); LiteLoaderInstaller liteloader;
if (!liteloader.canApply()) if (!liteloader.canApply(m_inst))
{ {
QMessageBox::critical( QMessageBox::critical(
this, tr("LiteLoader"), this, tr("LiteLoader"),
@ -174,7 +174,7 @@ void DerpModEditDialog::on_liteloaderBtn_clicked()
"into this version of Minecraft")); "into this version of Minecraft"));
return; return;
} }
if (!liteloader.apply(m_version)) if (!liteloader.add(m_inst))
{ {
QMessageBox::critical( QMessageBox::critical(
this, tr("LiteLoader"), this, tr("LiteLoader"),

View File

@ -35,10 +35,16 @@ DerpInstance::DerpInstance(const QString &rootDir, SettingsObject *settings, QOb
d->m_settings->registerSetting("IntendedVersion", ""); d->m_settings->registerSetting("IntendedVersion", "");
d->m_settings->registerSetting("ShouldUpdate", false); d->m_settings->registerSetting("ShouldUpdate", false);
d->version.reset(new DerpVersion(this, this)); d->version.reset(new DerpVersion(this, this));
if (QDir(instanceRoot()).exists("version.json"))
{
reloadFullVersion(); reloadFullVersion();
}
else
{
clearFullVersion();
}
} }
std::shared_ptr<Task> DerpInstance::doUpdate(bool only_prepare) std::shared_ptr<Task> DerpInstance::doUpdate(bool only_prepare)
{ {
return std::shared_ptr<Task>(new DerpUpdate(this, only_prepare)); return std::shared_ptr<Task>(new DerpUpdate(this, only_prepare));
@ -280,9 +286,8 @@ bool DerpInstance::setIntendedVersionId(QString version)
{ {
settings().set("IntendedVersion", version); settings().set("IntendedVersion", version);
setShouldUpdate(true); setShouldUpdate(true);
auto pathOrig = PathCombine(instanceRoot(), "version.json"); QFile::remove(PathCombine(instanceRoot(), "version.json"));
QFile::remove(pathOrig); clearFullVersion();
reloadFullVersion();
return true; return true;
} }
@ -327,6 +332,13 @@ bool DerpInstance::reloadFullVersion(QWidget *widgetParent)
return ret; return ret;
} }
void DerpInstance::clearFullVersion()
{
I_D(DerpInstance);
d->version->clear();
emit versionReloaded();
}
std::shared_ptr<DerpVersion> DerpInstance::getFullVersion() std::shared_ptr<DerpVersion> DerpInstance::getFullVersion()
{ {
I_D(DerpInstance); I_D(DerpInstance);

View File

@ -53,6 +53,8 @@ public:
/// reload the full version json files. return true on success! /// reload the full version json files. return true on success!
bool reloadFullVersion(QWidget *widgetParent = 0); bool reloadFullVersion(QWidget *widgetParent = 0);
/// clears all version information in preparation for an update
void clearFullVersion();
/// get the current full version info /// get the current full version info
std::shared_ptr<DerpVersion> getFullVersion(); std::shared_ptr<DerpVersion> getFullVersion();
/// is the current version original, or custom? /// is the current version original, or custom?

View File

@ -22,6 +22,7 @@
DerpVersion::DerpVersion(DerpInstance *instance, QObject *parent) DerpVersion::DerpVersion(DerpInstance *instance, QObject *parent)
: QAbstractListModel(parent), m_instance(instance) : QAbstractListModel(parent), m_instance(instance)
{ {
clear();
} }
bool DerpVersion::reload(QWidget *widgetParent) bool DerpVersion::reload(QWidget *widgetParent)
@ -29,6 +30,20 @@ bool DerpVersion::reload(QWidget *widgetParent)
return DerpVersionBuilder::build(this, m_instance, widgetParent); return DerpVersionBuilder::build(this, m_instance, widgetParent);
} }
void DerpVersion::clear()
{
id.clear();
time.clear();
releaseTime.clear();
type.clear();
assets.clear();
processArguments.clear();
minecraftArguments.clear();
minimumLauncherVersion = 0xDEADBEAF;
mainClass.clear();
libraries.clear();
}
QList<std::shared_ptr<DerpLibrary> > DerpVersion::getActiveNormalLibs() QList<std::shared_ptr<DerpLibrary> > DerpVersion::getActiveNormalLibs()
{ {
QList<std::shared_ptr<DerpLibrary> > output; QList<std::shared_ptr<DerpLibrary> > output;

View File

@ -39,6 +39,7 @@ public:
virtual Qt::ItemFlags flags(const QModelIndex &index) const; virtual Qt::ItemFlags flags(const QModelIndex &index) const;
bool reload(QWidget *widgetParent); bool reload(QWidget *widgetParent);
void clear();
public: public:
QList<std::shared_ptr<DerpLibrary>> getActiveNormalLibs(); QList<std::shared_ptr<DerpLibrary>> getActiveNormalLibs();

View File

@ -24,6 +24,7 @@
#include <QMessageBox> #include <QMessageBox>
#include <QObject> #include <QObject>
#include <QDir> #include <QDir>
#include <QDebug>
#include "DerpVersion.h" #include "DerpVersion.h"
#include "DerpInstance.h" #include "DerpInstance.h"
@ -45,7 +46,7 @@ bool DerpVersionBuilder::build(DerpVersion *version, DerpInstance *instance, QWi
bool DerpVersionBuilder::build() bool DerpVersionBuilder::build()
{ {
clear(); m_version->clear();
QDir root(m_instance->instanceRoot()); QDir root(m_instance->instanceRoot());
QDir patches(root.absoluteFilePath("patches/")); QDir patches(root.absoluteFilePath("patches/"));
@ -112,20 +113,6 @@ bool DerpVersionBuilder::build()
return true; return true;
} }
void DerpVersionBuilder::clear()
{
m_version->id.clear();
m_version->time.clear();
m_version->releaseTime.clear();
m_version->type.clear();
m_version->assets.clear();
m_version->processArguments.clear();
m_version->minecraftArguments.clear();
m_version->minimumLauncherVersion = 0xDEADBEAF;
m_version->mainClass.clear();
m_version->libraries.clear();
}
void applyString(const QJsonObject &obj, const QString &key, QString &out) void applyString(const QJsonObject &obj, const QString &key, QString &out)
{ {
if (obj.contains(key) && obj.value(key).isString()) if (obj.contains(key) && obj.value(key).isString())
@ -181,6 +168,7 @@ bool DerpVersionBuilder::apply(const QJsonObject &object)
} }
// libraries // libraries
if (object.contains("libraries"))
{ {
auto librariesValue = object.value("libraries"); auto librariesValue = object.value("libraries");
if (!librariesValue.isArray()) if (!librariesValue.isArray())

View File

@ -15,12 +15,18 @@
#include "LiteLoaderInstaller.h" #include "LiteLoaderInstaller.h"
#include <QJsonArray>
#include <QJsonDocument>
#include "logger/QsLog.h"
#include "DerpVersion.h" #include "DerpVersion.h"
#include "DerpLibrary.h" #include "DerpLibrary.h"
#include "DerpInstance.h"
QMap<QString, QString> LiteLoaderInstaller::m_launcherWrapperVersionMapping; QMap<QString, QString> LiteLoaderInstaller::m_launcherWrapperVersionMapping;
LiteLoaderInstaller::LiteLoaderInstaller(const QString &mcVersion) : m_mcVersion(mcVersion) LiteLoaderInstaller::LiteLoaderInstaller()
{ {
if (m_launcherWrapperVersionMapping.isEmpty()) if (m_launcherWrapperVersionMapping.isEmpty())
{ {
@ -31,71 +37,82 @@ LiteLoaderInstaller::LiteLoaderInstaller(const QString &mcVersion) : m_mcVersion
} }
} }
bool LiteLoaderInstaller::canApply() const bool LiteLoaderInstaller::canApply(DerpInstance *instance) const
{ {
return m_launcherWrapperVersionMapping.contains(m_mcVersion); return m_launcherWrapperVersionMapping.contains(instance->intendedVersionId());
} }
bool LiteLoaderInstaller::apply(std::shared_ptr<DerpVersion> to) bool LiteLoaderInstaller::isApplied(DerpInstance *on)
{ {
// DERPFIX return QFile::exists(filename(on->instanceRoot()));
}
applyLaunchwrapper(to); bool LiteLoaderInstaller::add(DerpInstance *to)
applyLiteLoader(to); {
if (!patchesDir(to->instanceRoot()).exists())
to->mainClass = "net.minecraft.launchwrapper.Launch";
if (!to->minecraftArguments.contains(
" --tweakClass com.mumfrey.liteloader.launch.LiteLoaderTweaker"))
{ {
to->minecraftArguments.append( QDir(to->instanceRoot()).mkdir("patches");
" --tweakClass com.mumfrey.liteloader.launch.LiteLoaderTweaker");
} }
if (isApplied(to))
{
if (!remove(to))
{
return false;
}
}
QJsonObject obj;
obj.insert("mainClass", QString("net.minecraft.launchwrapper.Launch"));
obj.insert("+minecraftArguments", QString(" --tweakClass com.mumfrey.liteloader.launch.LiteLoaderTweaker"));
obj.insert("order", 10);
QJsonArray libraries;
// launchwrapper
{
DerpLibrary launchwrapperLib("net.minecraft:launchwrapper:" + m_launcherWrapperVersionMapping[to->intendedVersionId()]);
launchwrapperLib.finalize();
QJsonObject lwLibObj = launchwrapperLib.toJson();
lwLibObj.insert("insert", QString("beginning"));
libraries.append(lwLibObj);
}
// liteloader
{
DerpLibrary liteloaderLib("com.mumfrey:liteloader:" + to->intendedVersionId());
liteloaderLib.setBaseUrl("http://dl.liteloader.com/versions/");
liteloaderLib.finalize();
QJsonObject llLibObj = liteloaderLib.toJson();
llLibObj.insert("insert", QString("beginning"));
libraries.append(llLibObj);
}
obj.insert("+libraries", libraries);
QFile file(filename(to->instanceRoot()));
if (!file.open(QFile::WriteOnly))
{
QLOG_ERROR() << "Error opening" << file.fileName() << "for reading:" << file.errorString();
return false;
}
file.write(QJsonDocument(obj).toJson());
file.close();
return true; return true;
} }
void LiteLoaderInstaller::applyLaunchwrapper(std::shared_ptr<DerpVersion> to) bool LiteLoaderInstaller::remove(DerpInstance *from)
{ {
const QString intendedVersion = m_launcherWrapperVersionMapping[m_mcVersion]; return QFile::remove(filename(from->instanceRoot()));
QMutableListIterator<std::shared_ptr<DerpLibrary>> it(to->libraries);
while (it.hasNext())
{
it.next();
if (it.value()->rawName().startsWith("net.minecraft:launchwrapper:"))
{
if (it.value()->version() >= intendedVersion)
{
return;
}
else
{
it.remove();
}
}
}
std::shared_ptr<DerpLibrary> lib(new DerpLibrary(
"net.minecraft:launchwrapper:" + m_launcherWrapperVersionMapping[m_mcVersion]));
lib->finalize();
to->libraries.prepend(lib);
} }
void LiteLoaderInstaller::applyLiteLoader(std::shared_ptr<DerpVersion> to) QString LiteLoaderInstaller::filename(const QString &root) const
{ {
QMutableListIterator<std::shared_ptr<DerpLibrary>> it(to->libraries); return patchesDir(root).absoluteFilePath(id() + ".json");
while (it.hasNext()) }
{ QDir LiteLoaderInstaller::patchesDir(const QString &root) const
it.next(); {
if (it.value()->rawName().startsWith("com.mumfrey:liteloader:")) return QDir(root + "/patches/");
{
it.remove();
}
}
std::shared_ptr<DerpLibrary> lib(
new DerpLibrary("com.mumfrey:liteloader:" + m_mcVersion));
lib->setBaseUrl("http://dl.liteloader.com/versions/");
lib->finalize();
to->libraries.prepend(lib);
} }

View File

@ -19,21 +19,25 @@
#include <memory> #include <memory>
class DerpVersion; class DerpVersion;
class DerpInstance;
class QDir;
// TODO base class
class LiteLoaderInstaller class LiteLoaderInstaller
{ {
public: public:
LiteLoaderInstaller(const QString &mcVersion); LiteLoaderInstaller();
bool canApply() const; bool canApply(DerpInstance *instance) const;
bool isApplied(DerpInstance *on);
bool apply(std::shared_ptr<DerpVersion> to); bool add(DerpInstance *to);
bool remove(DerpInstance *from);
private: private:
QString m_mcVersion; virtual QString id() const { return "com.mumfrey.liteloader"; }
QString filename(const QString &root) const;
void applyLaunchwrapper(std::shared_ptr<DerpVersion> to); QDir patchesDir(const QString &root) const;
void applyLiteLoader(std::shared_ptr<DerpVersion> to);
static QMap<QString, QString> m_launcherWrapperVersionMapping; static QMap<QString, QString> m_launcherWrapperVersionMapping;
}; };