mirror of
https://bitbucket.org/smil3y/kde-workspace.git
synced 2025-02-24 19:02:51 +00:00
186 lines
7.3 KiB
C++
186 lines
7.3 KiB
C++
/*
|
|
KSysGuard, the KDE System Guard
|
|
|
|
Copyright (c) 1999 - 2001 Chris Schlaeger <cs@kde.org>
|
|
Copyright (c) 2006 John Tapsell <john.tapsell@kde.org>
|
|
|
|
This program is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU General Public License as
|
|
published by the Free Software Foundation; version 2 of
|
|
the License, or (at your option) version 3.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
#include <QtXml/qdom.h>
|
|
#include <QTimer>
|
|
#include <QLineEdit>
|
|
#include <QTreeView>
|
|
#include <QCheckBox>
|
|
#include <QHeaderView>
|
|
#include <QStackedLayout>
|
|
|
|
#include <kdebug.h>
|
|
|
|
#include "moc_ProcessController.cpp"
|
|
#include "ProcessController.h"
|
|
#include "processui/ksysguardprocesslist.h"
|
|
#include "processes.h"
|
|
|
|
//#define DO_MODELCHECK
|
|
#ifdef DO_MODELCHECK
|
|
#include "modeltest.h"
|
|
#endif
|
|
ProcessController::ProcessController(QWidget* parent, SharedSettings *workSheetSettings)
|
|
: KSGRD::SensorDisplay(parent, QString(), workSheetSettings)
|
|
{
|
|
mProcessList = NULL;
|
|
mProcesses = NULL;
|
|
}
|
|
|
|
void
|
|
ProcessController::sensorError(int, bool err)
|
|
{
|
|
if (err == sensors().at(0)->isOk())
|
|
{
|
|
if (err) {
|
|
kDebug(1215) << "SensorError called with an error";
|
|
}
|
|
/* This happens only when the sensorOk status needs to be changed. */
|
|
sensors().at(0)->setIsOk( !err );
|
|
}
|
|
setSensorOk(sensors().at(0)->isOk());
|
|
}
|
|
|
|
bool
|
|
ProcessController::restoreSettings(QDomElement& element)
|
|
{
|
|
bool result = addSensor(element.attribute("hostName"),
|
|
element.attribute("sensorName"),
|
|
(element.attribute("sensorType").isEmpty() ? "table" : element.attribute("sensorType")),
|
|
QString());
|
|
if(!result) return false;
|
|
|
|
int version = element.attribute("version", "0").toUInt();
|
|
if(version == PROCESSHEADERVERSION) { //If the header has changed, the old settings are no longer valid. Only restore if version is the same
|
|
mProcessList->restoreHeaderState(QByteArray::fromBase64(element.attribute("treeViewHeader").toLatin1()));
|
|
}
|
|
|
|
bool showTotals = element.attribute("showTotals", "1").toUInt();
|
|
mProcessList->setShowTotals(showTotals);
|
|
|
|
|
|
int units = element.attribute("units", QString::number((int)ProcessModel::UnitsKB)).toUInt();
|
|
mProcessList->setUnits((ProcessModel::Units)units);
|
|
|
|
int ioUnits = element.attribute("ioUnits", QString::number((int)ProcessModel::UnitsKB)).toUInt();
|
|
mProcessList->processModel()->setIoUnits((ProcessModel::Units)ioUnits);
|
|
|
|
int ioInformation = element.attribute("ioInformation", QString::number((int)ProcessModel::ActualBytesRate)).toUInt();
|
|
mProcessList->processModel()->setIoInformation((ProcessModel::IoInformation)ioInformation);
|
|
|
|
bool showCommandLineOptions = element.attribute("showCommandLineOptions", "0").toUInt();
|
|
mProcessList->processModel()->setShowCommandLineOptions(showCommandLineOptions);
|
|
|
|
bool showTooltips = element.attribute("showTooltips", "1").toUInt();
|
|
mProcessList->processModel()->setShowingTooltips(showTooltips);
|
|
|
|
bool normalizeCPUUsage = element.attribute("normalizeCPUUsage", "1").toUInt();
|
|
mProcessList->processModel()->setNormalizedCPUUsage(normalizeCPUUsage);
|
|
|
|
int filterState = element.attribute("filterState", QString::number((int)ProcessFilter::AllProcesses)).toUInt();
|
|
mProcessList->setState((ProcessFilter::State)filterState);
|
|
|
|
SensorDisplay::restoreSettings(element);
|
|
return result;
|
|
}
|
|
|
|
bool ProcessController::saveSettings(QDomDocument& doc, QDomElement& element)
|
|
{
|
|
if(!mProcessList)
|
|
return false;
|
|
element.setAttribute("hostName", sensors().at(0)->hostName());
|
|
element.setAttribute("sensorName", sensors().at(0)->name());
|
|
element.setAttribute("sensorType", sensors().at(0)->type());
|
|
|
|
element.setAttribute("version", QString::number(PROCESSHEADERVERSION));
|
|
element.setAttribute("treeViewHeader", QString::fromLatin1(mProcessList->treeView()->header()->saveState().toBase64()));
|
|
element.setAttribute("showTotals", mProcessList->showTotals()?1:0);
|
|
|
|
element.setAttribute("units", (int)(mProcessList->units()));
|
|
element.setAttribute("ioUnits", (int)(mProcessList->processModel()->ioUnits()));
|
|
element.setAttribute("ioInformation", (int)(mProcessList->processModel()->ioInformation()));
|
|
element.setAttribute("showCommandLineOptions", mProcessList->processModel()->isShowCommandLineOptions());
|
|
element.setAttribute("showTooltips", mProcessList->processModel()->isShowingTooltips());
|
|
element.setAttribute("normalizeCPUUsage", mProcessList->processModel()->isNormalizedCPUUsage());
|
|
element.setAttribute("filterState", (int)(mProcessList->state()));
|
|
|
|
SensorDisplay::saveSettings(doc, element);
|
|
|
|
return true;
|
|
}
|
|
|
|
void ProcessController::timerTick() {
|
|
mProcessList->updateList();
|
|
|
|
}
|
|
void ProcessController::answerReceived( int id, const QList<QByteArray>& answer ) {
|
|
if(mProcesses)
|
|
mProcesses->answerReceived(id, answer);
|
|
}
|
|
|
|
bool ProcessController::addSensor(const QString& hostName,
|
|
const QString& sensorName,
|
|
const QString& sensorType,
|
|
const QString& title)
|
|
{
|
|
if (sensorType != "table")
|
|
return false;
|
|
|
|
|
|
QStackedLayout *layout = new QStackedLayout(this);
|
|
mProcessList = new KSysGuardProcessList(this, hostName);
|
|
mProcessList->setUpdateIntervalMSecs(0); //we will call updateList() manually
|
|
mProcessList->setContentsMargins(0,0,0,0);
|
|
addActions(mProcessList->actions());
|
|
connect(mProcessList, SIGNAL(updated()), this, SIGNAL(updated()));
|
|
connect(mProcessList, SIGNAL(processListChanged()), this, SIGNAL(processListChanged()));
|
|
mProcessList->setContextMenuPolicy( Qt::CustomContextMenu );
|
|
connect(mProcessList, SIGNAL(customContextMenuRequested(QPoint)), SLOT(showContextMenu(QPoint)));
|
|
|
|
layout->addWidget(mProcessList);
|
|
|
|
/** To use a remote sensor, we need to drill down through the layers, to connect to the remote processes. Then connect to its signals and slots.
|
|
* It's horrible I know :( */
|
|
if(!hostName.isEmpty() && hostName != "localhost") {
|
|
KSysGuard::Processes *processes = mProcessList->processModel()->processController();
|
|
mProcesses = processes;
|
|
if(processes) {
|
|
connect( processes, SIGNAL(runCommand(QString,int)), SLOT(runCommand(QString,int)));
|
|
}
|
|
|
|
}
|
|
|
|
setPlotterWidget(mProcessList);
|
|
|
|
QTimer::singleShot(0, mProcessList->filterLineEdit(), SLOT(setFocus()));
|
|
|
|
registerSensor(new KSGRD::SensorProperties(hostName, sensorName, sensorType, title));
|
|
/* This just triggers the first communication. The full set of
|
|
* requests are send whenever the sensor reconnects (detected in
|
|
* sensorError(). */
|
|
sensors().at(0)->setIsOk(true); //Assume it is okay from the start
|
|
setSensorOk(sensors().at(0)->isOk());
|
|
emit processListChanged();
|
|
return true;
|
|
}
|
|
|
|
void ProcessController::runCommand(const QString &command, int id) {
|
|
sendRequest(sensors().at(0)->hostName(), command, id);
|
|
}
|
|
|