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

View File

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