forked from pool/libksysguard5
Accepting request 641913 from home:Vogtinator:kf5ls
- Add patch to use WebEngine instead of WebKit: * 0001-Port-scripting-to-Qt-WebEngine.patch - Use gcc7 on Leap 42.3 OBS-URL: https://build.opensuse.org/request/show/641913 OBS-URL: https://build.opensuse.org/package/show/KDE:Frameworks5/libksysguard5?expand=0&rev=186
This commit is contained in:
parent
7484d9643e
commit
f674f18d9e
509
0001-Port-scripting-to-Qt-WebEngine.patch
Normal file
509
0001-Port-scripting-to-Qt-WebEngine.patch
Normal file
@ -0,0 +1,509 @@
|
||||
From c9747e37c53101c8228f9571c9367ce4193d3b51 Mon Sep 17 00:00:00 2001
|
||||
From: Fabian Vogt <fabian@ritter-vogt.de>
|
||||
Date: Sat, 1 Sep 2018 18:41:59 +0200
|
||||
Subject: [PATCH] Port scripting to Qt WebEngine
|
||||
|
||||
Summary:
|
||||
Unfortunately it relies on Qt WebKit features quite intensely, so a few
|
||||
godawful hacks were necessary to make it work. Most of those are needed
|
||||
to workaround restrictions of QWebChannel as bridge to the browser page.
|
||||
|
||||
We gain:
|
||||
+ Independence from WebKit
|
||||
+ Support for newer JS and HTML features in scripts
|
||||
|
||||
We lose:
|
||||
- Performance (especially memory use)
|
||||
- Independence from WebEngine
|
||||
- Sanity
|
||||
|
||||
Test Plan:
|
||||
Tested the detailed memory info pages on a few processes, info is
|
||||
correct and the page seems to work fully.
|
||||
|
||||
Reviewers: #plasma, davidedmundson
|
||||
|
||||
Reviewed By: #plasma, davidedmundson
|
||||
|
||||
Subscribers: davidedmundson, plasma-devel
|
||||
|
||||
Tags: #plasma
|
||||
|
||||
Differential Revision: https://phabricator.kde.org/D15209
|
||||
---
|
||||
CMakeLists.txt | 10 +--
|
||||
config-ksysguard.h.cmake | 4 +-
|
||||
processui/CMakeLists.txt | 4 +-
|
||||
processui/scripting.cpp | 180 +++++++++++++++++++++++++++++----------
|
||||
processui/scripting.h | 109 +++++++++++++-----------
|
||||
5 files changed, 203 insertions(+), 104 deletions(-)
|
||||
|
||||
diff --git a/CMakeLists.txt b/CMakeLists.txt
|
||||
index 8211298..8b59bdb 100644
|
||||
--- a/CMakeLists.txt
|
||||
+++ b/CMakeLists.txt
|
||||
@@ -26,10 +26,10 @@ include(CheckLibraryExists)
|
||||
include(FeatureSummary)
|
||||
|
||||
find_package(Qt5 ${QT_MIN_VERSION} REQUIRED CONFIG COMPONENTS DBus Network Widgets)
|
||||
-find_package(Qt5WebKitWidgets ${QT_MIN_VERSION} CONFIG)
|
||||
-set_package_properties(Qt5WebKitWidgets PROPERTIES
|
||||
- URL "git://gitorious.org/qt/qtwebkit.git"
|
||||
- DESCRIPTION "Qt Webkit module (web browsing engine)"
|
||||
+find_package(Qt5WebEngineWidgets ${QT_MIN_VERSION} CONFIG)
|
||||
+set_package_properties(Qt5WebEngineWidgets PROPERTIES
|
||||
+ URL "git://code.qt.org/qt/qtwebenginewidgets.git"
|
||||
+ DESCRIPTION "Qt WebEngine module (web browsing engine)"
|
||||
TYPE OPTIONAL
|
||||
PURPOSE "Used by the HTML-based GUI ksysguard library"
|
||||
)
|
||||
@@ -76,7 +76,7 @@ endif()
|
||||
|
||||
set(HAVE_X11 ${X11_FOUND})
|
||||
set(HAVE_XRES ${X11_XRes_FOUND})
|
||||
-set(HAVE_QTWEBKITWIDGETS ${Qt5WebKitWidgets_FOUND})
|
||||
+set(HAVE_QTWEBENGINEWIDGETS ${Qt5WebEngineWidgets_FOUND})
|
||||
configure_file(config-ksysguard.h.cmake ${CMAKE_CURRENT_BINARY_DIR}/config-ksysguard.h )
|
||||
|
||||
add_definitions(-DQT_NO_URL_CAST_FROM_STRING)
|
||||
diff --git a/config-ksysguard.h.cmake b/config-ksysguard.h.cmake
|
||||
index e5b8609..ad648f1 100644
|
||||
--- a/config-ksysguard.h.cmake
|
||||
+++ b/config-ksysguard.h.cmake
|
||||
@@ -10,8 +10,8 @@
|
||||
/* Define to 1 if you have the X11 xres file */
|
||||
#cmakedefine HAVE_XRES 1
|
||||
|
||||
-/* Define if you have QtWebKitWidgets */
|
||||
-#cmakedefine01 HAVE_QTWEBKITWIDGETS
|
||||
+/* Define if you have QtWebEngineWidgets */
|
||||
+#cmakedefine01 HAVE_QTWEBENGINEWIDGETS
|
||||
|
||||
/* Define if you have X11 at all */
|
||||
#cmakedefine01 HAVE_X11
|
||||
diff --git a/processui/CMakeLists.txt b/processui/CMakeLists.txt
|
||||
index b1dbebe..72ad79d 100644
|
||||
--- a/processui/CMakeLists.txt
|
||||
+++ b/processui/CMakeLists.txt
|
||||
@@ -58,8 +58,8 @@ if(X11_FOUND)
|
||||
target_link_libraries(processui PRIVATE Qt5::X11Extras KF5::WindowSystem)
|
||||
endif()
|
||||
|
||||
-if(Qt5WebKitWidgets_FOUND)
|
||||
- target_link_libraries(processui PRIVATE Qt5::WebKitWidgets)
|
||||
+if(Qt5WebEngineWidgets_FOUND)
|
||||
+ target_link_libraries(processui PRIVATE Qt5::WebEngineWidgets)
|
||||
endif()
|
||||
|
||||
if(NOT HAVE_CLOCK_GETTIME_C)
|
||||
diff --git a/processui/scripting.cpp b/processui/scripting.cpp
|
||||
index fd2200b..e0b4ed0 100644
|
||||
--- a/processui/scripting.cpp
|
||||
+++ b/processui/scripting.cpp
|
||||
@@ -1,7 +1,8 @@
|
||||
/*
|
||||
KSysGuard, the KDE System Guard
|
||||
|
||||
- Copyright (c) 2009 John Tapsell <john.tapsell@kde.org>
|
||||
+ Copyright (c) 2009 John Tapsell <john.tapsell@kde.org>
|
||||
+ Copyright (c) 2018 Fabian Vogt <fabian@ritter-vogt.de>
|
||||
|
||||
This library is free software; you can redistribute it and/or
|
||||
modify it under the terms of the GNU Library General Public
|
||||
@@ -42,11 +43,32 @@
|
||||
#include <QMessageBox>
|
||||
#include <QDialogButtonBox>
|
||||
|
||||
-#if HAVE_QTWEBKITWIDGETS
|
||||
-#include <QWebView>
|
||||
-#include <QWebFrame>
|
||||
+#if HAVE_QTWEBENGINEWIDGETS
|
||||
+#include <QWebChannel>
|
||||
+#include <QWebEngineSettings>
|
||||
+#include <QWebEngineView>
|
||||
+#include <QWebEngineProfile>
|
||||
+#include <QWebEngineScriptCollection>
|
||||
+#include <QWebEngineUrlRequestInterceptor>
|
||||
#endif
|
||||
|
||||
+class RemoteUrlInterceptor : public QWebEngineUrlRequestInterceptor {
|
||||
+public:
|
||||
+ RemoteUrlInterceptor(QObject *parent) : QWebEngineUrlRequestInterceptor(parent) {}
|
||||
+ void interceptRequest(QWebEngineUrlRequestInfo &info) override
|
||||
+ {
|
||||
+ // Block non-GET/HEAD requests
|
||||
+ if(!QStringList({QStringLiteral("GET"), QStringLiteral("HEAD")})
|
||||
+ .contains(QString::fromLatin1(info.requestMethod())))
|
||||
+ info.block(true);
|
||||
+
|
||||
+ // Block remote URLs
|
||||
+ if(!QStringList({QStringLiteral("blob"), QStringLiteral("data"),
|
||||
+ QStringLiteral("file")}).contains(info.requestUrl().scheme()))
|
||||
+ info.block(true);
|
||||
+ }
|
||||
+};
|
||||
+
|
||||
class ScriptingHtmlDialog : public QDialog {
|
||||
public:
|
||||
ScriptingHtmlDialog(QWidget *parent) : QDialog(parent) {
|
||||
@@ -56,44 +78,22 @@ class ScriptingHtmlDialog : public QDialog {
|
||||
connect(buttonBox, &QDialogButtonBox::accepted, this, &QDialog::accept);
|
||||
connect(buttonBox, &QDialogButtonBox::rejected, this, &QDialog::reject);
|
||||
|
||||
-#if HAVE_QTWEBKITWIDGETS
|
||||
+#if HAVE_QTWEBENGINEWIDGETS
|
||||
QVBoxLayout *layout = new QVBoxLayout;
|
||||
layout->addWidget(&m_webView);
|
||||
layout->addWidget(buttonBox);
|
||||
setLayout(layout);
|
||||
- (void)minimumSizeHint(); //Force the dialog to be laid out now
|
||||
layout->setContentsMargins(0,0,0,0);
|
||||
- m_webView.settings()->setOfflineStoragePath(QString());
|
||||
- m_webView.settings()->setObjectCacheCapacities(0,0,0);
|
||||
- m_webView.settings()->setAttribute(QWebSettings::PluginsEnabled, false);
|
||||
- m_webView.settings()->setAttribute(QWebSettings::DeveloperExtrasEnabled, false);
|
||||
- m_webView.page()->setNetworkAccessManager(nullptr); //Disable talking to remote servers
|
||||
- m_webView.page()->mainFrame()->setScrollBarPolicy(Qt::Horizontal, Qt::ScrollBarAsNeeded);
|
||||
- m_webView.page()->mainFrame()->setScrollBarPolicy(Qt::Vertical, Qt::ScrollBarAsNeeded);
|
||||
-
|
||||
- // inject a style sheet that follows system colors, otherwise we might end up with black text on dark gray background
|
||||
- const QString styleSheet = QStringLiteral(
|
||||
- "body { background: %1; color: %2; }" \
|
||||
- "a { color: %3; }" \
|
||||
- "a:visited { color: %4; } "
|
||||
- ).arg(palette().background().color().name(),
|
||||
- palette().text().color().name(),
|
||||
- palette().link().color().name(),
|
||||
- palette().linkVisited().color().name());
|
||||
-
|
||||
- // you can only provide a user style sheet url, so we turn it into a data url here
|
||||
- const QUrl dataUrl(QStringLiteral("data:text/css;charset=utf-8;base64,") + QString::fromLatin1(styleSheet.toUtf8().toBase64()));
|
||||
-
|
||||
- m_webView.settings()->setUserStyleSheetUrl(dataUrl);
|
||||
-
|
||||
+ m_webView.settings()->setAttribute(QWebEngineSettings::PluginsEnabled, false);
|
||||
+ m_webView.page()->profile()->setRequestInterceptor(new RemoteUrlInterceptor(this));
|
||||
#endif
|
||||
}
|
||||
-#if HAVE_QTWEBKITWIDGETS
|
||||
- QWebView *webView() {
|
||||
+#if HAVE_QTWEBENGINEWIDGETS
|
||||
+ QWebEngineView *webView() {
|
||||
return &m_webView;
|
||||
}
|
||||
protected:
|
||||
- QWebView m_webView;
|
||||
+ QWebEngineView m_webView;
|
||||
#endif
|
||||
};
|
||||
|
||||
@@ -127,11 +127,15 @@ void Scripting::runScript(const QString &path, const QString &name) {
|
||||
mScriptPath = path;
|
||||
mScriptName = name;
|
||||
|
||||
-#if HAVE_QTWEBKITWIDGETS
|
||||
+#if HAVE_QTWEBENGINEWIDGETS
|
||||
QUrl fileName = QUrl::fromLocalFile(path + QStringLiteral("index.html"));
|
||||
if(!mScriptingHtmlDialog) {
|
||||
mScriptingHtmlDialog = new ScriptingHtmlDialog(this);
|
||||
+ mWebChannel = new QWebChannel(mScriptingHtmlDialog);
|
||||
connect(mScriptingHtmlDialog, &QDialog::rejected, this, &Scripting::stopAllScripts);
|
||||
+ // Only show after page loaded to allow for layouting
|
||||
+ mScriptingHtmlDialog->connect(mScriptingHtmlDialog->webView(), &QWebEngineView::loadFinished,
|
||||
+ mScriptingHtmlDialog, &ScriptingHtmlDialog::show);
|
||||
|
||||
QAction *refreshAction = new QAction(QStringLiteral("refresh"), mScriptingHtmlDialog);
|
||||
refreshAction->setShortcut(QKeySequence::Refresh);
|
||||
@@ -145,23 +149,107 @@ void Scripting::runScript(const QString &path, const QString &name) {
|
||||
mScriptingHtmlDialog->addAction(zoomOutAction);
|
||||
}
|
||||
|
||||
- //Make the process information available to the script
|
||||
- mScriptingHtmlDialog->webView()->load(fileName);
|
||||
- mScriptingHtmlDialog->show();
|
||||
- connect(mScriptingHtmlDialog->webView()->page()->mainFrame(), &QWebFrame::javaScriptWindowObjectCleared, this, &Scripting::setupJavascriptObjects);
|
||||
+ // Make the process information available to the script
|
||||
+ QWebEngineProfile *profile = mScriptingHtmlDialog->webView()->page()->profile();
|
||||
+ QFile webChannelJsFile(QStringLiteral(":/qtwebchannel/qwebchannel.js"));
|
||||
+ webChannelJsFile.open(QIODevice::ReadOnly);
|
||||
+ QString webChannelJs = QString::fromUtf8(webChannelJsFile.readAll());
|
||||
+
|
||||
+ /* Warning: Awful hack ahead!
|
||||
+ * WebChannel does not allow synchonous calls so we need to make
|
||||
+ * asynchronous calls synchronous.
|
||||
+ * The conversion is achieved by caching the result of all readFile
|
||||
+ * and fileExists calls and restarting the script on every result until
|
||||
+ * all requests can be fulfilled synchronously.
|
||||
+ * Another challenge is that WebEngine does not support reading
|
||||
+ * files from /proc over file:// (they are always empty) so we need
|
||||
+ * to keep using the ProcessObject helper methods.
|
||||
+ */
|
||||
+ webChannelJs.append(QStringLiteral(R"JS(
|
||||
+new QWebChannel(window.qt.webChannelTransport, function(channel) {
|
||||
+ window.process = channel.objects.process;
|
||||
+ window.process.realReadFile = window.process.readFile;
|
||||
+ window.process.realFileExists = window.process.fileExists;
|
||||
+ var files = {}; // Map of all read files. null means does not exist
|
||||
+ window.process.fileExists = function(name, cb) {
|
||||
+ if(cb) return window.process.realFileExists(name, cb);
|
||||
+ if (files[name] === null)
|
||||
+ return false; // Definitely does not exist
|
||||
+ if (typeof(files[name]) == 'string')
|
||||
+ return true; // Definitely exists
|
||||
+
|
||||
+ window.process.realFileExists(name, function(r) {
|
||||
+ if(!r) {
|
||||
+ files[name] = null;
|
||||
+ refresh();
|
||||
+ return;
|
||||
+ }
|
||||
+ window.process.realReadFile(name, function(r) {
|
||||
+ files[name] = r;
|
||||
+ refresh();
|
||||
+ });
|
||||
+ });
|
||||
+
|
||||
+ return true; // Might exist
|
||||
+ };
|
||||
+ window.process.readFile = function(name,cb) {
|
||||
+ if(cb) return window.process.realReadFile(name, cb);
|
||||
+ if (typeof(files[name]) == 'string')
|
||||
+ return files[name]; // From cache
|
||||
+
|
||||
+ window.process.fileExists(name); // Fill the cache
|
||||
+ return '';
|
||||
+ };
|
||||
+ refresh && refresh();
|
||||
+});)JS"));
|
||||
+
|
||||
+ QWebEngineScript webChannelScript;
|
||||
+ webChannelScript.setSourceCode(webChannelJs);
|
||||
+ webChannelScript.setName(QStringLiteral("qwebchannel.js"));
|
||||
+ webChannelScript.setWorldId(QWebEngineScript::MainWorld);
|
||||
+ webChannelScript.setInjectionPoint(QWebEngineScript::DocumentCreation);
|
||||
+ webChannelScript.setRunsOnSubFrames(false);
|
||||
+
|
||||
+ profile->scripts()->insert(webChannelScript);
|
||||
+
|
||||
+ // Inject a style sheet that follows system colors, otherwise we might end up with black text on dark gray background
|
||||
+ const QString styleSheet = QStringLiteral(
|
||||
+ "body { background: %1; color: %2; }" \
|
||||
+ "a { color: %3; }" \
|
||||
+ "a:visited { color: %4; } "
|
||||
+ ).arg(palette().background().color().name(),
|
||||
+ palette().text().color().name(),
|
||||
+ palette().link().color().name(),
|
||||
+ palette().linkVisited().color().name());
|
||||
+
|
||||
+ QString styleSheetJs = QStringLiteral("\nvar node = document.createElement('style');"
|
||||
+ "node.innerHTML = '%1';"
|
||||
+ "document.body.appendChild(node);").arg(styleSheet);
|
||||
+
|
||||
+ QWebEngineScript styleSheetScript;
|
||||
+ styleSheetScript.setSourceCode(styleSheetJs);
|
||||
+ styleSheetScript.setName(QStringLiteral("stylesheet.js"));
|
||||
+ styleSheetScript.setWorldId(QWebEngineScript::MainWorld);
|
||||
+ styleSheetScript.setInjectionPoint(QWebEngineScript::DocumentReady);
|
||||
+ styleSheetScript.setRunsOnSubFrames(false);
|
||||
+
|
||||
+ profile->scripts()->insert(styleSheetScript);
|
||||
+
|
||||
setupJavascriptObjects();
|
||||
+
|
||||
+ mScriptingHtmlDialog->webView()->load(fileName);
|
||||
#else
|
||||
- QMessageBox::critical(this, i18n("QtWebKitWidgets not available"),
|
||||
- i18n("KSysGuard library was compiled without QtWebKitWidgets, please contact your distribution."));
|
||||
+ QMessageBox::critical(this, i18n("QtWebEngineWidgets not available"),
|
||||
+ i18n("KSysGuard library was compiled without QtWebEngineWidgets, please contact your distribution."));
|
||||
#endif
|
||||
}
|
||||
-#if HAVE_QTWEBKITWIDGETS
|
||||
+#if HAVE_QTWEBENGINEWIDGETS
|
||||
void Scripting::zoomIn() {
|
||||
- QWebView *webView = mScriptingHtmlDialog->webView();
|
||||
+ QWebEngineView *webView = mScriptingHtmlDialog->webView();
|
||||
webView->setZoomFactor( webView->zoomFactor() * 1.1 );
|
||||
}
|
||||
void Scripting::zoomOut() {
|
||||
- QWebView *webView = mScriptingHtmlDialog->webView();
|
||||
+ QWebEngineView *webView = mScriptingHtmlDialog->webView();
|
||||
if(webView->zoomFactor() > 0.1) //Prevent it getting too small
|
||||
webView->setZoomFactor( webView->zoomFactor() / 1.1 );
|
||||
}
|
||||
@@ -169,14 +257,16 @@ void Scripting::zoomOut() {
|
||||
void Scripting::refreshScript() {
|
||||
//Call any refresh function, if it exists
|
||||
mProcessList->processModel()->update(0, KSysGuard::Processes::XMemory);
|
||||
- if(mScriptingHtmlDialog && mScriptingHtmlDialog->webView() && mScriptingHtmlDialog->webView()->page() && mScriptingHtmlDialog->webView()->page()->mainFrame()) {
|
||||
- mScriptingHtmlDialog->webView()->page()->mainFrame()->evaluateJavaScript(QStringLiteral("refresh();"));
|
||||
+ mProcessObject->anythingChanged();
|
||||
+ if(mScriptingHtmlDialog && mScriptingHtmlDialog->webView() && mScriptingHtmlDialog->webView()->page()) {
|
||||
+ mScriptingHtmlDialog->webView()->page()->runJavaScript(QStringLiteral("refresh && refresh();"));
|
||||
}
|
||||
}
|
||||
void Scripting::setupJavascriptObjects() {
|
||||
mProcessList->processModel()->update(0, KSysGuard::Processes::XMemory);
|
||||
mProcessObject = new ProcessObject(mProcessList->processModel(), mPid);
|
||||
- mScriptingHtmlDialog->webView()->page()->mainFrame()->addToJavaScriptWindowObject(QStringLiteral("process"), mProcessObject, QWebFrame::ScriptOwnership);
|
||||
+ mWebChannel->registerObject(QStringLiteral("process"), mProcessObject);
|
||||
+ mScriptingHtmlDialog->webView()->page()->setWebChannel(mWebChannel);
|
||||
}
|
||||
#endif
|
||||
void Scripting::stopAllScripts()
|
||||
diff --git a/processui/scripting.h b/processui/scripting.h
|
||||
index 33eb3de..e9794da 100644
|
||||
--- a/processui/scripting.h
|
||||
+++ b/processui/scripting.h
|
||||
@@ -34,6 +34,7 @@ class QAction;
|
||||
class ScriptingHtmlDialog; //Defined in scripting.cpp file
|
||||
class KSysGuardProcessList;
|
||||
class ProcessObject;
|
||||
+class QWebChannel;
|
||||
|
||||
class Scripting : public QWidget {
|
||||
Q_OBJECT
|
||||
@@ -55,7 +56,7 @@ class Scripting : public QWidget {
|
||||
private Q_SLOTS:
|
||||
/** Run the script associated with the QAction that called this slot */
|
||||
void runScriptSlot();
|
||||
-#if HAVE_QTWEBKITWIDGETS
|
||||
+#if HAVE_QTWEBENGINEWIDGETS
|
||||
void setupJavascriptObjects();
|
||||
void refreshScript();
|
||||
void zoomIn();
|
||||
@@ -64,6 +65,8 @@ class Scripting : public QWidget {
|
||||
private:
|
||||
/** This is created on the fly as needed, and deleted when no longer used */
|
||||
ScriptingHtmlDialog *mScriptingHtmlDialog;
|
||||
+ /** Used to expose mProcessObject to the WebEnginePage */
|
||||
+ QWebChannel *mWebChannel;
|
||||
/** The parent process list to script for */
|
||||
KSysGuardProcessList * const mProcessList;
|
||||
/** List of context menu actions that are created by loadContextMenu() */
|
||||
@@ -75,60 +78,62 @@ class Scripting : public QWidget {
|
||||
qlonglong mPid;
|
||||
};
|
||||
|
||||
+// QWebChannel only reloads properties on demand, so we need a signal.
|
||||
+#define P_PROPERTY(x) Q_PROPERTY(x NOTIFY anythingChanged)
|
||||
#define PROPERTY(Type,Name) Type Name() const { KSysGuard::Process *process = mModel->getProcess(mPid); if(process) return process->Name(); else return Type();}
|
||||
|
||||
class ProcessObject : public QObject {
|
||||
Q_OBJECT
|
||||
public:
|
||||
- Q_PROPERTY(qlonglong pid READ pid WRITE setPid) /* Add functionality to 'set' the pid to change which process to read from */
|
||||
- Q_PROPERTY(qlonglong ppid READ parentPid) /* Map 'ppid' to 'parentPid' to give it a nicer scripting name */
|
||||
- Q_PROPERTY(QString name READ name) /* Defined below to return the first word of the name */
|
||||
- Q_PROPERTY(QString fullname READ fullname) /* Defined below to return 'name' */
|
||||
- Q_PROPERTY(qlonglong rss READ vmRSS) /* Map 'rss' to 'vmRSS' just to give it a nicer scripting name */
|
||||
- Q_PROPERTY(qlonglong urss READ vmURSS) /* Map 'urss' to 'vmURSS' just to give it a nicer scripting name */
|
||||
- Q_PROPERTY(int numThreads READ numThreads) PROPERTY(int, numThreads)
|
||||
- Q_PROPERTY(qlonglong fsgid READ fsgid) PROPERTY(qlonglong, fsgid)
|
||||
- Q_PROPERTY(qlonglong parentPid READ parentPid) PROPERTY(qlonglong, parentPid)
|
||||
- Q_PROPERTY(QString login READ login) PROPERTY(QString, login)
|
||||
- Q_PROPERTY(qlonglong uid READ uid) PROPERTY(qlonglong, uid)
|
||||
- Q_PROPERTY(qlonglong euid READ euid) PROPERTY(qlonglong, euid)
|
||||
- Q_PROPERTY(qlonglong suid READ suid) PROPERTY(qlonglong, suid)
|
||||
- Q_PROPERTY(qlonglong fsuid READ fsuid) PROPERTY(qlonglong, fsuid)
|
||||
- Q_PROPERTY(qlonglong gid READ gid) PROPERTY(qlonglong, gid)
|
||||
- Q_PROPERTY(qlonglong egid READ egid) PROPERTY(qlonglong, egid)
|
||||
- Q_PROPERTY(qlonglong sgid READ sgid) PROPERTY(qlonglong, sgid)
|
||||
- Q_PROPERTY(qlonglong tracerpid READ tracerpid) PROPERTY(qlonglong, tracerpid)
|
||||
- Q_PROPERTY(QByteArray tty READ tty) PROPERTY(QByteArray, tty)
|
||||
- Q_PROPERTY(qlonglong userTime READ userTime) PROPERTY(qlonglong, userTime)
|
||||
- Q_PROPERTY(qlonglong sysTime READ sysTime) PROPERTY(qlonglong, sysTime)
|
||||
- Q_PROPERTY(int userUsage READ userUsage) PROPERTY(int, userUsage)
|
||||
- Q_PROPERTY(int sysUsage READ sysUsage) PROPERTY(int, sysUsage)
|
||||
- Q_PROPERTY(int totalUserUsage READ totalUserUsage) PROPERTY(int, totalUserUsage)
|
||||
- Q_PROPERTY(int totalSysUsage READ totalSysUsage) PROPERTY(int, totalSysUsage)
|
||||
- Q_PROPERTY(int numChildren READ numChildren) PROPERTY(int, numChildren)
|
||||
- Q_PROPERTY(int niceLevel READ niceLevel) PROPERTY(int, niceLevel)
|
||||
- Q_PROPERTY(int scheduler READ scheduler) PROPERTY(int, scheduler)
|
||||
- Q_PROPERTY(int ioPriorityClass READ ioPriorityClass) PROPERTY(int, ioPriorityClass)
|
||||
- Q_PROPERTY(int ioniceLevel READ ioniceLevel) PROPERTY(int, ioniceLevel)
|
||||
- Q_PROPERTY(qlonglong vmSize READ vmSize) PROPERTY(qlonglong, vmSize)
|
||||
- Q_PROPERTY(qlonglong vmRSS READ vmRSS) PROPERTY(qlonglong, vmRSS)
|
||||
- Q_PROPERTY(qlonglong vmURSS READ vmURSS) PROPERTY(qlonglong, vmURSS)
|
||||
- Q_PROPERTY(qlonglong pixmapBytes READ pixmapBytes) PROPERTY(qlonglong, pixmapBytes)
|
||||
- Q_PROPERTY(bool hasManagedGuiWindow READ hasManagedGuiWindow) PROPERTY(bool, hasManagedGuiWindow)
|
||||
- Q_PROPERTY(QString command READ command) PROPERTY(QString, command)
|
||||
- Q_PROPERTY(qlonglong status READ status) PROPERTY(qlonglong, status)
|
||||
- Q_PROPERTY(qlonglong ioCharactersRead READ ioCharactersRead) PROPERTY(qlonglong, ioCharactersRead)
|
||||
- Q_PROPERTY(qlonglong ioCharactersWritten READ ioCharactersWritten) PROPERTY(qlonglong, ioCharactersWritten)
|
||||
- Q_PROPERTY(qlonglong ioReadSyscalls READ ioReadSyscalls) PROPERTY(qlonglong, ioReadSyscalls)
|
||||
- Q_PROPERTY(qlonglong ioWriteSyscalls READ ioWriteSyscalls) PROPERTY(qlonglong, ioWriteSyscalls)
|
||||
- Q_PROPERTY(qlonglong ioCharactersActuallyRead READ ioCharactersActuallyRead) PROPERTY(qlonglong, ioCharactersActuallyRead)
|
||||
- Q_PROPERTY(qlonglong ioCharactersActuallyWritten READ ioCharactersActuallyWritten) PROPERTY(qlonglong, ioCharactersActuallyWritten)
|
||||
- Q_PROPERTY(qlonglong ioCharactersReadRate READ ioCharactersReadRate) PROPERTY(qlonglong, ioCharactersReadRate)
|
||||
- Q_PROPERTY(qlonglong ioCharactersWrittenRate READ ioCharactersWrittenRate) PROPERTY(qlonglong, ioCharactersWrittenRate)
|
||||
- Q_PROPERTY(qlonglong ioReadSyscallsRate READ ioReadSyscallsRate) PROPERTY(qlonglong, ioReadSyscallsRate)
|
||||
- Q_PROPERTY(qlonglong ioWriteSyscallsRate READ ioWriteSyscallsRate) PROPERTY(qlonglong, ioWriteSyscallsRate)
|
||||
- Q_PROPERTY(qlonglong ioCharactersActuallyReadRate READ ioCharactersActuallyReadRate) PROPERTY(qlonglong, ioCharactersActuallyReadRate)
|
||||
- Q_PROPERTY(qlonglong ioCharactersActuallyWrittenRate READ ioCharactersActuallyWrittenRate) PROPERTY(qlonglong, ioCharactersActuallyWrittenRate)
|
||||
+ P_PROPERTY(qlonglong pid READ pid WRITE setPid) /* Add functionality to 'set' the pid to change which process to read from */
|
||||
+ P_PROPERTY(qlonglong ppid READ parentPid) /* Map 'ppid' to 'parentPid' to give it a nicer scripting name */
|
||||
+ P_PROPERTY(QString name READ name) /* Defined below to return the first word of the name */
|
||||
+ P_PROPERTY(QString fullname READ fullname) /* Defined below to return 'name' */
|
||||
+ P_PROPERTY(qlonglong rss READ vmRSS) /* Map 'rss' to 'vmRSS' just to give it a nicer scripting name */
|
||||
+ P_PROPERTY(qlonglong urss READ vmURSS) /* Map 'urss' to 'vmURSS' just to give it a nicer scripting name */
|
||||
+ P_PROPERTY(int numThreads READ numThreads) PROPERTY(int, numThreads)
|
||||
+ P_PROPERTY(qlonglong fsgid READ fsgid) PROPERTY(qlonglong, fsgid)
|
||||
+ P_PROPERTY(qlonglong parentPid READ parentPid) PROPERTY(qlonglong, parentPid)
|
||||
+ P_PROPERTY(QString login READ login) PROPERTY(QString, login)
|
||||
+ P_PROPERTY(qlonglong uid READ uid) PROPERTY(qlonglong, uid)
|
||||
+ P_PROPERTY(qlonglong euid READ euid) PROPERTY(qlonglong, euid)
|
||||
+ P_PROPERTY(qlonglong suid READ suid) PROPERTY(qlonglong, suid)
|
||||
+ P_PROPERTY(qlonglong fsuid READ fsuid) PROPERTY(qlonglong, fsuid)
|
||||
+ P_PROPERTY(qlonglong gid READ gid) PROPERTY(qlonglong, gid)
|
||||
+ P_PROPERTY(qlonglong egid READ egid) PROPERTY(qlonglong, egid)
|
||||
+ P_PROPERTY(qlonglong sgid READ sgid) PROPERTY(qlonglong, sgid)
|
||||
+ P_PROPERTY(qlonglong tracerpid READ tracerpid) PROPERTY(qlonglong, tracerpid)
|
||||
+ P_PROPERTY(QByteArray tty READ tty) PROPERTY(QByteArray, tty)
|
||||
+ P_PROPERTY(qlonglong userTime READ userTime) PROPERTY(qlonglong, userTime)
|
||||
+ P_PROPERTY(qlonglong sysTime READ sysTime) PROPERTY(qlonglong, sysTime)
|
||||
+ P_PROPERTY(int userUsage READ userUsage) PROPERTY(int, userUsage)
|
||||
+ P_PROPERTY(int sysUsage READ sysUsage) PROPERTY(int, sysUsage)
|
||||
+ P_PROPERTY(int totalUserUsage READ totalUserUsage) PROPERTY(int, totalUserUsage)
|
||||
+ P_PROPERTY(int totalSysUsage READ totalSysUsage) PROPERTY(int, totalSysUsage)
|
||||
+ P_PROPERTY(int numChildren READ numChildren) PROPERTY(int, numChildren)
|
||||
+ P_PROPERTY(int niceLevel READ niceLevel) PROPERTY(int, niceLevel)
|
||||
+ P_PROPERTY(int scheduler READ scheduler) PROPERTY(int, scheduler)
|
||||
+ P_PROPERTY(int ioPriorityClass READ ioPriorityClass) PROPERTY(int, ioPriorityClass)
|
||||
+ P_PROPERTY(int ioniceLevel READ ioniceLevel) PROPERTY(int, ioniceLevel)
|
||||
+ P_PROPERTY(qlonglong vmSize READ vmSize) PROPERTY(qlonglong, vmSize)
|
||||
+ P_PROPERTY(qlonglong vmRSS READ vmRSS) PROPERTY(qlonglong, vmRSS)
|
||||
+ P_PROPERTY(qlonglong vmURSS READ vmURSS) PROPERTY(qlonglong, vmURSS)
|
||||
+ P_PROPERTY(qlonglong pixmapBytes READ pixmapBytes) PROPERTY(qlonglong, pixmapBytes)
|
||||
+ P_PROPERTY(bool hasManagedGuiWindow READ hasManagedGuiWindow) PROPERTY(bool, hasManagedGuiWindow)
|
||||
+ P_PROPERTY(QString command READ command) PROPERTY(QString, command)
|
||||
+ P_PROPERTY(qlonglong status READ status) PROPERTY(qlonglong, status)
|
||||
+ P_PROPERTY(qlonglong ioCharactersRead READ ioCharactersRead) PROPERTY(qlonglong, ioCharactersRead)
|
||||
+ P_PROPERTY(qlonglong ioCharactersWritten READ ioCharactersWritten) PROPERTY(qlonglong, ioCharactersWritten)
|
||||
+ P_PROPERTY(qlonglong ioReadSyscalls READ ioReadSyscalls) PROPERTY(qlonglong, ioReadSyscalls)
|
||||
+ P_PROPERTY(qlonglong ioWriteSyscalls READ ioWriteSyscalls) PROPERTY(qlonglong, ioWriteSyscalls)
|
||||
+ P_PROPERTY(qlonglong ioCharactersActuallyRead READ ioCharactersActuallyRead) PROPERTY(qlonglong, ioCharactersActuallyRead)
|
||||
+ P_PROPERTY(qlonglong ioCharactersActuallyWritten READ ioCharactersActuallyWritten) PROPERTY(qlonglong, ioCharactersActuallyWritten)
|
||||
+ P_PROPERTY(qlonglong ioCharactersReadRate READ ioCharactersReadRate) PROPERTY(qlonglong, ioCharactersReadRate)
|
||||
+ P_PROPERTY(qlonglong ioCharactersWrittenRate READ ioCharactersWrittenRate) PROPERTY(qlonglong, ioCharactersWrittenRate)
|
||||
+ P_PROPERTY(qlonglong ioReadSyscallsRate READ ioReadSyscallsRate) PROPERTY(qlonglong, ioReadSyscallsRate)
|
||||
+ P_PROPERTY(qlonglong ioWriteSyscallsRate READ ioWriteSyscallsRate) PROPERTY(qlonglong, ioWriteSyscallsRate)
|
||||
+ P_PROPERTY(qlonglong ioCharactersActuallyReadRate READ ioCharactersActuallyReadRate) PROPERTY(qlonglong, ioCharactersActuallyReadRate)
|
||||
+ P_PROPERTY(qlonglong ioCharactersActuallyWrittenRate READ ioCharactersActuallyWrittenRate) PROPERTY(qlonglong, ioCharactersActuallyWrittenRate)
|
||||
|
||||
ProcessObject(ProcessModel * processModel, int pid);
|
||||
void update(KSysGuard::Process *process);
|
||||
@@ -141,6 +146,10 @@ class ProcessObject : public QObject {
|
||||
public Q_SLOTS:
|
||||
bool fileExists(const QString &filename);
|
||||
QString readFile(const QString &filename);
|
||||
+
|
||||
+ Q_SIGNALS:
|
||||
+ void anythingChanged();
|
||||
+
|
||||
private:
|
||||
int mPid;
|
||||
ProcessModel *mModel;
|
||||
--
|
||||
2.18.0
|
||||
|
@ -1,3 +1,10 @@
|
||||
-------------------------------------------------------------------
|
||||
Sat Oct 13 16:37:32 UTC 2018 - fabian@ritter-vogt.de
|
||||
|
||||
- Add patch to use WebEngine instead of WebKit:
|
||||
* 0001-Port-scripting-to-Qt-WebEngine.patch
|
||||
- Use gcc7 on Leap 42.3
|
||||
|
||||
-------------------------------------------------------------------
|
||||
Fri Oct 5 10:01:11 UTC 2018 - fabian@ritter-vogt.de
|
||||
|
||||
|
@ -30,6 +30,8 @@ Source1: libksysguard-%{version}.tar.xz.sig
|
||||
Source2: plasma.keyring
|
||||
%endif
|
||||
Source3: baselibs.conf
|
||||
# PATCH-FEATURE-UPSTREAM
|
||||
Patch100: 0001-Port-scripting-to-Qt-WebEngine.patch
|
||||
BuildRequires: extra-cmake-modules >= 1.2.0
|
||||
BuildRequires: kf5-filesystem
|
||||
BuildRequires: xz
|
||||
@ -48,12 +50,16 @@ BuildRequires: cmake(KF5WidgetsAddons)
|
||||
BuildRequires: cmake(KF5WindowSystem)
|
||||
BuildRequires: cmake(Qt5DBus) >= 5.4.0
|
||||
BuildRequires: cmake(Qt5Network) >= 5.4.0
|
||||
BuildRequires: cmake(Qt5WebKitWidgets) >= 5.4.0
|
||||
BuildRequires: cmake(Qt5WebEngineWidgets) >= 5.4.0
|
||||
BuildRequires: cmake(Qt5Widgets) >= 5.4.0
|
||||
BuildRequires: cmake(Qt5X11Extras) >= 5.4.0
|
||||
BuildRequires: pkgconfig(x11)
|
||||
BuildRequires: pkgconfig(xres)
|
||||
BuildRequires: pkgconfig(zlib)
|
||||
%if 0%{?suse_version} < 1330
|
||||
# It does not build with the default compiler (GCC 4.8) on Leap 42.x
|
||||
BuildRequires: gcc7-c++
|
||||
%endif
|
||||
Recommends: %{name}-lang
|
||||
|
||||
%description
|
||||
@ -85,10 +91,16 @@ Task management and system monitoring library. This package contains helper file
|
||||
for actions that require elevated privileges.
|
||||
|
||||
%lang_package
|
||||
|
||||
%prep
|
||||
%setup -q -n libksysguard-%{version}
|
||||
%autosetup -p1 -n libksysguard-%{version}
|
||||
|
||||
%build
|
||||
%if 0%{?suse_version} < 1330
|
||||
# It does not build with the default compiler (GCC 4.8) on Leap 42.x
|
||||
export CC=gcc-7
|
||||
export CXX=g++-7
|
||||
%endif
|
||||
%cmake_kf5 -d build -- -DCMAKE_INSTALL_LOCALEDIR=%{_kf5_localedir}
|
||||
%make_jobs
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user