2013-02-14 22:40:00 -06:00
|
|
|
/* 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
|
2013-10-10 01:47:48 +02:00
|
|
|
*
|
2013-02-14 22:40:00 -06:00
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
2013-07-29 00:59:35 +02:00
|
|
|
#pragma once
|
2013-02-14 22:40:00 -06:00
|
|
|
|
|
|
|
#include <QObject>
|
|
|
|
#include <QDateTime>
|
2014-03-10 17:38:27 +01:00
|
|
|
#include <QSet>
|
2013-02-14 22:40:00 -06:00
|
|
|
|
2013-02-25 14:44:36 -06:00
|
|
|
#include <settingsobject.h>
|
|
|
|
|
2013-02-20 19:10:09 -06:00
|
|
|
#include "inifile.h"
|
2014-05-08 21:20:10 +02:00
|
|
|
#include "logic/BaseVersionList.h"
|
2013-11-20 18:31:15 -06:00
|
|
|
#include "logic/auth/MojangAccount.h"
|
2013-02-20 19:10:09 -06:00
|
|
|
|
2014-06-08 20:11:09 +02:00
|
|
|
class ModList;
|
2013-08-17 13:40:51 +02:00
|
|
|
class QDialog;
|
2014-02-21 19:15:59 +01:00
|
|
|
class QDir;
|
2013-11-24 06:36:16 +01:00
|
|
|
class Task;
|
2013-08-03 15:57:33 +02:00
|
|
|
class MinecraftProcess;
|
2013-08-04 14:46:33 +02:00
|
|
|
class OneSixUpdate;
|
2013-02-14 22:40:00 -06:00
|
|
|
class InstanceList;
|
2013-08-03 15:57:33 +02:00
|
|
|
class BaseInstancePrivate;
|
2013-02-14 22:40:00 -06:00
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Base class for instances.
|
2013-10-10 01:47:48 +02:00
|
|
|
* This class implements many functions that are common between instances and
|
2013-02-14 22:40:00 -06:00
|
|
|
* provides a standard interface for all instances.
|
2013-10-10 01:47:48 +02:00
|
|
|
*
|
2013-02-14 22:40:00 -06:00
|
|
|
* To create a new instance type, create a new class inheriting from this class
|
|
|
|
* and implement the pure virtual functions.
|
|
|
|
*/
|
2013-08-17 13:40:51 +02:00
|
|
|
class BaseInstance : public QObject
|
2013-02-14 22:40:00 -06:00
|
|
|
{
|
|
|
|
Q_OBJECT
|
2013-08-03 15:57:33 +02:00
|
|
|
protected:
|
|
|
|
/// no-touchy!
|
2013-10-10 01:47:48 +02:00
|
|
|
BaseInstance(BaseInstancePrivate *d, const QString &rootDir, SettingsObject *settings,
|
|
|
|
QObject *parent = 0);
|
|
|
|
|
2013-02-14 22:40:00 -06:00
|
|
|
public:
|
2013-08-03 15:57:33 +02:00
|
|
|
/// virtual destructor to make sure the destruction is COMPLETE
|
|
|
|
virtual ~BaseInstance() {};
|
2013-10-10 01:47:48 +02:00
|
|
|
|
2014-02-21 18:01:06 +01:00
|
|
|
virtual void init() {}
|
2014-02-21 19:15:59 +01:00
|
|
|
virtual void copy(const QDir &newDir) {}
|
2014-02-21 18:01:06 +01:00
|
|
|
|
2013-10-10 01:47:48 +02:00
|
|
|
/// nuke thoroughly - deletes the instance contents, notifies the list/model which is
|
|
|
|
/// responsible of cleaning up the husk
|
2013-08-26 06:30:11 +02:00
|
|
|
void nuke();
|
2013-10-10 01:47:48 +02:00
|
|
|
|
|
|
|
/// The instance's ID. The ID SHALL be determined by MMC internally. The ID IS guaranteed to
|
|
|
|
/// be unique.
|
2014-01-15 22:49:37 +01:00
|
|
|
virtual QString id() const;
|
2013-10-10 01:47:48 +02:00
|
|
|
|
2013-08-03 15:57:33 +02:00
|
|
|
/// get the type of this instance
|
|
|
|
QString instanceType() const;
|
2013-10-10 01:47:48 +02:00
|
|
|
|
2013-08-03 15:57:33 +02:00
|
|
|
/// Path to the instance's root directory.
|
2013-08-12 00:39:19 +02:00
|
|
|
QString instanceRoot() const;
|
2013-10-10 01:47:48 +02:00
|
|
|
|
2013-08-12 00:39:19 +02:00
|
|
|
/// Path to the instance's minecraft directory.
|
|
|
|
QString minecraftRoot() const;
|
2013-10-10 01:47:48 +02:00
|
|
|
|
2013-08-03 15:57:33 +02:00
|
|
|
QString name() const;
|
|
|
|
void setName(QString val);
|
2013-10-10 01:47:48 +02:00
|
|
|
|
2014-01-12 23:38:12 +01:00
|
|
|
/// Value used for instance window titles
|
|
|
|
QString windowTitle() const;
|
|
|
|
|
2013-08-03 15:57:33 +02:00
|
|
|
QString iconKey() const;
|
|
|
|
void setIconKey(QString val);
|
2013-10-10 01:47:48 +02:00
|
|
|
|
2013-08-03 15:57:33 +02:00
|
|
|
QString notes() const;
|
|
|
|
void setNotes(QString val);
|
2013-10-10 01:47:48 +02:00
|
|
|
|
2013-08-03 15:57:33 +02:00
|
|
|
QString group() const;
|
2013-08-25 22:48:41 +02:00
|
|
|
void setGroupInitial(QString val);
|
|
|
|
void setGroupPost(QString val);
|
2013-10-10 01:47:48 +02:00
|
|
|
|
2014-05-05 00:10:59 +02:00
|
|
|
virtual QStringList extraArguments() const;
|
2014-01-09 01:22:34 +01:00
|
|
|
|
2013-08-05 03:29:50 +02:00
|
|
|
virtual QString intendedVersionId() const = 0;
|
2013-08-03 23:58:39 +02:00
|
|
|
virtual bool setIntendedVersionId(QString version) = 0;
|
2013-10-10 01:47:48 +02:00
|
|
|
|
|
|
|
virtual bool versionIsCustom() = 0;
|
|
|
|
|
2013-08-05 03:29:50 +02:00
|
|
|
/*!
|
|
|
|
* The instance's current version.
|
2013-10-10 01:47:48 +02:00
|
|
|
* This value represents the instance's current version. If this value is
|
2013-08-05 03:29:50 +02:00
|
|
|
* different from the intendedVersion, the instance should be updated.
|
|
|
|
* \warning Don't change this value unless you know what you're doing.
|
|
|
|
*/
|
|
|
|
virtual QString currentVersionId() const = 0;
|
2013-10-10 01:47:48 +02:00
|
|
|
|
2013-08-05 03:29:50 +02:00
|
|
|
/*!
|
|
|
|
* Whether or not Minecraft should be downloaded when the instance is launched.
|
|
|
|
*/
|
|
|
|
virtual bool shouldUpdate() const = 0;
|
|
|
|
virtual void setShouldUpdate(bool val) = 0;
|
2013-08-24 03:09:46 +02:00
|
|
|
|
2014-06-08 20:11:09 +02:00
|
|
|
////// Mod Lists //////
|
|
|
|
virtual std::shared_ptr<ModList> resourcePackList()
|
|
|
|
{
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
virtual std::shared_ptr<ModList> texturePackList()
|
|
|
|
{
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Traits. Normally inside the version, depends on instance implementation.
|
|
|
|
virtual QSet <QString> traits() = 0;
|
|
|
|
|
2013-10-10 01:47:48 +02:00
|
|
|
/// Get the curent base jar of this instance. By default, it's the
|
|
|
|
/// versions/$version/$version.jar
|
2013-08-24 03:09:46 +02:00
|
|
|
QString baseJar() const;
|
|
|
|
|
|
|
|
/// the default base jar of this instance
|
|
|
|
virtual QString defaultBaseJar() const = 0;
|
|
|
|
/// the default custom base jar of this instance
|
|
|
|
virtual QString defaultCustomBaseJar() const = 0;
|
2013-10-10 01:47:48 +02:00
|
|
|
|
2013-08-24 03:09:46 +02:00
|
|
|
/*!
|
|
|
|
* Whether or not custom base jar is used
|
|
|
|
*/
|
|
|
|
bool shouldUseCustomBaseJar() const;
|
|
|
|
void setShouldUseCustomBaseJar(bool val);
|
|
|
|
/*!
|
|
|
|
* The value of the custom base jar
|
|
|
|
*/
|
|
|
|
QString customBaseJar() const;
|
|
|
|
void setCustomBaseJar(QString val);
|
2013-10-10 01:47:48 +02:00
|
|
|
|
2013-08-03 15:57:33 +02:00
|
|
|
/**
|
|
|
|
* Gets the time that the instance was last launched.
|
|
|
|
* Stored in milliseconds since epoch.
|
|
|
|
*/
|
|
|
|
qint64 lastLaunch() const;
|
|
|
|
/// Sets the last launched time to 'val' milliseconds since epoch
|
|
|
|
void setLastLaunch(qint64 val = QDateTime::currentMSecsSinceEpoch());
|
2013-10-10 01:47:48 +02:00
|
|
|
|
2013-08-03 23:58:39 +02:00
|
|
|
/*!
|
2013-10-10 01:47:48 +02:00
|
|
|
* \brief Gets the instance list that this instance is a part of.
|
|
|
|
* Returns NULL if this instance is not in a list
|
2013-08-03 23:58:39 +02:00
|
|
|
* (the parent is not an InstanceList).
|
2013-10-10 01:47:48 +02:00
|
|
|
* \return A pointer to the InstanceList containing this instance.
|
2013-08-03 23:58:39 +02:00
|
|
|
*/
|
|
|
|
InstanceList *instList() const;
|
2013-10-10 01:47:48 +02:00
|
|
|
|
2013-03-08 13:56:26 -06:00
|
|
|
/*!
|
|
|
|
* \brief Gets a pointer to this instance's version list.
|
|
|
|
* \return A pointer to the available version list for this instance.
|
|
|
|
*/
|
2013-10-06 01:13:40 +02:00
|
|
|
virtual std::shared_ptr<BaseVersionList> versionList() const;
|
2013-10-10 01:47:48 +02:00
|
|
|
|
2013-02-25 14:44:36 -06:00
|
|
|
/*!
|
|
|
|
* \brief Gets this instance's settings object.
|
|
|
|
* This settings object stores instance-specific settings.
|
|
|
|
* \return A pointer to this instance's settings object.
|
|
|
|
*/
|
2013-02-25 16:36:27 -06:00
|
|
|
virtual SettingsObject &settings() const;
|
2013-10-10 01:47:48 +02:00
|
|
|
|
2013-12-15 18:10:51 +01:00
|
|
|
/// returns a valid update task
|
2014-01-27 03:00:49 +01:00
|
|
|
virtual std::shared_ptr<Task> doUpdate() = 0;
|
2013-10-10 01:47:48 +02:00
|
|
|
|
2013-11-20 18:31:15 -06:00
|
|
|
/// returns a valid minecraft process, ready for launch with the given account.
|
2014-05-18 19:07:01 +02:00
|
|
|
virtual bool prepareForLaunch(AuthSessionPtr account, QString & launchScript) = 0;
|
2013-10-10 01:47:48 +02:00
|
|
|
|
|
|
|
/// do any necessary cleanups after the instance finishes. also runs before
|
|
|
|
/// 'prepareForLaunch'
|
2013-08-05 03:29:50 +02:00
|
|
|
virtual void cleanupAfterRun() = 0;
|
2013-10-10 01:47:48 +02:00
|
|
|
|
2013-08-25 01:32:42 +02:00
|
|
|
/// is a particular action enabled with this instance selected?
|
|
|
|
virtual bool menuActionEnabled(QString action_name) const = 0;
|
2013-10-10 01:47:48 +02:00
|
|
|
|
2013-08-25 01:32:42 +02:00
|
|
|
virtual QString getStatusbarDescription() = 0;
|
2013-10-10 01:47:48 +02:00
|
|
|
|
2013-08-25 01:32:42 +02:00
|
|
|
/// FIXME: this really should be elsewhere...
|
|
|
|
virtual QString instanceConfigFolder() const = 0;
|
2013-10-10 01:47:48 +02:00
|
|
|
|
2014-02-17 20:31:50 +01:00
|
|
|
enum InstanceFlag
|
|
|
|
{
|
|
|
|
NoFlags = 0x00,
|
|
|
|
VersionBrokenFlag = 0x01
|
|
|
|
};
|
2014-03-10 17:38:27 +01:00
|
|
|
QSet<InstanceFlag> flags() const;
|
|
|
|
void setFlags(const QSet<InstanceFlag> &flags);
|
2014-02-17 20:31:50 +01:00
|
|
|
|
|
|
|
bool canLaunch() const;
|
|
|
|
|
2014-03-09 08:18:50 +01:00
|
|
|
virtual bool reload();
|
|
|
|
|
2013-03-19 06:24:34 +01:00
|
|
|
signals:
|
|
|
|
/*!
|
|
|
|
* \brief Signal emitted when properties relevant to the instance view change
|
|
|
|
*/
|
2013-10-10 01:47:48 +02:00
|
|
|
void propertiesChanged(BaseInstance *inst);
|
2013-08-25 22:48:41 +02:00
|
|
|
/*!
|
|
|
|
* \brief Signal emitted when groups are affected in any way
|
|
|
|
*/
|
|
|
|
void groupChanged();
|
2013-08-26 06:30:11 +02:00
|
|
|
/*!
|
|
|
|
* \brief The instance just got nuked. Hurray!
|
|
|
|
*/
|
2013-10-10 01:47:48 +02:00
|
|
|
void nuked(BaseInstance *inst);
|
|
|
|
|
2014-02-17 20:31:50 +01:00
|
|
|
void flagsChanged();
|
|
|
|
|
2013-12-31 01:24:28 +01:00
|
|
|
protected slots:
|
|
|
|
void iconUpdated(QString key);
|
|
|
|
|
2013-08-03 15:57:33 +02:00
|
|
|
protected:
|
2013-10-06 01:13:40 +02:00
|
|
|
std::shared_ptr<BaseInstancePrivate> inst_d;
|
2013-02-14 22:40:00 -06:00
|
|
|
};
|
|
|
|
|
2013-02-22 16:17:31 +01:00
|
|
|
// pointer for lazy people
|
2013-10-06 01:13:40 +02:00
|
|
|
typedef std::shared_ptr<BaseInstance> InstancePtr;
|
2014-02-17 20:31:50 +01:00
|
|
|
|
2014-03-10 17:38:27 +01:00
|
|
|
Q_DECLARE_METATYPE(BaseInstance::InstanceFlag)
|