PrismLauncher/gui/ConsoleWindow.h

86 lines
2.0 KiB
C
Raw Normal View History

/* 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
*
* 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-22 17:18:23 +00:00
#include <QMainWindow>
#include "logic/MinecraftProcess.h"
2013-02-22 17:18:23 +00:00
namespace Ui
{
2013-02-22 17:18:23 +00:00
class ConsoleWindow;
}
class ConsoleWindow : public QMainWindow
2013-02-22 17:18:23 +00:00
{
Q_OBJECT
2013-02-22 17:18:23 +00:00
public:
2013-09-06 21:40:50 +01:00
explicit ConsoleWindow(MinecraftProcess *proc, QWidget *parent = 0);
~ConsoleWindow();
2013-02-22 17:18:23 +00:00
/**
* @brief specify if the window is allowed to close
* @param mayclose
* used to keep it alive while MC runs
*/
void setMayClose(bool mayclose);
2013-02-22 17:18:23 +00:00
signals:
void isClosing();
public
slots:
/**
* @brief write a string
* @param data the string
* @param mode the WriteMode
* lines have to be put through this as a whole!
*/
void write(QString data, MessageLevel::Enum level = MessageLevel::MultiMC);
/**
* @brief write a colored paragraph
* @param data the string
* @param color the css color name
* this will only insert a single paragraph.
* \n are ignored. a real \n is always appended.
*/
void writeColor(QString data, const char *color = nullptr);
/**
* @brief clear the text widget
*/
void clear();
2013-02-22 17:18:23 +00:00
private
slots:
void on_closeButton_clicked();
2013-09-06 21:40:50 +01:00
void on_btnKillMinecraft_clicked();
void onEnded(BaseInstance *instance, int code, QProcess::ExitStatus status);
void onLaunchFailed(BaseInstance *instance);
// FIXME: add handlers for the other MinecraftProcess signals (pre/post launch command
// failures)
2013-02-22 17:18:23 +00:00
protected:
void closeEvent(QCloseEvent *);
2013-02-22 17:18:23 +00:00
private:
Ui::ConsoleWindow *ui = nullptr;
MinecraftProcess *proc = nullptr;
bool m_mayclose = true;
2013-02-22 17:18:23 +00:00
};