mirror of
https://github.com/arcan1s/awesome-widgets.git
synced 2025-07-16 23:29:58 +00:00
Compare commits
2 Commits
b6ade7310a
...
4.0.0alpha
Author | SHA1 | Date | |
---|---|---|---|
161ff64293 | |||
115bef3dbe |
24
.github/workflows/release.yml
vendored
24
.github/workflows/release.yml
vendored
@ -25,17 +25,17 @@ jobs:
|
|||||||
env:
|
env:
|
||||||
VERSION: ${{ steps.version.outputs.VERSION }}
|
VERSION: ${{ steps.version.outputs.VERSION }}
|
||||||
|
|
||||||
- name: build debian package
|
# - name: build debian package
|
||||||
run: |
|
# run: |
|
||||||
sudo apt update && \
|
# sudo apt update && \
|
||||||
sudo apt install -yq cmake extra-cmake-modules g++ git gettext make && \
|
# sudo apt install -yq cmake extra-cmake-modules g++ git gettext make && \
|
||||||
sudo apt install -yq libkf5i18n-dev libkf5notifications-dev libkf5service-dev \
|
# sudo apt install -yq libkf5i18n-dev libkf5notifications-dev libkf5service-dev \
|
||||||
libkf5windowsystem-dev libkf5plasma-dev qtbase5-dev qtdeclarative5-dev \
|
# libkf5windowsystem-dev libkf5plasma-dev qtbase5-dev qtdeclarative5-dev \
|
||||||
plasma-workspace-dev && \
|
# plasma-workspace-dev && \
|
||||||
cmake -B build-deb -DKDE_INSTALL_USE_QT_SYS_PATHS=ON -DCMAKE_INSTALL_PREFIX=/usr -DCMAKE_BUILD_TYPE=Optimization -DBUILD_FUTURE=ON -DBUILD_DEB_PACKAGE=ON sources && \
|
# cmake -B build-deb -DKDE_INSTALL_USE_QT_SYS_PATHS=ON -DCMAKE_INSTALL_PREFIX=/usr -DCMAKE_BUILD_TYPE=Optimization -DBUILD_FUTURE=ON -DBUILD_DEB_PACKAGE=ON sources && \
|
||||||
cd build-deb && \
|
# cd build-deb && \
|
||||||
make package && \
|
# make package && \
|
||||||
cd ..
|
# cd ..
|
||||||
|
|
||||||
- name: release
|
- name: release
|
||||||
uses: softprops/action-gh-release@v1
|
uses: softprops/action-gh-release@v1
|
||||||
@ -45,7 +45,7 @@ jobs:
|
|||||||
${{ steps.changelog.outputs.changelog }}
|
${{ steps.changelog.outputs.changelog }}
|
||||||
files: |
|
files: |
|
||||||
awesome-widgets-*-src.tar.xz
|
awesome-widgets-*-src.tar.xz
|
||||||
build-deb/plasma-widget-awesome-widgets-*.deb
|
# build-deb/plasma-widget-awesome-widgets-*.deb
|
||||||
fail_on_unmatched_files: true
|
fail_on_unmatched_files: true
|
||||||
env:
|
env:
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
@ -1,3 +1,6 @@
|
|||||||
|
Ver.4.0.0:
|
||||||
|
* migration to plasma 6
|
||||||
|
|
||||||
Ver.3.5.0:
|
Ver.3.5.0:
|
||||||
+ wayland support
|
+ wayland support
|
||||||
* update code to latest standards
|
* update code to latest standards
|
||||||
@ -12,7 +15,6 @@ Ver.3.4.2:
|
|||||||
* update to new qt api
|
* update to new qt api
|
||||||
- fix non printable spaces (#142, #143)
|
- fix non printable spaces (#142, #143)
|
||||||
|
|
||||||
|
|
||||||
Ver.3.3.3:
|
Ver.3.3.3:
|
||||||
+ add custom keys support (#101)
|
+ add custom keys support (#101)
|
||||||
* DBus interface improvements
|
* DBus interface improvements
|
||||||
|
@ -1,22 +1,21 @@
|
|||||||
# Maintainer: Evgeniy Alekseev <arcanis at archlinux dot org>
|
# Maintainer: Evgeniy Alekseev <arcanis at archlinux dot org>
|
||||||
|
|
||||||
pkgname=plasma5-applet-awesome-widgets
|
pkgname=plasma6-applet-awesome-widgets
|
||||||
_pkgname=awesome-widgets
|
_pkgname=awesome-widgets
|
||||||
pkgver=3.4.3
|
pkgver=4.0.0alpha1
|
||||||
pkgrel=1
|
pkgrel=1
|
||||||
pkgdesc="Collection of minimalistic Plasmoids which look like Awesome WM widgets (ex-PyTextMonitor)"
|
pkgdesc="Collection of minimalistic Plasmoids which look like Awesome WM widgets (ex-PyTextMonitor)"
|
||||||
arch=('i686' 'x86_64')
|
arch=('x86_64')
|
||||||
url="https://arcanis.me/projects/awesome-widgets"
|
url="https://arcanis.me/projects/awesome-widgets"
|
||||||
license=('GPL3')
|
license=('GPL3')
|
||||||
depends=('ksysguard' 'plasma-framework')
|
depends=('plasma-workspace')
|
||||||
optdepends=("hddtemp: for HDD temperature monitor"
|
optdepends=("hddtemp: for HDD temperature monitor"
|
||||||
"smartmontools: for HDD temperature monitor"
|
"smartmontools: for HDD temperature monitor"
|
||||||
"mpd: for music player monitor"
|
"mpd: for music player monitor"
|
||||||
"nvidia-utils: for GPU monitor")
|
"nvidia-utils: for GPU monitor")
|
||||||
makedepends=('cmake' 'extra-cmake-modules' 'python')
|
makedepends=('cmake' 'extra-cmake-modules' 'python')
|
||||||
source=(https://github.com/arcan1s/awesome-widgets/releases/download/V.${pkgver}/${_pkgname}-${pkgver}-src.tar.xz)
|
source=(https://github.com/arcan1s/awesome-widgets/releases/download/${pkgver}/${_pkgname}-${pkgver}-src.tar.xz)
|
||||||
install=${pkgname}.install
|
install="$pkgname.install"
|
||||||
md5sums=('5953ba518191bb6fff83cdb8633c735c')
|
|
||||||
backup=('etc/xdg/plasma-dataengine-extsysmon.conf')
|
backup=('etc/xdg/plasma-dataengine-extsysmon.conf')
|
||||||
|
|
||||||
build () {
|
build () {
|
||||||
@ -30,3 +29,5 @@ build () {
|
|||||||
package() {
|
package() {
|
||||||
DESTDIR="$pkgdir" cmake --install build
|
DESTDIR="$pkgdir" cmake --install build
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sha256sums=('b2a7b07a1df6f710f4e0d6e5898933f4ddb131818b922dc4b8e48afe3e98a664')
|
||||||
|
@ -14,9 +14,9 @@ project(awesomewidgets)
|
|||||||
set(PROJECT_AUTHOR "Evgeniy Alekseev")
|
set(PROJECT_AUTHOR "Evgeniy Alekseev")
|
||||||
set(PROJECT_CONTACT "esalexeev@gmail.com")
|
set(PROJECT_CONTACT "esalexeev@gmail.com")
|
||||||
set(PROJECT_LICENSE "GPL3")
|
set(PROJECT_LICENSE "GPL3")
|
||||||
set(PROJECT_VERSION_MAJOR "3")
|
set(PROJECT_VERSION_MAJOR "4")
|
||||||
set(PROJECT_VERSION_MINOR "5")
|
set(PROJECT_VERSION_MINOR "0")
|
||||||
set(PROJECT_VERSION_PATCH "1")
|
set(PROJECT_VERSION_PATCH "0")
|
||||||
set(PROJECT_VERSION "${PROJECT_VERSION_MAJOR}.${PROJECT_VERSION_MINOR}.${PROJECT_VERSION_PATCH}")
|
set(PROJECT_VERSION "${PROJECT_VERSION_MAJOR}.${PROJECT_VERSION_MINOR}.${PROJECT_VERSION_PATCH}")
|
||||||
# append git version if any
|
# append git version if any
|
||||||
set(PROJECT_COMMIT_SHA "Commit hash" CACHE INTERNAL "")
|
set(PROJECT_COMMIT_SHA "Commit hash" CACHE INTERNAL "")
|
||||||
|
@ -17,15 +17,17 @@
|
|||||||
|
|
||||||
#include "awdataengineaggregator.h"
|
#include "awdataengineaggregator.h"
|
||||||
|
|
||||||
#include <QDBusConnection>
|
|
||||||
#include <ksysguard/formatter/Unit.h>
|
#include <ksysguard/formatter/Unit.h>
|
||||||
#include <ksysguard/systemstats/DBusInterface.h>
|
#include <ksysguard/systemstats/DBusInterface.h>
|
||||||
|
|
||||||
|
#include <QDBusConnection>
|
||||||
|
|
||||||
#include "awdebug.h"
|
#include "awdebug.h"
|
||||||
|
|
||||||
|
|
||||||
AWDataEngineAggregator::AWDataEngineAggregator(QObject *_parent)
|
AWDataEngineAggregator::AWDataEngineAggregator(QObject *_parent)
|
||||||
: QObject(_parent)
|
: QObject(_parent)
|
||||||
|
, m_interface(new KSysGuard::SystemStats::DBusInterface())
|
||||||
{
|
{
|
||||||
qCDebug(LOG_AW) << __PRETTY_FUNCTION__;
|
qCDebug(LOG_AW) << __PRETTY_FUNCTION__;
|
||||||
|
|
||||||
@ -34,12 +36,14 @@ AWDataEngineAggregator::AWDataEngineAggregator(QObject *_parent)
|
|||||||
qDBusRegisterMetaType<KSysGuard::SensorDataList>();
|
qDBusRegisterMetaType<KSysGuard::SensorDataList>();
|
||||||
qDBusRegisterMetaType<QHash<QString, KSysGuard::SensorInfo>>();
|
qDBusRegisterMetaType<QHash<QString, KSysGuard::SensorInfo>>();
|
||||||
|
|
||||||
m_interface = new KSysGuard::SystemStats::DBusInterface();
|
connect(m_interface, &KSysGuard::SystemStats::DBusInterface::newSensorData, this,
|
||||||
|
&AWDataEngineAggregator::updateData);
|
||||||
connect(m_interface, &KSysGuard::SystemStats::DBusInterface::newSensorData, this, &AWDataEngineAggregator::updateData);
|
connect(m_interface, &KSysGuard::SystemStats::DBusInterface::sensorMetaDataChanged, this,
|
||||||
connect(m_interface, &KSysGuard::SystemStats::DBusInterface::sensorMetaDataChanged, this, &AWDataEngineAggregator::updateSensors);
|
&AWDataEngineAggregator::updateSensors);
|
||||||
connect(m_interface, &KSysGuard::SystemStats::DBusInterface::sensorAdded, this, &AWDataEngineAggregator::sensorAdded);
|
connect(m_interface, &KSysGuard::SystemStats::DBusInterface::sensorAdded, this,
|
||||||
connect(m_interface, &KSysGuard::SystemStats::DBusInterface::sensorRemoved, this, &AWDataEngineAggregator::sensorRemoved);
|
&AWDataEngineAggregator::sensorAdded);
|
||||||
|
connect(m_interface, &KSysGuard::SystemStats::DBusInterface::sensorRemoved, this,
|
||||||
|
&AWDataEngineAggregator::sensorRemoved);
|
||||||
|
|
||||||
loadSources();
|
loadSources();
|
||||||
}
|
}
|
||||||
@ -54,9 +58,20 @@ AWDataEngineAggregator::~AWDataEngineAggregator()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void AWDataEngineAggregator::connectSources()
|
||||||
|
{
|
||||||
|
auto keys = m_sensors.keys();
|
||||||
|
auto newKeys = QSet(keys.cbegin(), keys.cend()) - m_subscribed;
|
||||||
|
|
||||||
|
m_interface->subscribe(newKeys.values()).waitForFinished();
|
||||||
|
m_subscribed.unite(newKeys);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void AWDataEngineAggregator::disconnectSources()
|
void AWDataEngineAggregator::disconnectSources()
|
||||||
{
|
{
|
||||||
m_interface->unsubscribe(m_sensors.keys());
|
m_interface->unsubscribe(m_subscribed.values()).waitForFinished();
|
||||||
|
m_subscribed.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -73,15 +88,7 @@ void AWDataEngineAggregator::loadSources()
|
|||||||
|
|
||||||
auto sensors = response.value();
|
auto sensors = response.value();
|
||||||
updateSensors(sensors);
|
updateSensors(sensors);
|
||||||
}
|
connectSources();
|
||||||
|
|
||||||
|
|
||||||
void AWDataEngineAggregator::reconnectSources(const int interval)
|
|
||||||
{
|
|
||||||
qCDebug(LOG_AW) << "Reconnect all sensors with update interval" << interval;
|
|
||||||
|
|
||||||
disconnectSources();
|
|
||||||
m_interface->subscribe(m_sensors.keys());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -89,7 +96,10 @@ void AWDataEngineAggregator::dropSource(const QString &_source)
|
|||||||
{
|
{
|
||||||
qCDebug(LOG_AW) << "Disconnect sensor" << _source;
|
qCDebug(LOG_AW) << "Disconnect sensor" << _source;
|
||||||
|
|
||||||
m_interface->unsubscribe({_source});
|
if (m_subscribed.contains(_source)) {
|
||||||
|
m_interface->unsubscribe({_source}).waitForFinished();
|
||||||
|
m_subscribed.remove(_source);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -100,13 +110,17 @@ void AWDataEngineAggregator::sensorAdded(const QString &_sensor)
|
|||||||
// check if sensor is actually valid
|
// check if sensor is actually valid
|
||||||
auto response = m_interface->sensors({_sensor});
|
auto response = m_interface->sensors({_sensor});
|
||||||
response.waitForFinished();
|
response.waitForFinished();
|
||||||
auto info = response.value();
|
|
||||||
if (info.count() != 1)
|
auto info = response.value().value(_sensor);
|
||||||
|
if (!isValidSensor(info))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
qCWarning(LOG_AW) << info.keys();
|
m_sensors[_sensor] = info;
|
||||||
|
dropSource(_sensor); // force reconnect
|
||||||
m_interface->subscribe({_sensor});
|
if (!m_subscribed.contains(_sensor)) {
|
||||||
|
m_interface->subscribe({_sensor}).waitForFinished();
|
||||||
|
m_subscribed.insert(_sensor);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -115,9 +129,10 @@ void AWDataEngineAggregator::sensorRemoved(const QString &_sensor)
|
|||||||
qCDebug(LOG_AW) << "Sensor" << _sensor << "has been removed";
|
qCDebug(LOG_AW) << "Sensor" << _sensor << "has been removed";
|
||||||
|
|
||||||
m_sensors.remove(_sensor);
|
m_sensors.remove(_sensor);
|
||||||
m_interface->unsubscribe({_sensor});
|
dropSource(_sensor);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void AWDataEngineAggregator::updateData(KSysGuard::SensorDataList _data)
|
void AWDataEngineAggregator::updateData(KSysGuard::SensorDataList _data)
|
||||||
{
|
{
|
||||||
emit(dataUpdated(m_sensors, _data));
|
emit(dataUpdated(m_sensors, _data));
|
||||||
|
@ -15,9 +15,7 @@
|
|||||||
* along with awesome-widgets. If not, see http://www.gnu.org/licenses/ *
|
* along with awesome-widgets. If not, see http://www.gnu.org/licenses/ *
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
#ifndef AWDATAENGINEAGGREGATOR_H
|
|
||||||
#define AWDATAENGINEAGGREGATOR_H
|
|
||||||
|
|
||||||
#include <ksysguard/systemstats/SensorInfo.h>
|
#include <ksysguard/systemstats/SensorInfo.h>
|
||||||
|
|
||||||
@ -31,7 +29,6 @@ namespace KSysGuard::SystemStats
|
|||||||
class DBusInterface;
|
class DBusInterface;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
class AWDataEngineAggregator : public QObject
|
class AWDataEngineAggregator : public QObject
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
@ -39,10 +36,10 @@ class AWDataEngineAggregator : public QObject
|
|||||||
public:
|
public:
|
||||||
explicit AWDataEngineAggregator(QObject *_parent = nullptr);
|
explicit AWDataEngineAggregator(QObject *_parent = nullptr);
|
||||||
~AWDataEngineAggregator() override;
|
~AWDataEngineAggregator() override;
|
||||||
|
void connectSources();
|
||||||
void disconnectSources();
|
void disconnectSources();
|
||||||
[[nodiscard]] bool isValidSensor(const KSysGuard::SensorInfo &_sensor);
|
[[nodiscard]] static bool isValidSensor(const KSysGuard::SensorInfo &_sensor);
|
||||||
void loadSources();
|
void loadSources();
|
||||||
void reconnectSources(const int interval);
|
|
||||||
|
|
||||||
signals:
|
signals:
|
||||||
void dataUpdated(const QHash<QString, KSysGuard::SensorInfo> &_sensors, const KSysGuard::SensorDataList &_data);
|
void dataUpdated(const QHash<QString, KSysGuard::SensorInfo> &_sensors, const KSysGuard::SensorDataList &_data);
|
||||||
@ -58,7 +55,5 @@ public slots:
|
|||||||
private:
|
private:
|
||||||
KSysGuard::SystemStats::DBusInterface *m_interface = nullptr;
|
KSysGuard::SystemStats::DBusInterface *m_interface = nullptr;
|
||||||
QHash<QString, KSysGuard::SensorInfo> m_sensors;
|
QHash<QString, KSysGuard::SensorInfo> m_sensors;
|
||||||
|
QSet<QString> m_subscribed;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
#endif /* AWDATAENGINEAGGREGATOR_H */
|
|
||||||
|
@ -131,15 +131,15 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, const KSy
|
|||||||
key.remove("extsysmon/custom/");
|
key.remove("extsysmon/custom/");
|
||||||
m_map.insert(_source, key);
|
m_map.insert(_source, key);
|
||||||
m_formatter[key] = AWKeysAggregator::FormatterType::NoFormat;
|
m_formatter[key] = AWKeysAggregator::FormatterType::NoFormat;
|
||||||
} else if (_source == "extsysmon/desktop/current/name") {
|
} else if (_source == "extsysmon/desktop/name") {
|
||||||
// current desktop name
|
// current desktop name
|
||||||
m_map.insert(_source, "desktop");
|
m_map.insert(_source, "desktop");
|
||||||
m_formatter["desktop"] = AWKeysAggregator::FormatterType::NoFormat;
|
m_formatter["desktop"] = AWKeysAggregator::FormatterType::NoFormat;
|
||||||
} else if (_source == "extsysmon/desktop/current/number") {
|
} else if (_source == "extsysmon/desktop/number") {
|
||||||
// current desktop number
|
// current desktop number
|
||||||
m_map.insert(_source, "ndesktop");
|
m_map.insert(_source, "ndesktop");
|
||||||
m_formatter["ndesktop"] = AWKeysAggregator::FormatterType::NoFormat;
|
m_formatter["ndesktop"] = AWKeysAggregator::FormatterType::NoFormat;
|
||||||
} else if (_source == "extsysmon/desktop/total/number") {
|
} else if (_source == "extsysmon/desktop/count") {
|
||||||
// desktop count
|
// desktop count
|
||||||
m_map.insert(_source, "tdesktops");
|
m_map.insert(_source, "tdesktops");
|
||||||
m_formatter["tdesktops"] = AWKeysAggregator::FormatterType::NoFormat;
|
m_formatter["tdesktops"] = AWKeysAggregator::FormatterType::NoFormat;
|
||||||
@ -217,7 +217,7 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, const KSy
|
|||||||
} else if (_source.startsWith("extsysmon/hdd/temperature")) {
|
} else if (_source.startsWith("extsysmon/hdd/temperature")) {
|
||||||
// hdd temperature
|
// hdd temperature
|
||||||
QString device = _source;
|
QString device = _source;
|
||||||
device.remove("hdd/temperature");
|
device.remove("extsysmon/hdd/temperature");
|
||||||
int index = m_devices["hdd"].indexOf(device);
|
int index = m_devices["hdd"].indexOf(device);
|
||||||
if (index > -1) {
|
if (index > -1) {
|
||||||
QString key = QString("hddtemp%1").arg(index);
|
QString key = QString("hddtemp%1").arg(index);
|
||||||
@ -313,15 +313,15 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, const KSy
|
|||||||
key.remove("extsysmon/player/");
|
key.remove("extsysmon/player/");
|
||||||
m_map.insert(_source, key);
|
m_map.insert(_source, key);
|
||||||
m_formatter[key] = AWKeysAggregator::FormatterType::NoFormat;
|
m_formatter[key] = AWKeysAggregator::FormatterType::NoFormat;
|
||||||
} else if (_source == "extsysmon/ps/running/count") {
|
} else if (_source == "extsysmon/ps/running") {
|
||||||
// running processes count
|
// running processes count
|
||||||
m_map.insert(_source, "pscount");
|
m_map.insert(_source, "pscount");
|
||||||
m_formatter["pscount"] = AWKeysAggregator::FormatterType::NoFormat;
|
m_formatter["pscount"] = AWKeysAggregator::FormatterType::NoFormat;
|
||||||
} else if (_source == "extsysmon/ps/running/list") {
|
} else if (_source == "extsysmon/ps/list") {
|
||||||
// list of running processes
|
// list of running processes
|
||||||
m_map.insert(_source, "ps");
|
m_map.insert(_source, "ps");
|
||||||
m_formatter["ps"] = AWKeysAggregator::FormatterType::List;
|
m_formatter["ps"] = AWKeysAggregator::FormatterType::List;
|
||||||
} else if (_source == "extsysmon/ps/total/count") {
|
} else if (_source == "extsysmon/ps/count") {
|
||||||
// total processes count
|
// total processes count
|
||||||
m_map.insert(_source, "pstot");
|
m_map.insert(_source, "pstot");
|
||||||
m_formatter["pstot"] = AWKeysAggregator::FormatterType::NoFormat;
|
m_formatter["pstot"] = AWKeysAggregator::FormatterType::NoFormat;
|
||||||
@ -347,7 +347,8 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, const KSy
|
|||||||
// gb
|
// gb
|
||||||
m_map.insert(_source, "swapgb");
|
m_map.insert(_source, "swapgb");
|
||||||
m_formatter["swapgb"] = AWKeysAggregator::FormatterType::MemGBFormat;
|
m_formatter["swapgb"] = AWKeysAggregator::FormatterType::MemGBFormat;
|
||||||
} else if (_source.startsWith("lmsensors/") || _source.contains(cpuTempRegExp) || _source == "cpu/all/averageTemperature") {
|
} else if (_source.startsWith("lmsensors/") || _source.contains(cpuTempRegExp)
|
||||||
|
|| _source == "cpu/all/averageTemperature") {
|
||||||
// temperature
|
// temperature
|
||||||
auto index = m_devices["temp"].indexOf(_source);
|
auto index = m_devices["temp"].indexOf(_source);
|
||||||
// HACK on DE initialization there are no units key
|
// HACK on DE initialization there are no units key
|
||||||
|
@ -302,19 +302,20 @@ void AWKeyOperations::addDevice(const QString &_source)
|
|||||||
{
|
{
|
||||||
qCDebug(LOG_AW) << "Source" << _source;
|
qCDebug(LOG_AW) << "Source" << _source;
|
||||||
|
|
||||||
auto diskRegexp = QRegularExpression("disk/(?:md|sd|hd)[a-z|0-9]_.*/Rate/(?:rblk)");
|
auto diskRegexp = QRegularExpression("disk/.*/read");
|
||||||
auto mountRegexp = QRegularExpression("partitions/.*/filllevel");
|
auto mountRegexp = QRegularExpression("disk/.*/usedPercent");
|
||||||
auto cpuTempRegExp = QRegularExpression("^cpu/cpu.*/temperature$");
|
auto cpuTempRegExp = QRegularExpression("^cpu/cpu.*/temperature$");
|
||||||
|
|
||||||
if (_source.contains(diskRegexp)) {
|
if (_source.contains(diskRegexp)) {
|
||||||
QString device = _source;
|
auto device = _source;
|
||||||
device.remove("/Rate/rblk");
|
device.remove("disk/").remove("/read");
|
||||||
addKeyToCache("disk", device);
|
addKeyToCache("disk", device);
|
||||||
} else if (_source.contains(mountRegexp)) {
|
} else if (_source.contains(mountRegexp)) {
|
||||||
QString device = _source;
|
auto device = _source;
|
||||||
device.remove("partitions").remove("/filllevel");
|
device.remove("disk/").remove("/usedPercent");
|
||||||
addKeyToCache("mount", device);
|
addKeyToCache("mount", device);
|
||||||
} else if (_source.startsWith("lmsensors") || _source.contains(cpuTempRegExp) || _source == "cpu/all/averageTemperature") {
|
} else if (_source.startsWith("lmsensors") || _source.contains(cpuTempRegExp)
|
||||||
|
|| _source == "cpu/all/averageTemperature") {
|
||||||
addKeyToCache("temp", _source);
|
addKeyToCache("temp", _source);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -60,7 +60,8 @@ AWKeys::AWKeys(QObject *_parent)
|
|||||||
connect(m_timer, &QTimer::timeout, this, &AWKeys::updateTextData);
|
connect(m_timer, &QTimer::timeout, this, &AWKeys::updateTextData);
|
||||||
|
|
||||||
// transfer signal from AWDataAggregator object to QML ui
|
// transfer signal from AWDataAggregator object to QML ui
|
||||||
connect(m_dataAggregator, &AWDataAggregator::toolTipPainted, [this](const QString &_tooltip) { emit(needToolTipToBeUpdated(_tooltip)); });
|
connect(m_dataAggregator, &AWDataAggregator::toolTipPainted,
|
||||||
|
[this](const QString &_tooltip) { emit(needToolTipToBeUpdated(_tooltip)); });
|
||||||
|
|
||||||
connect(this, &AWKeys::dropSourceFromDataengine, m_dataEngineAggregator, &AWDataEngineAggregator::dropSource);
|
connect(this, &AWKeys::dropSourceFromDataengine, m_dataEngineAggregator, &AWDataEngineAggregator::dropSource);
|
||||||
connect(m_dataEngineAggregator, &AWDataEngineAggregator::dataUpdated, this, &AWKeys::dataUpdated);
|
connect(m_dataEngineAggregator, &AWDataEngineAggregator::dataUpdated, this, &AWKeys::dataUpdated);
|
||||||
@ -102,7 +103,6 @@ void AWKeys::initKeys(const QString &_currentPattern, const int _interval, const
|
|||||||
m_aggregator->initFormatters();
|
m_aggregator->initFormatters();
|
||||||
m_keyOperator->setPattern(_currentPattern);
|
m_keyOperator->setPattern(_currentPattern);
|
||||||
m_keyOperator->updateCache();
|
m_keyOperator->updateCache();
|
||||||
m_dataEngineAggregator->reconnectSources(_interval);
|
|
||||||
|
|
||||||
// timer
|
// timer
|
||||||
m_timer->setInterval(_interval);
|
m_timer->setInterval(_interval);
|
||||||
|
@ -64,7 +64,6 @@ void ExtSysMonAggregator::init(const QHash<QString, QString> &_config)
|
|||||||
// custom
|
// custom
|
||||||
createSensor("custom", i18n("Scripts"), new CustomSource(this, {}));
|
createSensor("custom", i18n("Scripts"), new CustomSource(this, {}));
|
||||||
// desktop
|
// desktop
|
||||||
// FIXME causes segfault
|
|
||||||
createSensor("desktop", i18n("Desktop"), new DesktopSource(this, {}));
|
createSensor("desktop", i18n("Desktop"), new DesktopSource(this, {}));
|
||||||
// gpu load
|
// gpu load
|
||||||
createSensor("gpuload", i18n("GPU load"), new GPULoadSource(this, {_config["GPUDEV"]}));
|
createSensor("gpuload", i18n("GPU load"), new GPULoadSource(this, {_config["GPUDEV"]}));
|
||||||
|
@ -51,13 +51,13 @@ QVariant DesktopSource::data(const QString &_source)
|
|||||||
auto decrement = KWindowSystem::isPlatformX11() ? 1 : 0;
|
auto decrement = KWindowSystem::isPlatformX11() ? 1 : 0;
|
||||||
auto current = nativeIndex - decrement;
|
auto current = nativeIndex - decrement;
|
||||||
|
|
||||||
if (_source == "current/name") {
|
if (_source == "name") {
|
||||||
return m_vdi->desktopNames().at(current);
|
return m_vdi->desktopNames().at(current);
|
||||||
} else if (_source == "current/number") {
|
} else if (_source == "number") {
|
||||||
return current + 1;
|
return current + 1;
|
||||||
} else if (_source == "total/name") {
|
} else if (_source == "names") {
|
||||||
return m_vdi->desktopNames();
|
return m_vdi->desktopNames();
|
||||||
} else if (_source == "total/number") {
|
} else if (_source == "count") {
|
||||||
return m_vdi->numberOfDesktops();
|
return m_vdi->numberOfDesktops();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -70,20 +70,20 @@ KSysGuard::SensorInfo *DesktopSource::initialData(const QString &_source) const
|
|||||||
qCDebug(LOG_ESS) << "Source" << _source;
|
qCDebug(LOG_ESS) << "Source" << _source;
|
||||||
|
|
||||||
auto data = new KSysGuard::SensorInfo();
|
auto data = new KSysGuard::SensorInfo();
|
||||||
if (_source == "current/name") {
|
if (_source == "name") {
|
||||||
data->name = "Current desktop name";
|
data->name = "Current desktop name";
|
||||||
data->variantType = QVariant::String;
|
data->variantType = QVariant::String;
|
||||||
data->unit = KSysGuard::UnitNone;
|
data->unit = KSysGuard::UnitNone;
|
||||||
} else if (_source == "current/number") {
|
} else if (_source == "number") {
|
||||||
data->min = 0;
|
data->min = 0;
|
||||||
data->name = "Current desktop number";
|
data->name = "Current desktop number";
|
||||||
data->variantType = QVariant::Int;
|
data->variantType = QVariant::Int;
|
||||||
data->unit = KSysGuard::UnitNone;
|
data->unit = KSysGuard::UnitNone;
|
||||||
} else if (_source == "total/name") {
|
} else if (_source == "names") {
|
||||||
data->name = "All desktops by name";
|
data->name = "All desktops by name";
|
||||||
data->variantType = QVariant::StringList;
|
data->variantType = QVariant::StringList;
|
||||||
data->unit = KSysGuard::UnitNone;
|
data->unit = KSysGuard::UnitNone;
|
||||||
} else if (_source == "total/number") {
|
} else if (_source == "count") {
|
||||||
data->min = 0;
|
data->min = 0;
|
||||||
data->name = "Desktops count";
|
data->name = "Desktops count";
|
||||||
data->variantType = QVariant::Int;
|
data->variantType = QVariant::Int;
|
||||||
@ -97,10 +97,10 @@ KSysGuard::SensorInfo *DesktopSource::initialData(const QString &_source) const
|
|||||||
QStringList DesktopSource::sources() const
|
QStringList DesktopSource::sources() const
|
||||||
{
|
{
|
||||||
QStringList sources;
|
QStringList sources;
|
||||||
sources.append("current/name");
|
sources.append("name");
|
||||||
sources.append("current/number");
|
sources.append("number");
|
||||||
sources.append("total/name");
|
sources.append("names");
|
||||||
sources.append("total/number");
|
sources.append("count");
|
||||||
|
|
||||||
return sources;
|
return sources;
|
||||||
}
|
}
|
||||||
|
@ -67,7 +67,6 @@ void ExtSysMonSensor::update()
|
|||||||
continue; // skip properties which are not explicitly subscribed
|
continue; // skip properties which are not explicitly subscribed
|
||||||
|
|
||||||
auto value = m_source->data(source);
|
auto value = m_source->data(source);
|
||||||
qCWarning(LOG_ESS) << source << value;
|
|
||||||
property->setValue(value);
|
property->setValue(value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -52,7 +52,7 @@ NetworkSource::~NetworkSource()
|
|||||||
|
|
||||||
QVariant NetworkSource::data(const QString &_source)
|
QVariant NetworkSource::data(const QString &_source)
|
||||||
{
|
{
|
||||||
qCWarning(LOG_ESS) << "Source" << _source;
|
qCDebug(LOG_ESS) << "Source" << _source;
|
||||||
|
|
||||||
if (!m_values.contains(_source))
|
if (!m_values.contains(_source))
|
||||||
run();
|
run();
|
||||||
@ -82,7 +82,9 @@ KSysGuard::SensorInfo *NetworkSource::initialData(const QString &_source) const
|
|||||||
void NetworkSource::run()
|
void NetworkSource::run()
|
||||||
{
|
{
|
||||||
m_values["device"] = NetworkSource::getCurrentDevice();
|
m_values["device"] = NetworkSource::getCurrentDevice();
|
||||||
m_process->start("iwgetid", {"-r"});
|
if (m_process->state() == QProcess::ProcessState::NotRunning) {
|
||||||
|
m_process->start("iwgetid", {"-r"});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -56,17 +56,17 @@ KSysGuard::SensorInfo *ProcessesSource::initialData(const QString &_source) cons
|
|||||||
qCDebug(LOG_ESS) << "Source" << _source;
|
qCDebug(LOG_ESS) << "Source" << _source;
|
||||||
|
|
||||||
auto data = new KSysGuard::SensorInfo();
|
auto data = new KSysGuard::SensorInfo();
|
||||||
if (_source == "running/count") {
|
if (_source == "running") {
|
||||||
data->min = 0;
|
data->min = 0;
|
||||||
data->max = 0;
|
data->max = 0;
|
||||||
data->name = "Count of running processes";
|
data->name = "Count of running processes";
|
||||||
data->variantType = QVariant::Int;
|
data->variantType = QVariant::Int;
|
||||||
data->unit = KSysGuard::UnitNone;
|
data->unit = KSysGuard::UnitNone;
|
||||||
} else if (_source == "running/list") {
|
} else if (_source == "list") {
|
||||||
data->name = "All running processes list";
|
data->name = "All running processes list";
|
||||||
data->variantType = QVariant::StringList;
|
data->variantType = QVariant::StringList;
|
||||||
data->unit = KSysGuard::UnitNone;
|
data->unit = KSysGuard::UnitNone;
|
||||||
} else if (_source == "total/count") {
|
} else if (_source == "count") {
|
||||||
data->min = 0;
|
data->min = 0;
|
||||||
data->max = 0;
|
data->max = 0;
|
||||||
data->name = "Total count of processes";
|
data->name = "Total count of processes";
|
||||||
@ -99,18 +99,18 @@ void ProcessesSource::run()
|
|||||||
cmdFile.close();
|
cmdFile.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
m_values["running/count"] = running.count();
|
m_values["running"] = running.count();
|
||||||
m_values["running/list"] = running;
|
m_values["list"] = running;
|
||||||
m_values["total/count"] = directories.count();
|
m_values["count"] = directories.count();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
QStringList ProcessesSource::sources() const
|
QStringList ProcessesSource::sources() const
|
||||||
{
|
{
|
||||||
QStringList sources;
|
QStringList sources;
|
||||||
sources.append("running/count");
|
sources.append("running");
|
||||||
sources.append("running/list");
|
sources.append("list");
|
||||||
sources.append("total/count");
|
sources.append("count");
|
||||||
|
|
||||||
return sources;
|
return sources;
|
||||||
}
|
}
|
||||||
|
@ -49,12 +49,10 @@ QVariant WeatherSource::data(const QString &_source)
|
|||||||
|
|
||||||
int ind = index(_source);
|
int ind = index(_source);
|
||||||
if (!m_values.contains(_source)) {
|
if (!m_values.contains(_source)) {
|
||||||
QVariantHash data = m_extWeather->itemByTagNumber(ind)->run();
|
auto data = m_extWeather->itemByTagNumber(ind)->run();
|
||||||
for (auto &key : data.keys())
|
m_values.insert(data);
|
||||||
m_values[key] = data[key];
|
|
||||||
}
|
}
|
||||||
QVariant value = m_values.take(_source);
|
return m_values.take(_source);
|
||||||
return value;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -94,7 +92,7 @@ KSysGuard::SensorInfo *WeatherSource::initialData(const QString &_source) const
|
|||||||
data->unit = KSysGuard::UnitCelsius;
|
data->unit = KSysGuard::UnitCelsius;
|
||||||
} else if (_source.startsWith("timestamp")) {
|
} else if (_source.startsWith("timestamp")) {
|
||||||
data->name = QString("Timestamp for '%1'").arg(m_extWeather->itemByTagNumber(ind)->uniq());
|
data->name = QString("Timestamp for '%1'").arg(m_extWeather->itemByTagNumber(ind)->uniq());
|
||||||
data->variantType = QVariant::String;
|
data->variantType = QVariant::DateTime;
|
||||||
data->unit = KSysGuard::UnitNone;
|
data->unit = KSysGuard::UnitNone;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -20,9 +20,9 @@ include_directories(
|
|||||||
set(AWTESTLIBRARY_HEADERS awtestlibrary.h)
|
set(AWTESTLIBRARY_HEADERS awtestlibrary.h)
|
||||||
set(AWTESTLIBRARY_SOURCES awtestlibrary.cpp)
|
set(AWTESTLIBRARY_SOURCES awtestlibrary.cpp)
|
||||||
add_library(${SUBPROJECT}-awtest STATIC ${AWTESTLIBRARY_SOURCES} ${AWTESTLIBRARY_HEADERS})
|
add_library(${SUBPROJECT}-awtest STATIC ${AWTESTLIBRARY_SOURCES} ${AWTESTLIBRARY_HEADERS})
|
||||||
target_link_libraries(${SUBPROJECT}-awtest ${Qt_LIBRARIES} ${Qt5Test_LIBRARIES} ${Kf6_LIBRARIES})
|
target_link_libraries(${SUBPROJECT}-awtest ${Qt_LIBRARIES} ${Qt6Test_LIBRARIES} ${Kf6_LIBRARIES})
|
||||||
set(LIBRARY_TEST_SET ${SUBPROJECT}-awtest ${PROJECT_LIBRARY} ${PROJECT_MONITORSOURCES}
|
set(LIBRARY_TEST_SET ${SUBPROJECT}-awtest ${PROJECT_LIBRARY} ${PROJECT_MONITORSOURCES}
|
||||||
${Qt_LIBRARIES} ${Kf6_LIBRARIES} ${Qt5Test_LIBRARIES})
|
${Qt_LIBRARIES} ${Kf6_LIBRARIES} ${Qt6Test_LIBRARIES})
|
||||||
|
|
||||||
# modules
|
# modules
|
||||||
set(TEST_MODULES
|
set(TEST_MODULES
|
||||||
|
Reference in New Issue
Block a user