NOISSUE more work on Legacy migration
This commit is contained in:
parent
9a6c2b0e2c
commit
ba3cbb7330
@ -67,8 +67,6 @@ public:
|
|||||||
/// virtual destructor to make sure the destruction is COMPLETE
|
/// virtual destructor to make sure the destruction is COMPLETE
|
||||||
virtual ~BaseInstance() {};
|
virtual ~BaseInstance() {};
|
||||||
|
|
||||||
virtual void copy(SettingsObjectPtr newSettings, const QDir &newDir) {}
|
|
||||||
|
|
||||||
virtual void init() = 0;
|
virtual void init() = 0;
|
||||||
|
|
||||||
/// nuke thoroughly - deletes the instance contents, notifies the list/model which is
|
/// nuke thoroughly - deletes the instance contents, notifies the list/model which is
|
||||||
@ -222,7 +220,8 @@ public:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool canLaunch() const;
|
virtual bool canLaunch() const;
|
||||||
|
virtual bool canEdit() const = 0;
|
||||||
virtual bool canExport() const = 0;
|
virtual bool canExport() const = 0;
|
||||||
|
|
||||||
virtual bool reload();
|
virtual bool reload();
|
||||||
|
@ -232,6 +232,8 @@ set(MINECRAFT_SOURCES
|
|||||||
minecraft/legacy/LegacyModList.cpp
|
minecraft/legacy/LegacyModList.cpp
|
||||||
minecraft/legacy/LegacyInstance.h
|
minecraft/legacy/LegacyInstance.h
|
||||||
minecraft/legacy/LegacyInstance.cpp
|
minecraft/legacy/LegacyInstance.cpp
|
||||||
|
minecraft/legacy/LegacyMigrationTask.h
|
||||||
|
minecraft/legacy/LegacyMigrationTask.cpp
|
||||||
minecraft/GradleSpecifier.h
|
minecraft/GradleSpecifier.h
|
||||||
minecraft/MinecraftInstance.cpp
|
minecraft/MinecraftInstance.cpp
|
||||||
minecraft/MinecraftInstance.h
|
minecraft/MinecraftInstance.h
|
||||||
|
@ -49,9 +49,6 @@ void InstanceCopyTask::copyFinished()
|
|||||||
auto instanceSettings = std::make_shared<INISettingsObject>(FS::PathCombine(m_stagingPath, "instance.cfg"));
|
auto instanceSettings = std::make_shared<INISettingsObject>(FS::PathCombine(m_stagingPath, "instance.cfg"));
|
||||||
instanceSettings->registerSetting("InstanceType", "Legacy");
|
instanceSettings->registerSetting("InstanceType", "Legacy");
|
||||||
|
|
||||||
// FIXME: and this too? errors???
|
|
||||||
m_origInstance->copy(instanceSettings, m_stagingPath);
|
|
||||||
|
|
||||||
InstancePtr inst(new NullInstance(m_globalSettings, instanceSettings, m_stagingPath));
|
InstancePtr inst(new NullInstance(m_globalSettings, instanceSettings, m_stagingPath));
|
||||||
inst->setName(m_instName);
|
inst->setName(m_instName);
|
||||||
inst->setIconKey(m_instIcon);
|
inst->setIconKey(m_instIcon);
|
||||||
|
@ -57,6 +57,14 @@ public:
|
|||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
bool canEdit() const override
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
bool canLaunch() const override
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
QStringList verboseDescription(AuthSessionPtr session) override
|
QStringList verboseDescription(AuthSessionPtr session) override
|
||||||
{
|
{
|
||||||
QStringList out;
|
QStringList out;
|
||||||
|
@ -21,6 +21,12 @@ public:
|
|||||||
|
|
||||||
QString typeName() const override;
|
QString typeName() const override;
|
||||||
QSet<QString> traits() override;
|
QSet<QString> traits() override;
|
||||||
|
|
||||||
|
bool canEdit() const override
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
bool canExport() const override
|
bool canExport() const override
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
|
@ -272,6 +272,15 @@ QString LegacyInstance::defaultCustomBaseJar() const
|
|||||||
return FS::PathCombine(binRoot(), "mcbackup.jar");
|
return FS::PathCombine(binRoot(), "mcbackup.jar");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::shared_ptr<WorldList> LegacyInstance::worldList() const
|
||||||
|
{
|
||||||
|
if (!m_world_list)
|
||||||
|
{
|
||||||
|
m_world_list.reset(new WorldList(savesDir()));
|
||||||
|
}
|
||||||
|
return m_world_list;
|
||||||
|
}
|
||||||
|
|
||||||
QString LegacyInstance::typeName() const
|
QString LegacyInstance::typeName() const
|
||||||
{
|
{
|
||||||
return tr("Legacy");
|
return tr("Legacy");
|
||||||
|
@ -22,6 +22,7 @@
|
|||||||
|
|
||||||
class ModList;
|
class ModList;
|
||||||
class LegacyModList;
|
class LegacyModList;
|
||||||
|
class WorldList;
|
||||||
class Task;
|
class Task;
|
||||||
/*
|
/*
|
||||||
* WHY: Legacy instances - from MultiMC 3 and 4 - are here only to provide a way to upgrade them to the current format.
|
* WHY: Legacy instances - from MultiMC 3 and 4 - are here only to provide a way to upgrade them to the current format.
|
||||||
@ -74,6 +75,7 @@ public:
|
|||||||
|
|
||||||
std::shared_ptr<LegacyModList> jarModList() const;
|
std::shared_ptr<LegacyModList> jarModList() const;
|
||||||
QList<Mod> getJarMods() const;
|
QList<Mod> getJarMods() const;
|
||||||
|
std::shared_ptr<WorldList> worldList() const;
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Whether or not the instance's minecraft.jar needs to be rebuilt.
|
* Whether or not the instance's minecraft.jar needs to be rebuilt.
|
||||||
@ -95,6 +97,14 @@ public:
|
|||||||
|
|
||||||
virtual QString typeName() const override;
|
virtual QString typeName() const override;
|
||||||
|
|
||||||
|
bool canLaunch() const override
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
bool canEdit() const override
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
bool canExport() const override
|
bool canExport() const override
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
@ -125,4 +135,5 @@ public:
|
|||||||
}
|
}
|
||||||
protected:
|
protected:
|
||||||
mutable std::shared_ptr<LegacyModList> jar_mod_list;
|
mutable std::shared_ptr<LegacyModList> jar_mod_list;
|
||||||
|
mutable std::shared_ptr<WorldList> m_world_list;
|
||||||
};
|
};
|
||||||
|
51
api/logic/minecraft/legacy/LegacyMigrationTask.cpp
Normal file
51
api/logic/minecraft/legacy/LegacyMigrationTask.cpp
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
#include "LegacyMigrationTask.h"
|
||||||
|
#include "BaseInstanceProvider.h"
|
||||||
|
#include "settings/INISettingsObject.h"
|
||||||
|
#include "FileSystem.h"
|
||||||
|
#include "NullInstance.h"
|
||||||
|
#include "pathmatcher/RegexpMatcher.h"
|
||||||
|
#include <QtConcurrentRun>
|
||||||
|
|
||||||
|
LegacyMigrationTask::LegacyMigrationTask(SettingsObjectPtr settings, const QString & stagingPath, InstancePtr origInstance)
|
||||||
|
{
|
||||||
|
m_globalSettings = settings;
|
||||||
|
m_stagingPath = stagingPath;
|
||||||
|
m_origInstance = origInstance;
|
||||||
|
}
|
||||||
|
|
||||||
|
void LegacyMigrationTask::executeTask()
|
||||||
|
{
|
||||||
|
setStatus(tr("Copying instance %1").arg(m_origInstance->name()));
|
||||||
|
|
||||||
|
FS::copy folderCopy(m_origInstance->instanceRoot(), m_stagingPath);
|
||||||
|
folderCopy.followSymlinks(true);
|
||||||
|
|
||||||
|
m_copyFuture = QtConcurrent::run(QThreadPool::globalInstance(), folderCopy);
|
||||||
|
connect(&m_copyFutureWatcher, &QFutureWatcher<bool>::finished, this, &LegacyMigrationTask::copyFinished);
|
||||||
|
connect(&m_copyFutureWatcher, &QFutureWatcher<bool>::canceled, this, &LegacyMigrationTask::copyAborted);
|
||||||
|
m_copyFutureWatcher.setFuture(m_copyFuture);
|
||||||
|
}
|
||||||
|
|
||||||
|
void LegacyMigrationTask::copyFinished()
|
||||||
|
{
|
||||||
|
auto successful = m_copyFuture.result();
|
||||||
|
if(!successful)
|
||||||
|
{
|
||||||
|
emitFailed(tr("Instance folder copy failed."));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// FIXME: shouldn't this be able to report errors?
|
||||||
|
auto instanceSettings = std::make_shared<INISettingsObject>(FS::PathCombine(m_stagingPath, "instance.cfg"));
|
||||||
|
instanceSettings->registerSetting("InstanceType", "Legacy");
|
||||||
|
|
||||||
|
InstancePtr inst(new NullInstance(m_globalSettings, instanceSettings, m_stagingPath));
|
||||||
|
inst->setName(tr("%1 (Migrated)").arg(m_origInstance->name()));
|
||||||
|
emitSucceeded();
|
||||||
|
}
|
||||||
|
|
||||||
|
void LegacyMigrationTask::copyAborted()
|
||||||
|
{
|
||||||
|
emitFailed(tr("Instance folder copy has been aborted."));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
37
api/logic/minecraft/legacy/LegacyMigrationTask.h
Normal file
37
api/logic/minecraft/legacy/LegacyMigrationTask.h
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "tasks/Task.h"
|
||||||
|
#include "multimc_logic_export.h"
|
||||||
|
#include "net/NetJob.h"
|
||||||
|
#include <QUrl>
|
||||||
|
#include <QFuture>
|
||||||
|
#include <QFutureWatcher>
|
||||||
|
#include "settings/SettingsObject.h"
|
||||||
|
#include "BaseVersion.h"
|
||||||
|
#include "BaseInstance.h"
|
||||||
|
|
||||||
|
|
||||||
|
class BaseInstanceProvider;
|
||||||
|
|
||||||
|
class MULTIMC_LOGIC_EXPORT LegacyMigrationTask : public Task
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
public:
|
||||||
|
explicit LegacyMigrationTask(SettingsObjectPtr settings, const QString & stagingPath, InstancePtr origInstance);
|
||||||
|
|
||||||
|
protected:
|
||||||
|
//! Entry point for tasks.
|
||||||
|
virtual void executeTask() override;
|
||||||
|
void copyFinished();
|
||||||
|
void copyAborted();
|
||||||
|
|
||||||
|
private: /* data */
|
||||||
|
SettingsObjectPtr m_globalSettings;
|
||||||
|
InstancePtr m_origInstance;
|
||||||
|
QString m_stagingPath;
|
||||||
|
QFuture<bool> m_copyFuture;
|
||||||
|
QFutureWatcher<bool> m_copyFutureWatcher;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -50,6 +50,9 @@ public:
|
|||||||
if(legacy)
|
if(legacy)
|
||||||
{
|
{
|
||||||
values.append(new LegacyUpgradePage(legacy.get()));
|
values.append(new LegacyUpgradePage(legacy.get()));
|
||||||
|
values.append(new NotesPage(legacy.get()));
|
||||||
|
values.append(new WorldListPage(legacy.get(), legacy->worldList(), "worlds", "worlds", tr("Worlds"), "Worlds"));
|
||||||
|
values.append(new ScreenshotsPage(FS::PathCombine(legacy->minecraftRoot(), "screenshots")));
|
||||||
}
|
}
|
||||||
auto logMatcher = inst->getLogFileMatcher();
|
auto logMatcher = inst->getLogFileMatcher();
|
||||||
if(logMatcher)
|
if(logMatcher)
|
||||||
|
@ -72,7 +72,7 @@ InstanceWindow::InstanceWindow(InstancePtr instance, QWidget *parent)
|
|||||||
m_launchOfflineButton = new QPushButton();
|
m_launchOfflineButton = new QPushButton();
|
||||||
horizontalLayout->addWidget(m_launchOfflineButton);
|
horizontalLayout->addWidget(m_launchOfflineButton);
|
||||||
m_launchOfflineButton->setText(tr("Launch Offline"));
|
m_launchOfflineButton->setText(tr("Launch Offline"));
|
||||||
setKillButton(m_instance->isRunning());
|
updateLaunchButtons();
|
||||||
connect(m_launchOfflineButton, SIGNAL(clicked(bool)), SLOT(on_btnLaunchMinecraftOffline_clicked()));
|
connect(m_launchOfflineButton, SIGNAL(clicked(bool)), SLOT(on_btnLaunchMinecraftOffline_clicked()));
|
||||||
|
|
||||||
m_closeButton = new QPushButton();
|
m_closeButton = new QPushButton();
|
||||||
@ -115,14 +115,21 @@ void InstanceWindow::on_instanceStatusChanged(BaseInstance::Status, BaseInstance
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void InstanceWindow::setKillButton(bool kill)
|
void InstanceWindow::updateLaunchButtons()
|
||||||
{
|
{
|
||||||
if(kill)
|
if(m_instance->isRunning())
|
||||||
{
|
{
|
||||||
m_launchOfflineButton->setEnabled(false);
|
m_launchOfflineButton->setEnabled(false);
|
||||||
m_killButton->setText(tr("Kill"));
|
m_killButton->setText(tr("Kill"));
|
||||||
m_killButton->setToolTip(tr("Kill the running instance"));
|
m_killButton->setToolTip(tr("Kill the running instance"));
|
||||||
}
|
}
|
||||||
|
else if(!m_instance->canLaunch())
|
||||||
|
{
|
||||||
|
m_launchOfflineButton->setEnabled(false);
|
||||||
|
m_killButton->setText(tr("Launch"));
|
||||||
|
m_killButton->setToolTip(tr("Launch the instance"));
|
||||||
|
m_killButton->setEnabled(false);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
m_launchOfflineButton->setEnabled(true);
|
m_launchOfflineButton->setEnabled(true);
|
||||||
@ -141,9 +148,9 @@ void InstanceWindow::on_InstanceLaunchTask_changed(std::shared_ptr<LaunchTask> p
|
|||||||
m_proc = proc;
|
m_proc = proc;
|
||||||
}
|
}
|
||||||
|
|
||||||
void InstanceWindow::on_RunningState_changed(bool running)
|
void InstanceWindow::on_RunningState_changed(bool)
|
||||||
{
|
{
|
||||||
setKillButton(running);
|
updateLaunchButtons();
|
||||||
m_container->refreshContainer();
|
m_container->refreshContainer();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -57,7 +57,7 @@ protected:
|
|||||||
void closeEvent(QCloseEvent *) override;
|
void closeEvent(QCloseEvent *) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void setKillButton(bool kill);
|
void updateLaunchButtons();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::shared_ptr<LaunchTask> m_proc;
|
std::shared_ptr<LaunchTask> m_proc;
|
||||||
|
@ -665,8 +665,10 @@ void MainWindow::showInstanceContextMenu(const QPoint &pos)
|
|||||||
}
|
}
|
||||||
QMenu myMenu;
|
QMenu myMenu;
|
||||||
myMenu.addActions(actions);
|
myMenu.addActions(actions);
|
||||||
|
/*
|
||||||
if (onInstance)
|
if (onInstance)
|
||||||
myMenu.setEnabled(m_selectedInstance->canLaunch());
|
myMenu.setEnabled(m_selectedInstance->canLaunch());
|
||||||
|
*/
|
||||||
myMenu.exec(view->mapToGlobal(pos));
|
myMenu.exec(view->mapToGlobal(pos));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -969,6 +969,11 @@ bool MultiMC::launch(InstancePtr instance, bool online, BaseProfilerFactory *pro
|
|||||||
showInstanceWindow(instance, "console");
|
showInstanceWindow(instance, "console");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
else if (instance->canEdit())
|
||||||
|
{
|
||||||
|
showInstanceWindow(instance);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user