AndroidSignalOperation: Connect to QtcProcess::done() signal

Instead of connecting to finished() signal.
Get rid of some code repetition.

Change-Id: I50d2ba0e4607c853dbc9a0baae5b9ba2bdf41e2c
Reviewed-by: Alessandro Portale <alessandro.portale@qt.io>
Reviewed-by: <github-actions-qt-creator@cristianadam.eu>
This commit is contained in:
Jarek Kobus
2022-04-05 17:57:04 +02:00
parent 7c8b5648fe
commit 5cf8c9fec3
2 changed files with 20 additions and 22 deletions

View File

@@ -44,23 +44,28 @@ AndroidSignalOperation::AndroidSignalOperation()
AndroidSignalOperation::~AndroidSignalOperation() = default;
bool AndroidSignalOperation::handleCrashMessage()
{
if (m_adbProcess->exitStatus() == QProcess::NormalExit)
return false;
m_errorMessage = QLatin1String(" adb process exit code: ") + QString::number(m_adbProcess->exitCode());
const QString adbError = m_adbProcess->errorString();
if (!adbError.isEmpty())
m_errorMessage += QLatin1String(" adb process error: ") + adbError;
return true;
}
void AndroidSignalOperation::adbFindRunAsFinished()
{
QTC_ASSERT(m_state == RunAs, return);
m_timeout->stop();
QString runAs = QString::fromLatin1(m_adbProcess->readAllStandardOutput());
if (m_adbProcess->exitStatus() != QProcess::NormalExit) {
m_errorMessage = QLatin1String(" adb Exit code: ") + QString::number(m_adbProcess->exitCode());
QString adbError = m_adbProcess->errorString();
if (!adbError.isEmpty())
m_errorMessage += QLatin1String(" adb process error: ") + adbError;
}
handleCrashMessage();
const QString runAs = QString::fromLatin1(m_adbProcess->readAllStandardOutput());
m_adbProcess.release()->deleteLater();
if (runAs.isEmpty() || !m_errorMessage.isEmpty()) {
m_errorMessage = QLatin1String("Cannot find User for process: ")
+ QString::number(m_pid)
+ m_errorMessage;
m_errorMessage.prepend(QLatin1String("Cannot find User for process: ")
+ QString::number(m_pid));
m_state = Idle;
emit finished(m_errorMessage);
} else {
@@ -75,19 +80,11 @@ void AndroidSignalOperation::adbKillFinished()
QTC_ASSERT(m_state == Kill, return);
m_timeout->stop();
if (m_adbProcess->exitStatus() != QProcess::NormalExit) {
m_errorMessage = QLatin1String(" adb process exit code: ") + QString::number(m_adbProcess->exitCode());
QString adbError = m_adbProcess->errorString();
if (!adbError.isEmpty())
m_errorMessage += QLatin1String(" adb process error: ") + adbError;
} else {
if (!handleCrashMessage())
m_errorMessage = QString::fromLatin1(m_adbProcess->readAllStandardError());
}
m_adbProcess.release()->deleteLater();
if (!m_errorMessage.isEmpty()) {
m_errorMessage = QLatin1String("Cannot kill process: ") + QString::number(m_pid)
+ m_errorMessage;
}
if (!m_errorMessage.isEmpty())
m_errorMessage.prepend(QLatin1String("Cannot kill process: ") + QString::number(m_pid));
m_state = Idle;
emit finished(m_errorMessage);
}
@@ -116,7 +113,7 @@ void AndroidSignalOperation::startAdbProcess(State state, const Utils::CommandLi
m_state = state;
m_timeout->start();
m_adbProcess.reset(new QtcProcess);
connect(m_adbProcess.get(), &QtcProcess::finished, this, handler);
connect(m_adbProcess.get(), &QtcProcess::done, this, handler);
m_adbProcess->setCommand(commandLine);
m_adbProcess->start();
}