Android: Use QtcProcess in AndroidSignalOperation

Plus some code cosmetics.

Change-Id: I8e0e16a2649dbb616af4e0ba076557d94a778467
Reviewed-by: Alessandro Portale <alessandro.portale@qt.io>
Reviewed-by: Artem Sokolovskii <artem.sokolovskii@qt.io>
This commit is contained in:
hjk
2021-08-20 09:05:03 +02:00
parent 7814605215
commit 7c17c00efa
2 changed files with 37 additions and 36 deletions

View File

@@ -27,31 +27,31 @@
#include "androidsignaloperation.h"
#include <utils/qtcassert.h>
#include <utils/qtcprocess.h>
#include <QProcess>
using namespace Utils;
Android::Internal::AndroidSignalOperation::AndroidSignalOperation()
: m_adbPath(AndroidConfigurations::currentConfig().adbToolPath().toString())
, m_adbProcess(new QProcess(this))
namespace Android {
namespace Internal {
AndroidSignalOperation::AndroidSignalOperation()
: m_adbPath(AndroidConfigurations::currentConfig().adbToolPath())
, m_adbProcess(new QtcProcess(this))
, m_timeout(new QTimer(this))
, m_state(Idle)
, m_pid(0)
, m_signal(0)
{
m_timeout->setInterval(5000);
connect(m_timeout, &QTimer::timeout, this, &AndroidSignalOperation::handleTimeout);
}
void Android::Internal::AndroidSignalOperation::adbFindRunAsFinished(int exitCode,
QProcess::ExitStatus exitStatus)
void AndroidSignalOperation::adbFindRunAsFinished()
{
QTC_ASSERT(m_state == RunAs, return);
m_timeout->stop();
m_adbProcess->disconnect(this);
QString runAs = QString::fromLatin1(m_adbProcess->readAllStandardOutput());
if (exitStatus != QProcess::NormalExit) {
m_errorMessage = QLatin1String(" adb Exit code: ") + QString::number(exitCode);
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;
@@ -63,25 +63,24 @@ void Android::Internal::AndroidSignalOperation::adbFindRunAsFinished(int exitCod
m_state = Idle;
emit finished(m_errorMessage);
} else {
connect(m_adbProcess, QOverload<int, QProcess::ExitStatus>::of(&QProcess::finished),
connect(m_adbProcess, &QtcProcess::finished,
this, &AndroidSignalOperation::adbKillFinished);
m_state = Kill;
m_timeout->start();
m_adbProcess->start(m_adbPath, QStringList({"shell", "run-as", runAs, "kill",
QString("-%1").arg(m_signal),
QString::number(m_pid)}));
m_adbProcess->setCommand({m_adbPath, {"shell", "run-as", runAs,
"kill", QString("-%1").arg(m_signal), QString::number(m_pid)}});
m_adbProcess->start();
}
}
void Android::Internal::AndroidSignalOperation::adbKillFinished(int exitCode,
QProcess::ExitStatus exitStatus)
void AndroidSignalOperation::adbKillFinished()
{
QTC_ASSERT(m_state == Kill, return);
m_timeout->stop();
m_adbProcess->disconnect(this);
if (exitStatus != QProcess::NormalExit) {
m_errorMessage = QLatin1String(" adb process exit code: ") + QString::number(exitCode);
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;
@@ -96,7 +95,7 @@ void Android::Internal::AndroidSignalOperation::adbKillFinished(int exitCode,
emit finished(m_errorMessage);
}
void Android::Internal::AndroidSignalOperation::handleTimeout()
void AndroidSignalOperation::handleTimeout()
{
m_adbProcess->disconnect(this);
m_adbProcess->kill();
@@ -106,26 +105,26 @@ void Android::Internal::AndroidSignalOperation::handleTimeout()
emit finished(m_errorMessage);
}
void Android::Internal::AndroidSignalOperation::signalOperationViaADB(qint64 pid, int signal)
void AndroidSignalOperation::signalOperationViaADB(qint64 pid, int signal)
{
QTC_ASSERT(m_state == Idle, return);
m_adbProcess->disconnect(this);
m_pid = pid;
m_signal = signal;
connect(m_adbProcess, QOverload<int, QProcess::ExitStatus>::of(&QProcess::finished),
connect(m_adbProcess, &QtcProcess::finished,
this, &AndroidSignalOperation::adbFindRunAsFinished);
m_state = RunAs;
m_timeout->start();
m_adbProcess->start(m_adbPath, QStringList({ "shell", "cat",
QString("/proc/%1/cmdline").arg(m_pid) }));
m_adbProcess->setCommand({m_adbPath, {"shell", "cat", QString("/proc/%1/cmdline").arg(m_pid)}});
m_adbProcess->start();
}
void Android::Internal::AndroidSignalOperation::killProcess(qint64 pid)
void AndroidSignalOperation::killProcess(qint64 pid)
{
signalOperationViaADB(pid, 9);
}
void Android::Internal::AndroidSignalOperation::killProcess(const QString &filePath)
void AndroidSignalOperation::killProcess(const QString &filePath)
{
Q_UNUSED(filePath)
m_errorMessage = QLatin1String("The android signal operation does "
@@ -133,15 +132,18 @@ void Android::Internal::AndroidSignalOperation::killProcess(const QString &fileP
emit finished(m_errorMessage);
}
void Android::Internal::AndroidSignalOperation::interruptProcess(qint64 pid)
void AndroidSignalOperation::interruptProcess(qint64 pid)
{
signalOperationViaADB(pid, 2);
}
void Android::Internal::AndroidSignalOperation::interruptProcess(const QString &filePath)
void AndroidSignalOperation::interruptProcess(const QString &filePath)
{
Q_UNUSED(filePath)
m_errorMessage = QLatin1String("The android signal operation does "
"not support interrupting by filepath.");
emit finished(m_errorMessage);
}
} // Internal
} // Android

View File

@@ -28,7 +28,6 @@
#include <projectexplorer/devicesupport/idevice.h>
#include <QObject>
#include <QProcess>
#include <QTimer>
namespace Android {
@@ -48,24 +47,24 @@ protected:
explicit AndroidSignalOperation();
private:
void adbFindRunAsFinished(int exitCode, QProcess::ExitStatus exitStatus);
void adbKillFinished(int exitCode, QProcess::ExitStatus exitStatus);
void adbFindRunAsFinished();
void adbKillFinished();
void handleTimeout();
void signalOperationViaADB(qint64 pid, int signal);
QString m_adbPath;
QProcess *m_adbProcess;
Utils::FilePath m_adbPath;
Utils::QtcProcess *m_adbProcess;
QTimer *m_timeout;
enum State {
Idle,
RunAs,
Kill
} m_state;
} m_state = Idle;
qint64 m_pid;
int m_signal;
qint64 m_pid = 0;
int m_signal = 0;
friend class AndroidDevice;
};