aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChristian Kandeler <christian.kandeler@qt.io>2018-12-14 10:12:59 +0100
committerChristian Kandeler <christian.kandeler@qt.io>2018-12-14 11:26:30 +0000
commita5cf6f194d79f67a99263cf7d6f07d41b79d5239 (patch)
tree33cdd354840bb3cd5db804b7f9fdf0b8be277878
parent2710a9b0e57d7055cd1fcb81dd20ad51e1557fce (diff)
SSH: Fix exit status/exit code interpretation
A "regular" exit of the ssh binary with exit code 255 means that the remote process has crashed. Change-Id: I82e6e44079041459e78e4f8f7e7b6e5cbcaa6c44 Reviewed-by: Ulf Hermann <ulf.hermann@qt.io>
-rw-r--r--src/libs/ssh/sshremoteprocess.cpp7
-rw-r--r--src/plugins/projectexplorer/devicesupport/sshdeviceprocess.cpp6
-rw-r--r--src/plugins/projectexplorer/devicesupport/sshdeviceprocess.h2
3 files changed, 10 insertions, 5 deletions
diff --git a/src/libs/ssh/sshremoteprocess.cpp b/src/libs/ssh/sshremoteprocess.cpp
index 22e2813150..ca38f48b39 100644
--- a/src/libs/ssh/sshremoteprocess.cpp
+++ b/src/libs/ssh/sshremoteprocess.cpp
@@ -68,7 +68,12 @@ SshRemoteProcess::SshRemoteProcess(const QByteArray &command, const QStringList
connect(this,
static_cast<void (QProcess::*)(int, QProcess::ExitStatus)>(&QProcess::finished),
[this] {
- emit done(exitStatus() == QProcess::NormalExit ? QString() : errorString());
+ QString error;
+ if (exitStatus() == QProcess::CrashExit)
+ error = tr("The ssh binary crashed: %1").arg(errorString());
+ else if (exitCode() == 255)
+ error = tr("Remote process crashed.");
+ emit done(error);
});
connect(this, &QProcess::errorOccurred, [this](QProcess::ProcessError error) {
if (error == QProcess::FailedToStart)
diff --git a/src/plugins/projectexplorer/devicesupport/sshdeviceprocess.cpp b/src/plugins/projectexplorer/devicesupport/sshdeviceprocess.cpp
index e3cc959a5d..4f447214f5 100644
--- a/src/plugins/projectexplorer/devicesupport/sshdeviceprocess.cpp
+++ b/src/plugins/projectexplorer/devicesupport/sshdeviceprocess.cpp
@@ -139,7 +139,7 @@ QProcess::ProcessState SshDeviceProcess::state() const
QProcess::ExitStatus SshDeviceProcess::exitStatus() const
{
- return d->exitStatus == QSsh::SshRemoteProcess::NormalExit
+ return d->exitStatus == QSsh::SshRemoteProcess::NormalExit && d->exitCode != 255
? QProcess::NormalExit : QProcess::CrashExit;
}
@@ -223,9 +223,9 @@ void SshDeviceProcess::handleProcessStarted()
emit started();
}
-void SshDeviceProcess::handleProcessFinished()
+void SshDeviceProcess::handleProcessFinished(const QString &error)
{
- d->errorMessage = d->process->errorString();
+ d->errorMessage = error;
d->exitCode = d->process->exitCode();
d->setState(SshDeviceProcessPrivate::Inactive);
emit finished();
diff --git a/src/plugins/projectexplorer/devicesupport/sshdeviceprocess.h b/src/plugins/projectexplorer/devicesupport/sshdeviceprocess.h
index 7bbe942354..8c1da7cf55 100644
--- a/src/plugins/projectexplorer/devicesupport/sshdeviceprocess.h
+++ b/src/plugins/projectexplorer/devicesupport/sshdeviceprocess.h
@@ -60,7 +60,7 @@ private:
void handleConnectionError();
void handleDisconnected();
void handleProcessStarted();
- void handleProcessFinished();
+ void handleProcessFinished(const QString &error);
void handleStdout();
void handleStderr();
void handleKillOperationFinished(const QString &errorMessage);