Qnx: Fixing "Show Running Processes" for BlackBerry devices

BlackBerryDeviceConfiguration is using the same QnxDeviceProcessList
as QnxDeviceConfiguration.

Task-number: QTCREATORBUG-9976
Change-Id: Ic07297619d4d5d4280918df4e1ea21b958fd1050
Reviewed-by: Fanda Vacek <fvacek@blackberry.com>
Reviewed-by: Nicolas Arnaud-Cormos <nicolas@kdab.com>
Reviewed-by: David Kaspar <dkaspar@blackberry.com>
This commit is contained in:
David Kaspar
2013-09-27 16:55:38 +02:00
parent 0643b832a5
commit 1d166f8ff9
7 changed files with 151 additions and 48 deletions

View File

@@ -35,6 +35,7 @@
#include "qnxdeviceprocesssignaloperation.h" #include "qnxdeviceprocesssignaloperation.h"
#include "blackberrydeviceconfigurationwidget.h" #include "blackberrydeviceconfigurationwidget.h"
#include "blackberrydeviceconnectionmanager.h" #include "blackberrydeviceconnectionmanager.h"
#include "qnxdeviceprocesslist.h"
#include <projectexplorer/kitinformation.h> #include <projectexplorer/kitinformation.h>
#include <ssh/sshconnection.h> #include <ssh/sshconnection.h>
@@ -162,6 +163,11 @@ QVariantMap BlackBerryDeviceConfiguration::toMap() const
return map; return map;
} }
DeviceProcessList *BlackBerryDeviceConfiguration::createProcessListModel(QObject *parent) const
{
return new QnxDeviceProcessList(sharedFromThis(), parent);
}
DeviceProcessSignalOperation::Ptr BlackBerryDeviceConfiguration::signalOperation() const DeviceProcessSignalOperation::Ptr BlackBerryDeviceConfiguration::signalOperation() const
{ {
return DeviceProcessSignalOperation::Ptr( return DeviceProcessSignalOperation::Ptr(

View File

@@ -64,6 +64,7 @@ public:
QString displayNameForActionId(Core::Id actionId) const; QString displayNameForActionId(Core::Id actionId) const;
void executeAction(Core::Id actionId, QWidget *parent); void executeAction(Core::Id actionId, QWidget *parent);
ProjectExplorer::IDevice::Ptr clone() const; ProjectExplorer::IDevice::Ptr clone() const;
ProjectExplorer::DeviceProcessList *createProcessListModel(QObject *parent) const;
bool hasDeviceTester() const; bool hasDeviceTester() const;
ProjectExplorer::DeviceProcessSignalOperation::Ptr signalOperation() const; ProjectExplorer::DeviceProcessSignalOperation::Ptr signalOperation() const;

View File

@@ -96,7 +96,8 @@ SOURCES += qnxplugin.cpp \
blackberryconfigurationmanager.cpp \ blackberryconfigurationmanager.cpp \
blackberrydevicelistdetector.cpp \ blackberrydevicelistdetector.cpp \
blackberrylogprocessrunner.cpp \ blackberrylogprocessrunner.cpp \
qnxdeviceprocesssignaloperation.cpp qnxdeviceprocesssignaloperation.cpp \
qnxdeviceprocesslist.cpp
HEADERS += qnxplugin.h\ HEADERS += qnxplugin.h\
qnxconstants.h \ qnxconstants.h \
@@ -192,7 +193,8 @@ HEADERS += qnxplugin.h\
blackberryconfigurationmanager.h \ blackberryconfigurationmanager.h \
blackberrydevicelistdetector.h \ blackberrydevicelistdetector.h \
blackberrylogprocessrunner.h \ blackberrylogprocessrunner.h \
qnxdeviceprocesssignaloperation.h qnxdeviceprocesssignaloperation.h \
qnxdeviceprocesslist.h
FORMS += \ FORMS += \
blackberrydeviceconfigurationwizardsetuppage.ui \ blackberrydeviceconfigurationwizardsetuppage.ui \

View File

@@ -213,6 +213,8 @@ QtcPlugin {
"qnxdeviceconfigurationwizard.h", "qnxdeviceconfigurationwizard.h",
"qnxdeviceconfigurationwizardpages.cpp", "qnxdeviceconfigurationwizardpages.cpp",
"qnxdeviceconfigurationwizardpages.h", "qnxdeviceconfigurationwizardpages.h",
"qnxdeviceprocesslist.cpp",
"qnxdeviceprocesslist.h",
"qnxdeviceprocesssignaloperation.cpp", "qnxdeviceprocesssignaloperation.cpp",
"qnxdeviceprocesssignaloperation.h", "qnxdeviceprocesssignaloperation.h",
"qnxdevicetester.cpp", "qnxdevicetester.cpp",

View File

@@ -31,9 +31,9 @@
#include "qnxdeviceconfiguration.h" #include "qnxdeviceconfiguration.h"
#include "qnxdevicetester.h" #include "qnxdevicetester.h"
#include "qnxdeviceprocesslist.h"
#include "qnxdeviceprocesssignaloperation.h" #include "qnxdeviceprocesssignaloperation.h"
#include <projectexplorer/devicesupport/sshdeviceprocesslist.h>
#include <ssh/sshconnection.h> #include <ssh/sshconnection.h>
#include <QRegExp> #include <QRegExp>
@@ -80,51 +80,6 @@ class QnxPortsGatheringMethod : public ProjectExplorer::PortsGatheringMethod
} }
}; };
class QnxDeviceProcessList : public ProjectExplorer::SshDeviceProcessList
{
public:
QnxDeviceProcessList(const ProjectExplorer::IDevice::ConstPtr &device, QObject *parent)
: SshDeviceProcessList(device, parent)
{
}
private:
QString listProcessesCommandLine() const
{
return QLatin1String("pidin -F \"%a %A '/%n'\"");
}
QList<ProjectExplorer::DeviceProcessItem> buildProcessList(const QString &listProcessesReply) const
{
QList<ProjectExplorer::DeviceProcessItem> processes;
QStringList lines = listProcessesReply.split(QLatin1Char('\n'));
if (lines.isEmpty())
return processes;
lines.pop_front(); // drop headers
QRegExp re(QLatin1String("\\s*(\\d+)\\s+(.*)'(.*)'"));
foreach (const QString& line, lines) {
if (re.exactMatch(line)) {
const QStringList captures = re.capturedTexts();
if (captures.size() == 4) {
const int pid = captures[1].toInt();
const QString args = captures[2];
const QString exe = captures[3];
ProjectExplorer::DeviceProcessItem deviceProcess;
deviceProcess.pid = pid;
deviceProcess.exe = exe.trimmed();
deviceProcess.cmdLine = args.trimmed();
processes.append(deviceProcess);
}
}
}
qSort(processes);
return processes;
}
};
QnxDeviceConfiguration::QnxDeviceConfiguration() QnxDeviceConfiguration::QnxDeviceConfiguration()
: RemoteLinux::LinuxDevice() : RemoteLinux::LinuxDevice()
{ {

View File

@@ -0,0 +1,80 @@
/**************************************************************************
**
** Copyright (C) 2013 BlackBerry Limited. All rights reserved.
**
** Contact: BlackBerry Limited (blackberry-qt@qnx.com)
** Contact: KDAB (info@kdab.com)
**
** This file is part of Qt Creator.
**
** Commercial License Usage
** Licensees holding valid commercial Qt licenses may use this file in
** accordance with the commercial license agreement provided with the
** Software or, alternatively, in accordance with the terms contained in
** a written agreement between you and Digia. For licensing terms and
** conditions see http://qt.digia.com/licensing. For further information
** use the contact form at http://qt.digia.com/contact-us.
**
** GNU Lesser General Public License Usage
** Alternatively, this file may be used under the terms of the GNU Lesser
** General Public License version 2.1 as published by the Free Software
** Foundation and appearing in the file LICENSE.LGPL included in the
** packaging of this file. Please review the following information to
** ensure the GNU Lesser General Public License version 2.1 requirements
** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
**
** In addition, as a special exception, Digia gives you certain additional
** rights. These rights are described in the Digia Qt LGPL Exception
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
**
****************************************************************************/
#include "qnxdeviceprocesslist.h"
#include <QRegExp>
#include <QStringList>
using namespace Qnx;
using namespace Qnx::Internal;
QnxDeviceProcessList::QnxDeviceProcessList(
const ProjectExplorer::IDevice::ConstPtr &device, QObject *parent)
: ProjectExplorer::SshDeviceProcessList(device, parent)
{
}
QString QnxDeviceProcessList::listProcessesCommandLine() const
{
return QLatin1String("pidin -F \"%a %A '/%n'\"");
}
QList<ProjectExplorer::DeviceProcessItem> QnxDeviceProcessList::buildProcessList(
const QString &listProcessesReply) const
{
QList<ProjectExplorer::DeviceProcessItem> processes;
QStringList lines = listProcessesReply.split(QLatin1Char('\n'));
if (lines.isEmpty())
return processes;
lines.pop_front(); // drop headers
QRegExp re(QLatin1String("\\s*(\\d+)\\s+(.*)'(.*)'"));
foreach (const QString& line, lines) {
if (re.exactMatch(line)) {
const QStringList captures = re.capturedTexts();
if (captures.size() == 4) {
const int pid = captures[1].toInt();
const QString args = captures[2];
const QString exe = captures[3];
ProjectExplorer::DeviceProcessItem deviceProcess;
deviceProcess.pid = pid;
deviceProcess.exe = exe.trimmed();
deviceProcess.cmdLine = args.trimmed();
processes.append(deviceProcess);
}
}
}
qSort(processes);
return processes;
}

View File

@@ -0,0 +1,57 @@
/**************************************************************************
**
** Copyright (C) 2013 BlackBerry Limited. All rights reserved.
**
** Contact: BlackBerry Limited (blackberry-qt@qnx.com)
** Contact: KDAB (info@kdab.com)
**
** This file is part of Qt Creator.
**
** Commercial License Usage
** Licensees holding valid commercial Qt licenses may use this file in
** accordance with the commercial license agreement provided with the
** Software or, alternatively, in accordance with the terms contained in
** a written agreement between you and Digia. For licensing terms and
** conditions see http://qt.digia.com/licensing. For further information
** use the contact form at http://qt.digia.com/contact-us.
**
** GNU Lesser General Public License Usage
** Alternatively, this file may be used under the terms of the GNU Lesser
** General Public License version 2.1 as published by the Free Software
** Foundation and appearing in the file LICENSE.LGPL included in the
** packaging of this file. Please review the following information to
** ensure the GNU Lesser General Public License version 2.1 requirements
** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
**
** In addition, as a special exception, Digia gives you certain additional
** rights. These rights are described in the Digia Qt LGPL Exception
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
**
****************************************************************************/
#ifndef QNX_INTERNAL_QNXDEVICEPROCESSLIST_H
#define QNX_INTERNAL_QNXDEVICEPROCESSLIST_H
#include <projectexplorer/devicesupport/idevice.h>
#include <projectexplorer/devicesupport/sshdeviceprocesslist.h>
namespace Qnx {
namespace Internal {
class QnxDeviceProcessList : public ProjectExplorer::SshDeviceProcessList
{
Q_OBJECT
public:
explicit QnxDeviceProcessList(
const ProjectExplorer::IDevice::ConstPtr &device, QObject *parent = 0);
private:
virtual QString listProcessesCommandLine() const;
virtual QList<ProjectExplorer::DeviceProcessItem> buildProcessList(
const QString &listProcessesReply) const;
};
} // namespace Internal
} // namespace Qnx
#endif // QNX_INTERNAL_QNXDEVICEPROCESSLIST_H