PrismLauncher/launcher/BaseInstance.h

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

343 lines
10 KiB
C
Raw Normal View History

// SPDX-License-Identifier: GPL-3.0-only
/*
* Prism Launcher - Minecraft Launcher
* Copyright (C) 2022 Sefa Eyeoglu <contact@scrumplex.net>
* Copyright (c) 2022 Jamie Mansfield <jmansfield@cadixdev.org>
* Copyright (C) 2023 TheKodeToad <TheKodeToad@proton.me>
2013-02-15 04:40:00 +00:00
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, version 3.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
2013-02-15 04:40:00 +00:00
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*
* This file incorporates work covered by the following copyright and
* permission notice:
*
* Copyright 2013-2021 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.
2013-02-15 04:40:00 +00:00
*/
#pragma once
2016-10-02 23:55:54 +01:00
#include <cassert>
2013-02-15 04:40:00 +00:00
#include <QDateTime>
#include <QMenu>
#include <QObject>
#include <QProcess>
#include <QSet>
#include "QObjectPtr.h"
2013-02-15 04:40:00 +00:00
2015-02-09 00:51:14 +00:00
#include "settings/SettingsObject.h"
2013-02-25 20:44:36 +00:00
2015-02-09 00:51:14 +00:00
#include "settings/INIFile.h"
#include "BaseVersionList.h"
#include "minecraft/auth/MinecraftAccount.h"
#include "MessageLevel.h"
#include "pathmatcher/IPathMatcher.h"
#include "net/Mode.h"
#include "minecraft/launch/MinecraftServerTarget.h"
#include "RuntimeContext.h"
2014-02-21 18:15:59 +00:00
class QDir;
class Task;
class LaunchTask;
class BaseInstance;
2013-02-15 04:40:00 +00:00
2014-09-06 17:16:56 +01:00
// pointer for lazy people
typedef std::shared_ptr<BaseInstance> InstancePtr;
2013-02-15 04:40:00 +00:00
/*!
* \brief Base class for instances.
* This class implements many functions that are common between instances and
2013-02-15 04:40:00 +00:00
* provides a standard interface for all instances.
*
2013-02-15 04:40:00 +00: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, public std::enable_shared_from_this<BaseInstance>
2013-02-15 04:40:00 +00:00
{
Q_OBJECT
2013-08-03 14:57:33 +01:00
protected:
/// no-touchy!
2015-02-01 02:08:25 +00:00
BaseInstance(SettingsObjectPtr globalSettings, SettingsObjectPtr settings, const QString &rootDir);
2016-10-02 23:55:54 +01:00
public: /* types */
enum class Status
{
Present,
Gone // either nuked or invalidated
};
2013-02-15 04:40:00 +00:00
public:
2013-08-03 14:57:33 +01:00
/// virtual destructor to make sure the destruction is COMPLETE
virtual ~BaseInstance() {};
virtual void saveNow() = 0;
2015-01-27 21:31:07 +00:00
2016-10-02 23:55:54 +01:00
/***
2021-10-17 23:47:02 +01:00
* the instance has been invalidated - it is no longer tracked by the launcher for some reason,
2016-10-02 23:55:54 +01:00
* but it has not necessarily been deleted.
*
* Happens when the instance folder changes to some other location, or the instance is removed by external means.
*/
void invalidate();
/// The instance's ID. The ID SHALL be determined by LAUNCHER internally. The ID IS guaranteed to
/// be unique.
virtual QString id() const;
2014-12-18 01:48:14 +00:00
void setRunning(bool running);
bool isRunning() const;
int64_t totalTimePlayed() const;
int64_t lastTimePlayed() const;
void resetTimePlayed();
2013-08-03 14:57:33 +01:00
/// get the type of this instance
QString instanceType() const;
2018-07-15 13:51:05 +01:00
2013-08-03 14:57:33 +01:00
/// Path to the instance's root directory.
QString instanceRoot() const;
2018-07-15 13:51:05 +01:00
/// Path to the instance's game root directory.
virtual QString gameRoot() const
{
return instanceRoot();
}
/// Path to the instance's mods directory.
virtual QString modsRoot() const = 0;
2013-08-03 14:57:33 +01:00
QString name() const;
void setName(QString val);
2018-07-15 13:51:05 +01:00
2014-01-12 22:38:12 +00:00
/// Value used for instance window titles
QString windowTitle() const;
2018-07-15 13:51:05 +01:00
2013-08-03 14:57:33 +01:00
QString iconKey() const;
void setIconKey(QString val);
2018-07-15 13:51:05 +01:00
2013-08-03 14:57:33 +01:00
QString notes() const;
void setNotes(QString val);
2018-07-15 13:51:05 +01:00
QString getPreLaunchCommand();
QString getPostExitCommand();
QString getWrapperCommand();
2018-07-15 13:51:05 +01:00
bool isManagedPack() const;
QString getManagedPackType() const;
QString getManagedPackID() const;
QString getManagedPackName() const;
QString getManagedPackVersionID() const;
QString getManagedPackVersionName() const;
void setManagedPack(const QString& type, const QString& id, const QString& name, const QString& versionId, const QString& version);
void copyManagedPack(BaseInstance& other);
2015-07-22 08:01:04 +01:00
/// guess log level from a line of game log
virtual MessageLevel::Enum guessLevel([[maybe_unused]] const QString &line, MessageLevel::Enum level)
2015-07-22 08:01:04 +01:00
{
return level;
};
2018-07-15 13:51:05 +01:00
virtual QStringList extraArguments();
2018-07-15 13:51:05 +01:00
/// Traits. Normally inside the version, depends on instance implementation.
2017-09-21 23:27:30 +01:00
virtual QSet <QString> traits() const = 0;
2018-07-15 13:51:05 +01:00
2013-08-03 14:57:33 +01: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());
2018-07-15 13:51:05 +01:00
2013-02-25 20:44:36 +00:00
/*!
* \brief Gets this instance's settings object.
* This settings object stores instance-specific settings.
*
* Note that this method is not const.
* It may call loadSpecificSettings() to ensure those are loaded.
*
2013-02-25 20:44:36 +00:00
* \return A pointer to this instance's settings object.
*/
virtual SettingsObjectPtr settings();
2018-07-15 13:51:05 +01:00
/*!
* \brief Loads settings specific to an instance type if they're not already loaded.
*/
virtual void loadSpecificSettings() = 0;
/// returns a valid update task
2021-11-21 22:36:55 +00:00
virtual Task::Ptr createUpdateTask(Net::Mode mode) = 0;
2018-07-15 13:51:05 +01:00
/// returns a valid launcher (task container)
virtual shared_qobject_ptr<LaunchTask> createLaunchTask(
AuthSessionPtr account, MinecraftServerTargetPtr serverToJoin) = 0;
2018-07-15 13:51:05 +01:00
/// returns the current launch task (if any)
shared_qobject_ptr<LaunchTask> getLaunchTask();
2018-07-15 13:51:05 +01:00
/*!
* Create envrironment variables for running the instance
*/
virtual QProcessEnvironment createEnvironment() = 0;
virtual QProcessEnvironment createLaunchEnvironment() = 0;
2018-07-15 13:51:05 +01:00
/*!
* Returns a matcher that can maps relative paths within the instance to whether they are 'log files'
*/
virtual IPathMatcher::Ptr getLogFileMatcher() = 0;
2018-07-15 13:51:05 +01:00
/*!
* Returns the root folder to use for looking up log files
*/
virtual QString getLogFileRoot() = 0;
2018-07-15 13:51:05 +01:00
virtual QString getStatusbarDescription() = 0;
2018-07-15 13:51:05 +01:00
/// FIXME: this really should be elsewhere...
virtual QString instanceConfigFolder() const = 0;
2018-07-15 13:51:05 +01:00
/// get variables this instance exports
virtual QMap<QString, QString> getVariables() = 0;
2018-07-15 13:51:05 +01:00
virtual QString typeName() const = 0;
2018-07-15 13:51:05 +01:00
void updateRuntimeContext();
RuntimeContext runtimeContext() const
{
return m_runtimeContext;
}
bool hasVersionBroken() const
{
return m_hasBrokenVersion;
}
void setVersionBroken(bool value)
{
if(m_hasBrokenVersion != value)
{
m_hasBrokenVersion = value;
emit propertiesChanged(this);
}
}
2018-07-15 13:51:05 +01:00
bool hasUpdateAvailable() const
{
return m_hasUpdate;
}
void setUpdateAvailable(bool value)
{
if(m_hasUpdate != value)
{
m_hasUpdate = value;
emit propertiesChanged(this);
}
}
2018-07-15 13:51:05 +01:00
bool hasCrashed() const
{
return m_crashed;
}
void setCrashed(bool value)
{
if(m_crashed != value)
{
m_crashed = value;
emit propertiesChanged(this);
}
}
2018-07-15 13:51:05 +01:00
2017-09-20 22:38:31 +01:00
virtual bool canLaunch() const;
virtual bool canEdit() const = 0;
virtual bool canExport() const = 0;
2018-07-15 13:51:05 +01:00
virtual void populateLaunchMenu(QMenu* menu) = 0;
bool reloadSettings();
2018-07-15 13:51:05 +01:00
/**
* 'print' a verbose description of the instance into a QStringList
*/
virtual QStringList verboseDescription(AuthSessionPtr session, MinecraftServerTargetPtr serverToJoin) = 0;
2018-07-15 13:51:05 +01:00
2016-10-02 23:55:54 +01:00
Status currentStatus() const;
2018-07-15 13:51:05 +01:00
int getConsoleMaxLines() const;
bool shouldStopOnConsoleOverflow() const;
QStringList getLinkedInstances() const;
void setLinkedInstances(const QStringList& list);
void addLinkedInstanceId(const QString& id);
bool removeLinkedInstanceId(const QString& id);
bool isLinkedToInstanceId(const QString& id) const;
2016-10-02 23:55:54 +01:00
protected:
void changeStatus(Status newStatus);
SettingsObjectPtr globalSettings() const { return m_global_settings.lock(); };
bool isSpecificSettingsLoaded() const { return m_specific_settings_loaded; }
void setSpecificSettingsLoaded(bool loaded) { m_specific_settings_loaded = loaded; }
signals:
/*!
* \brief Signal emitted when properties relevant to the instance view change
*/
void propertiesChanged(BaseInstance *inst);
void launchTaskChanged(shared_qobject_ptr<LaunchTask>);
void runningStatusChanged(bool running);
void profilerChanged();
2016-10-02 23:55:54 +01:00
void statusChanged(Status from, Status to);
protected slots:
void iconUpdated(QString key);
2016-10-02 23:55:54 +01:00
protected: /* data */
2014-12-18 01:48:14 +00:00
QString m_rootDir;
2015-02-09 00:51:14 +00:00
SettingsObjectPtr m_settings;
// InstanceFlags m_flags;
2014-12-18 01:48:14 +00:00
bool m_isRunning = false;
shared_qobject_ptr<LaunchTask> m_launchProcess;
QDateTime m_timeStarted;
RuntimeContext m_runtimeContext;
2016-10-02 23:55:54 +01:00
private: /* data */
Status m_status = Status::Present;
bool m_crashed = false;
bool m_hasUpdate = false;
bool m_hasBrokenVersion = false;
SettingsObjectWeakPtr m_global_settings;
bool m_specific_settings_loaded = false;
2013-02-15 04:40:00 +00:00
};
Q_DECLARE_METATYPE(shared_qobject_ptr<BaseInstance>)
//Q_DECLARE_METATYPE(BaseInstance::InstanceFlag)
//Q_DECLARE_OPERATORS_FOR_FLAGS(BaseInstance::InstanceFlags)