2014-11-03 00:19:58 +05:30
|
|
|
/* Copyright 2013-2014 MultiMC Contributors
|
2013-02-22 20:47:31 +05:30
|
|
|
*
|
|
|
|
* Authors: Orochimarufan <orochimarufan.x3@gmail.com>
|
|
|
|
*
|
|
|
|
* 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-03-22 19:10:55 +05:30
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
2013-02-22 20:47:31 +05:30
|
|
|
*
|
|
|
|
* 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-11-04 07:23:05 +05:30
|
|
|
|
2013-07-29 04:29:35 +05:30
|
|
|
#pragma once
|
2013-02-22 20:47:31 +05:30
|
|
|
|
|
|
|
#include <QProcess>
|
2014-01-09 05:52:34 +05:30
|
|
|
#include <QString>
|
2013-07-29 04:29:35 +05:30
|
|
|
#include "BaseInstance.h"
|
2013-02-22 20:47:31 +05:30
|
|
|
|
2013-03-22 19:10:55 +05:30
|
|
|
/**
|
|
|
|
* @brief the MessageLevel Enum
|
|
|
|
* defines what level a message is
|
|
|
|
*/
|
2013-11-04 07:23:05 +05:30
|
|
|
namespace MessageLevel
|
|
|
|
{
|
|
|
|
enum Enum
|
|
|
|
{
|
|
|
|
MultiMC, /**< MultiMC Messages */
|
|
|
|
Debug, /**< Debug Messages */
|
2014-01-18 03:25:10 +05:30
|
|
|
Info, /**< Info Messages */
|
2013-11-04 07:23:05 +05:30
|
|
|
Message, /**< Standard Messages */
|
|
|
|
Warning, /**< Warnings */
|
|
|
|
Error, /**< Errors */
|
2014-01-18 03:25:10 +05:30
|
|
|
Fatal, /**< Fatal Errors */
|
|
|
|
PrePost, /**< Pre/Post Launch command output */
|
2013-03-22 19:10:55 +05:30
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2013-02-22 20:47:31 +05:30
|
|
|
/**
|
|
|
|
* @file data/minecraftprocess.h
|
|
|
|
* @brief The MinecraftProcess class
|
|
|
|
*/
|
2013-08-17 17:10:51 +05:30
|
|
|
class MinecraftProcess : public QProcess
|
2013-02-22 20:47:31 +05:30
|
|
|
{
|
2013-03-22 19:10:55 +05:30
|
|
|
Q_OBJECT
|
2013-02-22 20:47:31 +05:30
|
|
|
public:
|
2013-03-22 19:10:55 +05:30
|
|
|
/**
|
|
|
|
* @brief MinecraftProcess constructor
|
|
|
|
* @param inst the Instance pointer to launch
|
|
|
|
*/
|
2014-05-18 22:37:01 +05:30
|
|
|
MinecraftProcess(InstancePtr inst);
|
2013-03-22 19:10:55 +05:30
|
|
|
|
2014-05-18 22:37:01 +05:30
|
|
|
virtual ~MinecraftProcess()
|
|
|
|
{
|
|
|
|
|
|
|
|
};
|
|
|
|
|
2013-03-22 19:10:55 +05:30
|
|
|
/**
|
2014-02-16 04:40:45 +05:30
|
|
|
* @brief start the launcher part with the provided launch script
|
|
|
|
*/
|
|
|
|
void arm();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief launch the armed instance!
|
2013-03-22 19:10:55 +05:30
|
|
|
*/
|
|
|
|
void launch();
|
|
|
|
|
2014-02-16 04:40:45 +05:30
|
|
|
/**
|
|
|
|
* @brief abort launch!
|
|
|
|
*/
|
|
|
|
void abort();
|
|
|
|
|
2014-05-18 22:37:01 +05:30
|
|
|
InstancePtr instance()
|
2013-11-23 06:11:28 +05:30
|
|
|
{
|
|
|
|
return m_instance;
|
|
|
|
}
|
|
|
|
|
2013-11-24 11:06:16 +05:30
|
|
|
void setWorkdir(QString path);
|
2013-11-04 07:23:05 +05:30
|
|
|
|
2014-01-09 05:52:34 +05:30
|
|
|
void setLaunchScript(QString script)
|
|
|
|
{
|
|
|
|
launchScript = script;
|
|
|
|
}
|
|
|
|
|
|
|
|
void setNativeFolder(QString natives)
|
|
|
|
{
|
|
|
|
m_nativeFolder = natives;
|
|
|
|
}
|
2013-11-04 07:23:05 +05:30
|
|
|
|
2013-09-06 22:18:41 +05:30
|
|
|
void killMinecraft();
|
2013-11-04 07:23:05 +05:30
|
|
|
|
2014-01-27 07:30:49 +05:30
|
|
|
inline void setLogin(AuthSessionPtr session)
|
2013-11-04 07:23:05 +05:30
|
|
|
{
|
2014-01-27 07:30:49 +05:30
|
|
|
m_session = session;
|
2013-11-04 07:23:05 +05:30
|
|
|
}
|
|
|
|
|
2013-02-22 20:47:31 +05:30
|
|
|
signals:
|
2013-11-23 06:11:28 +05:30
|
|
|
/**
|
|
|
|
* @brief emitted when Minecraft immediately fails to run
|
|
|
|
*/
|
2014-05-18 22:37:01 +05:30
|
|
|
void launch_failed(InstancePtr);
|
2013-11-23 06:11:28 +05:30
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief emitted when the PreLaunchCommand fails
|
|
|
|
*/
|
2014-05-18 22:37:01 +05:30
|
|
|
void prelaunch_failed(InstancePtr, int code, QProcess::ExitStatus status);
|
2013-11-23 06:11:28 +05:30
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief emitted when the PostLaunchCommand fails
|
|
|
|
*/
|
2014-05-18 22:37:01 +05:30
|
|
|
void postlaunch_failed(InstancePtr, int code, QProcess::ExitStatus status);
|
2013-11-23 06:11:28 +05:30
|
|
|
|
2013-03-22 19:10:55 +05:30
|
|
|
/**
|
|
|
|
* @brief emitted when mc has finished and the PostLaunchCommand was run
|
|
|
|
*/
|
2014-05-18 22:37:01 +05:30
|
|
|
void ended(InstancePtr, int code, QProcess::ExitStatus status);
|
2013-03-22 19:10:55 +05:30
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief emitted when we want to log something
|
|
|
|
* @param text the text to log
|
|
|
|
* @param level the level to log at
|
|
|
|
*/
|
2013-11-04 07:23:05 +05:30
|
|
|
void log(QString text, MessageLevel::Enum level = MessageLevel::MultiMC);
|
2013-02-22 20:47:31 +05:30
|
|
|
|
|
|
|
protected:
|
2014-05-18 22:37:01 +05:30
|
|
|
InstancePtr m_instance;
|
2013-03-26 19:04:34 +05:30
|
|
|
QString m_err_leftover;
|
|
|
|
QString m_out_leftover;
|
2013-03-22 19:10:55 +05:30
|
|
|
QProcess m_prepostlaunchprocess;
|
2013-12-01 06:30:42 +05:30
|
|
|
bool killed = false;
|
2014-01-27 07:30:49 +05:30
|
|
|
AuthSessionPtr m_session;
|
2014-01-09 05:52:34 +05:30
|
|
|
QString launchScript;
|
|
|
|
QString m_nativeFolder;
|
2013-02-22 20:47:31 +05:30
|
|
|
|
2014-03-09 12:48:50 +05:30
|
|
|
bool preLaunch();
|
|
|
|
bool postLaunch();
|
2014-03-15 13:32:56 +05:30
|
|
|
bool waitForPrePost();
|
2014-03-09 12:48:50 +05:30
|
|
|
QMap<QString, QString> getVariables() const;
|
|
|
|
QString substituteVariables(const QString &cmd) const;
|
|
|
|
|
|
|
|
QStringList javaArguments() const;
|
|
|
|
|
2013-11-04 07:23:05 +05:30
|
|
|
protected
|
|
|
|
slots:
|
2013-03-22 19:10:55 +05:30
|
|
|
void finish(int, QProcess::ExitStatus status);
|
|
|
|
void on_stdErr();
|
|
|
|
void on_stdOut();
|
2014-01-18 03:25:10 +05:30
|
|
|
void on_prepost_stdOut();
|
|
|
|
void on_prepost_stdErr();
|
|
|
|
void logOutput(const QStringList &lines,
|
|
|
|
MessageLevel::Enum defaultLevel = MessageLevel::Message,
|
|
|
|
bool guessLevel = true, bool censor = true);
|
|
|
|
void logOutput(QString line,
|
|
|
|
MessageLevel::Enum defaultLevel = MessageLevel::Message,
|
|
|
|
bool guessLevel = true, bool censor = true);
|
2013-11-04 07:23:05 +05:30
|
|
|
|
2013-09-06 22:18:41 +05:30
|
|
|
private:
|
2013-12-01 06:30:42 +05:30
|
|
|
QString censorPrivateInfo(QString in);
|
2014-01-18 03:25:10 +05:30
|
|
|
MessageLevel::Enum guessLevel(const QString &message, MessageLevel::Enum defaultLevel);
|
|
|
|
MessageLevel::Enum getLevel(const QString &levelName);
|
2013-02-22 20:47:31 +05:30
|
|
|
};
|