pollymc/logic/BaseInstance.h

224 lines
6.0 KiB
C
Raw Normal View History

2014-11-02 19:49:58 +01:00
/* Copyright 2013-2014 MultiMC Contributors
2013-02-14 22:40:00 -06:00
*
* 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-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.
*/
#pragma once
2013-02-14 22:40:00 -06:00
#include <QObject>
#include <QDateTime>
#include <QSet>
2013-02-14 22:40:00 -06:00
#include "logic/settings/SettingsObject.h"
2013-02-25 14:44:36 -06:00
#include "logic/settings/INIFile.h"
2014-05-08 21:20:10 +02:00
#include "logic/BaseVersionList.h"
#include "logic/auth/MojangAccount.h"
class ModList;
class QDialog;
2014-02-21 19:15:59 +01:00
class QDir;
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
2014-09-06 18:16:56 +02:00
// pointer for lazy people
class BaseInstance;
typedef std::shared_ptr<BaseInstance> InstancePtr;
2013-02-14 22:40:00 -06:00
/*!
* \brief Base class for instances.
* 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-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.
*/
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!
2014-12-18 02:48:14 +01:00
BaseInstance(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() {};
virtual void init() {}
2014-02-21 19:15:59 +01:00
virtual void copy(const QDir &newDir) {}
/// nuke thoroughly - deletes the instance contents, notifies the list/model which is
/// responsible of cleaning up the husk
void nuke();
/// The instance's ID. The ID SHALL be determined by MMC internally. The ID IS guaranteed to
/// be unique.
virtual QString id() const;
2014-12-18 02:48:14 +01:00
void setRunning(bool running);
bool isRunning() const;
2013-08-03 15:57:33 +02:00
/// get the type of this instance
QString instanceType() const;
2013-08-03 15:57:33 +02:00
/// Path to the instance's root directory.
QString instanceRoot() const;
/// Path to the instance's minecraft directory.
QString minecraftRoot() const;
2013-08-03 15:57:33 +02:00
QString name() const;
void setName(QString val);
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-08-03 15:57:33 +02:00
QString notes() const;
void setNotes(QString val);
2013-08-03 15:57:33 +02:00
QString group() const;
void setGroupInitial(QString val);
void setGroupPost(QString val);
2014-05-05 00:10:59 +02:00
virtual QStringList extraArguments() const;
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;
virtual bool versionIsCustom() = 0;
2013-08-05 03:29:50 +02:00
/*!
* The instance's current version.
* 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-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;
////// Mod Lists //////
virtual std::shared_ptr<ModList> resourcePackList()
{
return nullptr;
}
virtual std::shared_ptr<ModList> texturePackList()
{
return nullptr;
}
2014-12-18 02:48:14 +01:00
/// Traits. Normally inside the version, depends on instance implementation.
virtual QSet <QString> traits() = 0;
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-08-03 23:58:39 +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).
* \return A pointer to the InstanceList containing this instance.
2013-08-03 23:58:39 +02:00
*/
InstanceList *instList() const;
2014-09-06 18:16:56 +02:00
InstancePtr getSharedPtr();
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-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;
/// returns a valid update task
virtual std::shared_ptr<Task> doUpdate() = 0;
/// returns a valid minecraft process, ready for launch with the given account.
virtual bool prepareForLaunch(AuthSessionPtr account, QString & launchScript) = 0;
/// do any necessary cleanups after the instance finishes. also runs before
/// 'prepareForLaunch'
2013-08-05 03:29:50 +02:00
virtual void cleanupAfterRun() = 0;
virtual QString getStatusbarDescription() = 0;
/// FIXME: this really should be elsewhere...
virtual QString instanceConfigFolder() const = 0;
enum InstanceFlag
{
2014-09-06 18:16:56 +02:00
VersionBrokenFlag = 0x01,
UpdateAvailable = 0x02
};
2014-12-18 02:48:14 +01:00
Q_DECLARE_FLAGS(InstanceFlags, InstanceFlag);
2014-09-06 18:16:56 +02:00
InstanceFlags flags() const;
void setFlags(const InstanceFlags &flags);
void setFlag(const InstanceFlag flag);
void unsetFlag(const InstanceFlag flag);
bool canLaunch() const;
virtual bool reload();
signals:
/*!
* \brief Signal emitted when properties relevant to the instance view change
*/
void propertiesChanged(BaseInstance *inst);
/*!
* \brief Signal emitted when groups are affected in any way
*/
void groupChanged();
/*!
* \brief The instance just got nuked. Hurray!
*/
void nuked(BaseInstance *inst);
void flagsChanged();
protected slots:
void iconUpdated(QString key);
2013-08-03 15:57:33 +02:00
protected:
2014-12-18 02:48:14 +01:00
QString m_rootDir;
QString m_group;
std::shared_ptr<SettingsObject> m_settings;
InstanceFlags m_flags;
bool m_isRunning = false;
2013-02-14 22:40:00 -06:00
};
2014-09-06 18:16:56 +02:00
Q_DECLARE_METATYPE(std::shared_ptr<BaseInstance>)
Q_DECLARE_METATYPE(BaseInstance::InstanceFlag)
2014-09-06 18:16:56 +02:00
Q_DECLARE_OPERATORS_FOR_FLAGS(BaseInstance::InstanceFlags)