forked from qt-creator/qt-creator
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:
@@ -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
|
||||||
|
@@ -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;
|
||||||
};
|
};
|
||||||
|
Reference in New Issue
Block a user