2019-11-26 16:49:50 +00:00
|
|
|
#include "muxForm.h"
|
2020-01-14 21:56:44 +01:00
|
|
|
|
2020-01-11 23:46:04 +01:00
|
|
|
#include <QCloseEvent>
|
|
|
|
#include <QProcess>
|
2019-08-10 18:07:43 +01:00
|
|
|
|
2020-01-14 21:56:44 +01:00
|
|
|
#include "ui_muxForm.h"
|
|
|
|
|
2019-11-26 16:49:50 +00:00
|
|
|
const static int MAX_ERRORS_CNT = 10000;
|
|
|
|
|
2020-01-14 21:56:44 +01:00
|
|
|
MuxForm::MuxForm(QWidget *parent) : QDialog(parent, Qt::WindowMaximizeButtonHint), ui(new Ui_muxForm), muxProcess(0)
|
|
|
|
{
|
|
|
|
ui->setupUi(this);
|
|
|
|
connect(ui->progressBar, &QProgressBar::valueChanged, this, &MuxForm::onProgressChanged);
|
|
|
|
connect(ui->abortBtn, &QPushButton::clicked, this, &MuxForm::onAbort);
|
|
|
|
connect(ui->okBtn, &QPushButton::clicked, this, &MuxForm::close);
|
2019-08-10 18:07:43 +01:00
|
|
|
}
|
|
|
|
|
2020-01-14 21:56:44 +01:00
|
|
|
void MuxForm::closeEvent(QCloseEvent *event)
|
|
|
|
{
|
|
|
|
onAbort();
|
|
|
|
event->accept();
|
2019-08-10 18:07:43 +01:00
|
|
|
}
|
|
|
|
|
2020-01-14 21:56:44 +01:00
|
|
|
void MuxForm::prepare(const QString &label)
|
|
|
|
{
|
|
|
|
muxProcess = 0;
|
|
|
|
errCnt = 0;
|
|
|
|
setWindowTitle(label);
|
|
|
|
ui->muxLabel->setText(label + '.');
|
|
|
|
ui->progressBar->setValue(0);
|
|
|
|
ui->stdoutText->clear();
|
|
|
|
ui->stderrText->clear();
|
|
|
|
ui->abortBtn->setEnabled(true);
|
|
|
|
ui->okBtn->setEnabled(false);
|
2019-08-10 18:07:43 +01:00
|
|
|
}
|
|
|
|
|
2020-01-14 21:56:44 +01:00
|
|
|
void MuxForm::onProgressChanged()
|
|
|
|
{
|
|
|
|
ui->progressLabel->setText(QString("Progress: ") + QString::number(ui->progressBar->value() / 10.0, 'f', 1) + '%');
|
2019-08-10 18:07:43 +01:00
|
|
|
}
|
|
|
|
|
2020-01-11 23:46:04 +01:00
|
|
|
void MuxForm::setProgress(int value) { ui->progressBar->setValue(value); }
|
2019-08-10 18:07:43 +01:00
|
|
|
|
2020-01-14 21:56:44 +01:00
|
|
|
void MuxForm::addStdOutLine(const QString &line)
|
|
|
|
{
|
|
|
|
ui->stdoutText->append(line);
|
|
|
|
QTextCursor c = ui->stdoutText->textCursor();
|
|
|
|
c.movePosition(QTextCursor::End);
|
|
|
|
ui->stdoutText->setTextCursor(c);
|
2019-08-10 18:07:43 +01:00
|
|
|
}
|
|
|
|
|
2020-01-14 21:56:44 +01:00
|
|
|
void MuxForm::addStdErrLine(const QString &line)
|
|
|
|
{
|
|
|
|
if (errCnt >= MAX_ERRORS_CNT)
|
|
|
|
return;
|
|
|
|
ui->stderrText->append(line);
|
|
|
|
errCnt = ui->stderrText->document()->blockCount();
|
|
|
|
if (errCnt >= MAX_ERRORS_CNT)
|
|
|
|
{
|
|
|
|
ui->stderrText->append("---------------------------------------");
|
|
|
|
ui->stderrText->append("Too many errors! tsMuxeR is terminated.");
|
|
|
|
onAbort();
|
|
|
|
}
|
|
|
|
QTextCursor c = ui->stderrText->textCursor();
|
|
|
|
c.movePosition(QTextCursor::End);
|
|
|
|
ui->stderrText->setTextCursor(c);
|
2019-08-10 18:07:43 +01:00
|
|
|
}
|
|
|
|
|
2020-01-14 21:56:44 +01:00
|
|
|
void MuxForm::muxFinished(int exitCode, const QString &)
|
|
|
|
{
|
|
|
|
if (muxProcess && ui->abortBtn->isEnabled())
|
|
|
|
{
|
|
|
|
if (exitCode == 0)
|
|
|
|
setWindowTitle("tsMuxeR successfully finished");
|
|
|
|
else
|
|
|
|
setWindowTitle("tsMuxeR finished with error code " + QString::number(exitCode));
|
|
|
|
ui->muxLabel->setText(windowTitle() + '.');
|
|
|
|
ui->abortBtn->setEnabled(false);
|
|
|
|
ui->okBtn->setEnabled(true);
|
|
|
|
}
|
2019-08-10 18:07:43 +01:00
|
|
|
}
|
|
|
|
|
2020-01-14 21:56:44 +01:00
|
|
|
void MuxForm::onAbort()
|
|
|
|
{
|
|
|
|
if (muxProcess == nullptr)
|
|
|
|
return;
|
|
|
|
ui->abortBtn->setEnabled(false);
|
|
|
|
ui->okBtn->setEnabled(true);
|
|
|
|
setWindowTitle("terminating tsMuxeR...");
|
|
|
|
muxProcess->kill();
|
|
|
|
muxProcess->waitForFinished();
|
|
|
|
setWindowTitle("tsMuxeR is terminated");
|
|
|
|
muxProcess = nullptr;
|
2019-08-10 18:07:43 +01:00
|
|
|
}
|
|
|
|
|
2019-11-26 16:49:50 +00:00
|
|
|
void MuxForm::setProcess(QProcess *proc) { muxProcess = proc; }
|