2013-11-04 02:53:05 +01: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
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "ConsoleWindow.h"
|
2013-11-23 01:41:28 +01:00
|
|
|
#include "MultiMC.h"
|
2013-02-22 18:18:23 +01:00
|
|
|
|
|
|
|
#include <QScrollBar>
|
2013-09-06 22:40:50 +02:00
|
|
|
#include <QMessageBox>
|
2014-01-06 02:52:51 +01:00
|
|
|
#include <QSystemTrayIcon>
|
2014-06-30 02:02:57 +02:00
|
|
|
#include <QHBoxLayout>
|
|
|
|
#include <QPushButton>
|
|
|
|
#include <qlayoutitem.h>
|
2013-02-22 18:18:23 +01:00
|
|
|
|
2013-11-04 02:53:05 +01:00
|
|
|
#include <gui/Platform.h>
|
|
|
|
#include <gui/dialogs/CustomMessageBox.h>
|
2013-12-06 16:24:55 -05:00
|
|
|
#include <gui/dialogs/ProgressDialog.h>
|
2014-06-30 02:02:57 +02:00
|
|
|
#include "widgets/PageContainer.h"
|
|
|
|
#include "pages/LogPage.h"
|
2013-12-06 16:24:55 -05:00
|
|
|
|
2014-01-06 02:52:51 +01:00
|
|
|
#include "logic/icons/IconList.h"
|
2013-10-18 18:42:41 +02:00
|
|
|
|
2014-06-30 02:02:57 +02:00
|
|
|
class LogPageProvider : public BasePageProvider
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
LogPageProvider(BasePageProviderPtr parent, BasePage * log_page)
|
|
|
|
{
|
|
|
|
m_parent = parent;
|
|
|
|
m_log_page = log_page;
|
|
|
|
}
|
|
|
|
virtual QString dialogTitle() {return "Fake";};
|
|
|
|
virtual QList<BasePage *> getPages()
|
|
|
|
{
|
|
|
|
auto pages = m_parent->getPages();
|
|
|
|
pages.prepend(m_log_page);
|
|
|
|
return pages;
|
|
|
|
}
|
|
|
|
private:
|
|
|
|
BasePageProviderPtr m_parent;
|
|
|
|
BasePage * m_log_page;
|
|
|
|
};
|
|
|
|
|
2013-11-13 00:24:49 +01:00
|
|
|
ConsoleWindow::ConsoleWindow(MinecraftProcess *mcproc, QWidget *parent)
|
2014-06-30 02:02:57 +02:00
|
|
|
: QMainWindow(parent), m_proc(mcproc)
|
2013-02-22 18:18:23 +01:00
|
|
|
{
|
2013-10-29 18:38:11 +00:00
|
|
|
MultiMCPlatform::fixWM_CLASS(this);
|
2014-06-30 02:02:57 +02:00
|
|
|
|
|
|
|
auto instance = m_proc->instance();
|
|
|
|
auto icon = MMC->icons()->getIcon(instance->iconKey());
|
|
|
|
QString windowTitle = tr("Console window for ") + instance->name();
|
|
|
|
|
|
|
|
// Set window properties
|
|
|
|
{
|
|
|
|
setWindowIcon(icon);
|
|
|
|
setWindowTitle(windowTitle);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Add page container
|
|
|
|
{
|
|
|
|
auto mainLayout = new QVBoxLayout;
|
|
|
|
auto provider = std::dynamic_pointer_cast<BasePageProvider>(m_proc->instance());
|
|
|
|
auto proxy_provider = std::make_shared<LogPageProvider>(provider, new LogPage(m_proc));
|
|
|
|
m_container = new PageContainer(proxy_provider, "console", this);
|
|
|
|
mainLayout->addWidget(m_container);
|
|
|
|
mainLayout->setSpacing(0);
|
|
|
|
mainLayout->setContentsMargins(0,0,0,0);
|
|
|
|
setLayout(mainLayout);
|
|
|
|
setCentralWidget(m_container);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Add custom buttons to the page container layout.
|
|
|
|
{
|
|
|
|
auto horizontalLayout = new QHBoxLayout();
|
|
|
|
horizontalLayout->setObjectName(QStringLiteral("horizontalLayout"));
|
|
|
|
horizontalLayout->setContentsMargins(6, -1, 6, -1);
|
|
|
|
|
|
|
|
auto btnHelp = new QPushButton();
|
|
|
|
btnHelp->setText(tr("Help"));
|
|
|
|
horizontalLayout->addWidget(btnHelp);
|
|
|
|
connect(btnHelp, SIGNAL(clicked(bool)), m_container, SLOT(help()));
|
|
|
|
|
|
|
|
auto spacer = new QSpacerItem(40, 20, QSizePolicy::Expanding, QSizePolicy::Minimum);
|
|
|
|
horizontalLayout->addSpacerItem(spacer);
|
|
|
|
|
|
|
|
m_killButton = new QPushButton();
|
|
|
|
m_killButton->setText(tr("Kill Minecraft"));
|
|
|
|
horizontalLayout->addWidget(m_killButton);
|
|
|
|
connect(m_killButton, SIGNAL(clicked(bool)), SLOT(on_btnKillMinecraft_clicked()));
|
|
|
|
|
|
|
|
m_closeButton = new QPushButton();
|
|
|
|
m_closeButton->setText(tr("Close"));
|
|
|
|
horizontalLayout->addWidget(m_closeButton);
|
|
|
|
connect(m_closeButton, SIGNAL(clicked(bool)), SLOT(on_closeButton_clicked()));
|
|
|
|
|
|
|
|
m_container->addButtons(horizontalLayout);
|
|
|
|
}
|
|
|
|
|
|
|
|
// restore window state
|
|
|
|
{
|
|
|
|
auto base64State = MMC->settings()->get("ConsoleWindowState").toByteArray();
|
|
|
|
restoreState(QByteArray::fromBase64(base64State));
|
|
|
|
auto base64Geometry = MMC->settings()->get("ConsoleWindowGeometry").toByteArray();
|
|
|
|
restoreGeometry(QByteArray::fromBase64(base64Geometry));
|
|
|
|
}
|
|
|
|
|
|
|
|
// Set up tray icon
|
|
|
|
{
|
|
|
|
m_trayIcon = new QSystemTrayIcon(icon, this);
|
|
|
|
m_trayIcon->setToolTip(windowTitle);
|
|
|
|
|
|
|
|
connect(m_trayIcon, SIGNAL(activated(QSystemTrayIcon::ActivationReason)),
|
|
|
|
SLOT(iconActivated(QSystemTrayIcon::ActivationReason)));
|
|
|
|
m_trayIcon->show();
|
|
|
|
}
|
|
|
|
|
|
|
|
// Set up signal connections
|
2014-05-18 19:07:01 +02:00
|
|
|
connect(mcproc, SIGNAL(ended(InstancePtr, int, QProcess::ExitStatus)), this,
|
|
|
|
SLOT(onEnded(InstancePtr, int, QProcess::ExitStatus)));
|
|
|
|
connect(mcproc, SIGNAL(prelaunch_failed(InstancePtr, int, QProcess::ExitStatus)), this,
|
|
|
|
SLOT(onEnded(InstancePtr, int, QProcess::ExitStatus)));
|
|
|
|
connect(mcproc, SIGNAL(launch_failed(InstancePtr)), this,
|
|
|
|
SLOT(onLaunchFailed(InstancePtr)));
|
2014-02-24 09:34:21 +01:00
|
|
|
|
2014-06-30 02:02:57 +02:00
|
|
|
setMayClose(false);
|
2014-01-06 02:52:51 +01:00
|
|
|
|
2013-11-23 01:41:28 +01:00
|
|
|
if (mcproc->instance()->settings().get("ShowConsole").toBool())
|
|
|
|
{
|
|
|
|
show();
|
|
|
|
}
|
2013-02-22 18:18:23 +01:00
|
|
|
}
|
|
|
|
|
2014-01-06 02:52:51 +01:00
|
|
|
void ConsoleWindow::iconActivated(QSystemTrayIcon::ActivationReason reason)
|
|
|
|
{
|
|
|
|
switch (reason)
|
|
|
|
{
|
|
|
|
case QSystemTrayIcon::Trigger:
|
|
|
|
{
|
|
|
|
toggleConsole();
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-02-22 18:18:23 +01:00
|
|
|
void ConsoleWindow::on_closeButton_clicked()
|
|
|
|
{
|
2013-03-22 14:40:55 +01:00
|
|
|
close();
|
2013-02-22 18:18:23 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void ConsoleWindow::setMayClose(bool mayclose)
|
|
|
|
{
|
2014-01-09 01:22:34 +01:00
|
|
|
if(mayclose)
|
2014-06-30 02:02:57 +02:00
|
|
|
m_closeButton->setText(tr("Close"));
|
2014-01-09 01:22:34 +01:00
|
|
|
else
|
2014-06-30 02:02:57 +02:00
|
|
|
m_closeButton->setText(tr("Hide"));
|
2013-03-22 14:40:55 +01:00
|
|
|
m_mayclose = mayclose;
|
2014-01-06 02:52:51 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void ConsoleWindow::toggleConsole()
|
|
|
|
{
|
2014-06-30 02:02:57 +02:00
|
|
|
//QScrollBar *bar = ui->text->verticalScrollBar();
|
2014-01-06 02:52:51 +01:00
|
|
|
if (isVisible())
|
|
|
|
{
|
2014-03-24 01:54:18 +01:00
|
|
|
if(!isActiveWindow())
|
|
|
|
{
|
|
|
|
activateWindow();
|
|
|
|
return;
|
|
|
|
}
|
2014-06-30 02:02:57 +02:00
|
|
|
/*
|
2014-01-06 02:52:51 +01:00
|
|
|
int max_bar = bar->maximum();
|
|
|
|
int val_bar = m_last_scroll_value = bar->value();
|
|
|
|
m_scroll_active = (max_bar - val_bar) <= 1;
|
2014-06-30 02:02:57 +02:00
|
|
|
*/
|
2014-01-06 02:52:51 +01:00
|
|
|
hide();
|
|
|
|
}
|
2013-03-22 14:40:55 +01:00
|
|
|
else
|
2014-01-06 02:52:51 +01:00
|
|
|
{
|
|
|
|
show();
|
2014-06-30 02:02:57 +02:00
|
|
|
/*
|
2014-01-06 02:52:51 +01:00
|
|
|
if (m_scroll_active)
|
|
|
|
{
|
|
|
|
bar->setValue(bar->maximum());
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
bar->setValue(m_last_scroll_value);
|
|
|
|
}
|
2014-06-30 02:02:57 +02:00
|
|
|
*/
|
2014-01-06 02:52:51 +01:00
|
|
|
}
|
2013-02-22 18:18:23 +01:00
|
|
|
}
|
|
|
|
|
2013-11-13 00:24:49 +01:00
|
|
|
void ConsoleWindow::closeEvent(QCloseEvent *event)
|
2013-02-22 18:18:23 +01:00
|
|
|
{
|
2013-11-13 00:24:49 +01:00
|
|
|
if (!m_mayclose)
|
2014-01-06 02:52:51 +01:00
|
|
|
{
|
|
|
|
toggleConsole();
|
|
|
|
}
|
2014-07-10 21:13:17 +02:00
|
|
|
else if(m_container->requestClose(event))
|
2013-11-23 01:41:28 +01:00
|
|
|
{
|
|
|
|
MMC->settings()->set("ConsoleWindowState", saveState().toBase64());
|
|
|
|
MMC->settings()->set("ConsoleWindowGeometry", saveGeometry().toBase64());
|
|
|
|
|
|
|
|
emit isClosing();
|
2014-01-06 02:52:51 +01:00
|
|
|
m_trayIcon->hide();
|
2013-11-23 01:41:28 +01:00
|
|
|
QMainWindow::closeEvent(event);
|
|
|
|
}
|
2013-02-22 18:18:23 +01:00
|
|
|
}
|
2013-09-06 22:40:50 +02:00
|
|
|
|
|
|
|
void ConsoleWindow::on_btnKillMinecraft_clicked()
|
|
|
|
{
|
2014-06-30 02:02:57 +02:00
|
|
|
m_killButton->setEnabled(false);
|
2013-11-13 00:24:49 +01:00
|
|
|
auto response = CustomMessageBox::selectable(
|
|
|
|
this, tr("Kill Minecraft?"),
|
|
|
|
tr("This can cause the instance to get corrupted and should only be used if Minecraft "
|
|
|
|
"is frozen for some reason"),
|
|
|
|
QMessageBox::Question, QMessageBox::Yes | QMessageBox::No, QMessageBox::Yes)->exec();
|
2013-10-29 12:40:09 +00:00
|
|
|
if (response == QMessageBox::Yes)
|
2014-06-30 02:02:57 +02:00
|
|
|
m_proc->killMinecraft();
|
2013-09-06 22:40:50 +02:00
|
|
|
else
|
2014-06-30 02:02:57 +02:00
|
|
|
m_killButton->setEnabled(true);
|
2013-09-06 23:52:17 +02:00
|
|
|
}
|
|
|
|
|
2014-05-18 19:07:01 +02:00
|
|
|
void ConsoleWindow::onEnded(InstancePtr instance, int code, QProcess::ExitStatus status)
|
2013-09-06 23:52:17 +02:00
|
|
|
{
|
2014-01-06 02:52:51 +01:00
|
|
|
bool peacefulExit = code == 0 && status != QProcess::CrashExit;
|
2014-06-30 02:02:57 +02:00
|
|
|
m_killButton->setEnabled(false);
|
2013-12-11 12:26:23 +00:00
|
|
|
setMayClose(true);
|
2013-11-13 00:24:49 +01:00
|
|
|
if (instance->settings().get("AutoCloseConsole").toBool())
|
2013-10-22 18:25:10 +01:00
|
|
|
{
|
2014-01-06 02:52:51 +01:00
|
|
|
if (peacefulExit)
|
2013-11-12 09:23:39 +01:00
|
|
|
{
|
|
|
|
this->close();
|
2013-11-23 01:41:28 +01:00
|
|
|
return;
|
2013-11-12 09:23:39 +01:00
|
|
|
}
|
2013-10-22 18:25:10 +01:00
|
|
|
}
|
2014-01-06 02:52:51 +01:00
|
|
|
if (!isVisible())
|
2013-11-23 01:41:28 +01:00
|
|
|
show();
|
2014-04-17 14:13:16 +02:00
|
|
|
// Raise Window
|
|
|
|
if (MMC->settings()->get("RaiseConsole").toBool())
|
|
|
|
{
|
|
|
|
raise();
|
|
|
|
activateWindow();
|
|
|
|
}
|
2013-11-23 01:41:28 +01:00
|
|
|
}
|
|
|
|
|
2014-05-18 19:07:01 +02:00
|
|
|
void ConsoleWindow::onLaunchFailed(InstancePtr instance)
|
2013-11-23 01:41:28 +01:00
|
|
|
{
|
2014-06-30 02:02:57 +02:00
|
|
|
m_killButton->setEnabled(false);
|
2013-12-11 12:26:23 +00:00
|
|
|
|
|
|
|
setMayClose(true);
|
|
|
|
|
2014-01-06 02:52:51 +01:00
|
|
|
if (!isVisible())
|
2013-11-23 01:41:28 +01:00
|
|
|
show();
|
2013-09-06 23:52:17 +02:00
|
|
|
}
|