2023-07-10 15:57:59 +02:00
|
|
|
#include "command.h"
|
|
|
|
|
|
|
|
#include <QProcess>
|
|
|
|
#include <QDebug>
|
|
|
|
#include <QRegularExpression>
|
|
|
|
|
|
|
|
Command::Command(QString const &command, int start_timeout, int finish_timeout)
|
|
|
|
: m_command(command.trimmed())
|
|
|
|
, m_commandResult("")
|
|
|
|
, m_waitForStartTimeout(start_timeout)
|
|
|
|
, m_waitForFinishTimeout(finish_timeout) {
|
|
|
|
}
|
|
|
|
|
|
|
|
QString Command::getCommandResult() const {
|
|
|
|
return m_commandResult;
|
|
|
|
}
|
|
|
|
|
|
|
|
void Command::readyReadStandardOutput() {
|
|
|
|
QProcess *p = (QProcess *)sender();
|
|
|
|
m_commandResult += p->readAllStandardOutput();
|
|
|
|
// qCritical() << m_commandResult;
|
|
|
|
}
|
|
|
|
|
|
|
|
void Command::readyReadStandardError() {
|
|
|
|
QProcess *p = (QProcess *)sender();
|
|
|
|
QByteArray buf = p->readAllStandardError();
|
|
|
|
qCritical() << buf;
|
|
|
|
}
|
|
|
|
|
|
|
|
void Command::finished(int /*exitCode*/, QProcess::ExitStatus /*exitStatus*/) {
|
|
|
|
QProcess *p = (QProcess *)sender();
|
|
|
|
// read all remaining data sent to the process, just in case
|
|
|
|
QString d = p->readAllStandardOutput();
|
|
|
|
if (!d.isEmpty()) {
|
|
|
|
m_commandResult += d;
|
|
|
|
}
|
|
|
|
disconnect(p, SIGNAL(finished(int,QProcess::ExitStatus)), this, SLOT(readyReadStandardOutput()));
|
|
|
|
disconnect(p, SIGNAL(finished(int,QProcess::ExitStatus)), this, SLOT(readyReadStandardError()));
|
|
|
|
}
|
|
|
|
|
2023-07-14 12:56:33 +02:00
|
|
|
bool Command::execute(QString workingDirectory, QStringList args) {
|
2023-07-10 15:57:59 +02:00
|
|
|
QScopedPointer<QProcess> p(new QProcess(this));
|
|
|
|
p->setProcessChannelMode(QProcess::MergedChannels);
|
|
|
|
|
|
|
|
connect(&(*p), SIGNAL(readyReadStandardOutput()), this, SLOT(readyReadStandardOutput()));
|
|
|
|
connect(&(*p), SIGNAL(readyReadStandardError()), this, SLOT(readyReadStandardError()));
|
|
|
|
|
2023-07-19 16:43:24 +02:00
|
|
|
//qCritical() << "START COMMAND" << m_command << "WITH ARGS" << args
|
|
|
|
// << "IN" << workingDirectory;
|
2023-07-14 12:56:33 +02:00
|
|
|
|
2023-07-10 15:57:59 +02:00
|
|
|
p->setWorkingDirectory(workingDirectory);
|
2023-07-14 12:56:33 +02:00
|
|
|
if (!args.isEmpty()) {
|
|
|
|
p->start(m_command, args);
|
|
|
|
} else {
|
|
|
|
p->start(m_command);
|
|
|
|
}
|
2023-07-10 15:57:59 +02:00
|
|
|
|
|
|
|
if (p->waitForStarted(m_waitForStartTimeout)) {
|
2023-07-19 16:43:24 +02:00
|
|
|
//qDebug() << "PROCESS" << m_command << "STARTED";
|
2023-07-10 15:57:59 +02:00
|
|
|
if (p->state() == QProcess::ProcessState::Running) {
|
2023-07-19 16:43:24 +02:00
|
|
|
//qDebug() << "PROCESS" << m_command << "RUNNING";
|
2023-07-10 15:57:59 +02:00
|
|
|
if (p->waitForFinished(m_waitForFinishTimeout)) {
|
2023-07-19 16:43:24 +02:00
|
|
|
//qDebug() << "PROCESS" << m_command << "FINISHED";
|
2023-07-10 15:57:59 +02:00
|
|
|
if (p->exitStatus() == QProcess::NormalExit) {
|
2023-08-04 13:31:12 +02:00
|
|
|
if (p->exitCode() == 0) {
|
|
|
|
return true;
|
|
|
|
} else {
|
|
|
|
qCritical() << "EXECUTED" << m_command << "with code" << p->exitCode();
|
|
|
|
}
|
2023-07-10 15:57:59 +02:00
|
|
|
} else {
|
|
|
|
qCritical() << "PROCESS" << m_command << "CRASHED with code"
|
|
|
|
<< p->exitCode();
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
qCritical() << "PROCESS" << m_command << "DID NOT FINISH";
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
qCritical() << "WRONG PROCESS STATE" << p->state();
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
qCritical() << "PROCESS" << m_command << "TIMEOUT AT START";
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|