summaryrefslogtreecommitdiff
path: root/kde-plasma/plasma-pa
diff options
context:
space:
mode:
authorV3n3RiX <venerix@redcorelinux.org>2019-04-05 21:17:31 +0100
committerV3n3RiX <venerix@redcorelinux.org>2019-04-05 21:17:31 +0100
commitdc7cbdfa65fd814b3b9aa3c56257da201109e807 (patch)
treec85d72f6f31f21f178069c9d41d41a7c1ff4b362 /kde-plasma/plasma-pa
parent0706fc6986773f4e4d391deff4ad5143c464ea4e (diff)
gentoo resync : 05.04.2019
Diffstat (limited to 'kde-plasma/plasma-pa')
-rw-r--r--kde-plasma/plasma-pa/Manifest5
-rw-r--r--kde-plasma/plasma-pa/files/plasma-pa-5.15.4-gsettings.patch622
-rw-r--r--kde-plasma/plasma-pa/plasma-pa-5.15.4-r1.ebuild (renamed from kde-plasma/plasma-pa/plasma-pa-5.15.3.ebuild)4
3 files changed, 628 insertions, 3 deletions
diff --git a/kde-plasma/plasma-pa/Manifest b/kde-plasma/plasma-pa/Manifest
index 3b2066461c37..284035f82b63 100644
--- a/kde-plasma/plasma-pa/Manifest
+++ b/kde-plasma/plasma-pa/Manifest
@@ -1,6 +1,7 @@
AUX plasma-pa-5.13.3-automagic_gconf.patch 530 BLAKE2B 49fa6547b997c0f31627941b333c30ce0ba1165910c235a8319e4855fc5b5acb8c8355b47cd87e57aa49d1f320ed9d6b395887376ef55a5098c436bcfa7d4e4a SHA512 5baaeafc2e4426251d445f954ce25b6561e9e5e36064f803068d8d60d6186cecc4d7eb97da20406160c166800bfa4e54543566f21ac4afa398c3cf4588d23546
+AUX plasma-pa-5.15.4-gsettings.patch 20407 BLAKE2B 872458be40b049d415e24559f9d285554f5449d26bde238bf09488c6f1453c0e040561425e188cf926a76a15e3957da2e8ff106e5f8d074a19b7453d43cc91ed SHA512 19b42891eaf3f53ee582fb96d63b2def3e28c037252f11dabf17e2b00a7b84c763fefd71e779a421fc6706809fdad8800625e94b6ea276e03d6461d3e566dd66
DIST plasma-pa-5.14.5.tar.xz 94368 BLAKE2B a8a1bf8ef2b6a9496941f4a35bfb1e92a4cf7a8d3b9ea014cff6d04ab7b01f0c3e12433eafd3a0f529f9391624e82f0d5f7a6314b8b717e58cb733636c18a1fc SHA512 436ef77d61d37bc4cb166ebffbbd0b0f51780008e902f791af66bebd0429f8cda608674790c87e89ddd40dd614eeb61eeb11e173c02f43d03cab420a2ffa196c
-DIST plasma-pa-5.15.3.tar.xz 95232 BLAKE2B cc183a2dfbfafd920c889e696c536d29cd6ec46cfd86a44c840670e9b8ceb710c506e38983732869f1666f3e0c0df6db34875e7d5d485d1125b4c6d3d6038ae4 SHA512 741e89c0c87858a0688aa030fd15de7fd7e552172cfea2b3d4e9cdc9e695a07c4352fd1603818db86d4365a4438d567f020961b77a67646b72b962e7c1d3f5b3
+DIST plasma-pa-5.15.4.tar.xz 95616 BLAKE2B d671379b2ac0fe4e6166e19a006b1768f1a9fff01a289c72bb5e90366908ee37df6feb897af6b6a40ecca20767ebc235364934d5066cfe94032c0df464872c58 SHA512 fa36e83eda2b560ef679c77680917544270a8e94cbd5a826fbf4641d814031816af6052363dfc9c35b45d276af41b70beba7801c80189439c474635c9e66b665
EBUILD plasma-pa-5.14.5.ebuild 669 BLAKE2B 742bf4b4a257921f1ffa83385259573492ed0d34694ab304b68d5d2e957ef56a77c4d8e58d9ee4f429852204138a3c12e63f176bd2464262afe474472ad23c41 SHA512 1695fd9426f50cef53ba9896d34bc6a0dcbcd5757fe9e22049d64e6b9fed922d7466b5136d272b0aef312ef71b880732f8994c2a4aa5b2fdecbebc5c2ef00aca
-EBUILD plasma-pa-5.15.3.ebuild 801 BLAKE2B c27a4f424cabf7d5a5e2a6f3bac40105a81b15aa8542e7a3024a818704d53ef4ed5edfeac4aeca9fd763af8c5a5daed345a5c50e1b60c8cb0b4b39ecb9ac107b SHA512 e8e96ae1d00862463261df69728043fa2911c6a3fdccdc9dc326c8e9f156bd969160aae0b166e6eeffd9a2a32b24bdde4431978aa1561c5b83d718c97439946a
+EBUILD plasma-pa-5.15.4-r1.ebuild 852 BLAKE2B 30d929da7e2c3bb6a4f8e27d8067041b90c0c1f7dd263b17136200fdb2394f772249f65b7b6161b3e97767830f20596f4d057b91038bed7f0d593c4ef3d5784c SHA512 0a4f8f1b9325c766a5deaacacc225e47960e43d342f5d2759695aa9711c73556fa89930ed1481a01a9907054b5fde20f3dd6d4a6d60e7083b54a128aba4a26dd
MISC metadata.xml 249 BLAKE2B ad415db89e5dee1627aa77f44ded9d4e1e5b8217d06c7ca25bbaa3fe92ce67c2b1090957c45a821b407d7927e5af798498aa6a5b903895ee1af8ee20a446c7f7 SHA512 76a5a340b13f0053ca3c5e94ed24380ea8d29b45ac8655419e22eaadb1e4a827c04d2e7e36b65145c4964e6526f656618fc6ac144e277ef53cb7373e6239e3c3
diff --git a/kde-plasma/plasma-pa/files/plasma-pa-5.15.4-gsettings.patch b/kde-plasma/plasma-pa/files/plasma-pa-5.15.4-gsettings.patch
new file mode 100644
index 000000000000..5ecb0ea216bc
--- /dev/null
+++ b/kde-plasma/plasma-pa/files/plasma-pa-5.15.4-gsettings.patch
@@ -0,0 +1,622 @@
+From c6f41bea3371e6e1948a99ac64d5882d76d9c66e Mon Sep 17 00:00:00 2001
+From: Nicolas Fella <nicolas.fella@gmx.de>
+Date: Sun, 31 Mar 2019 16:19:55 +0200
+Subject: [PATCH] Port from GConf to GSettings
+
+Summary:
+CCBUG: 386665
+
+As discussed in bug 386665 GConf is deprecated and needs to be replaced by GSettings to keep features enabled.
+
+Question: Do we need GConf as a fallback for PA versions without module-gsettings?
+
+Test Plan:
+Checkboxes in Advanced tab are enabled again.
+Changed settings are shown in dconf-editor and vice versa.
+Combine output checkbox shows/hides combined sink in applet
+
+Reviewers: drosca, davidedmundson
+
+Reviewed By: drosca
+
+Subscribers: pino, lbeltrame, evpokp, rikmills, broulik, asturmlechner, plasma-devel
+
+Tags: #plasma
+
+Differential Revision: https://phabricator.kde.org/D14147
+---
+ CMakeLists.txt | 15 ++--
+ cmake/FindGIO.cmake | 72 +++++++++++++++++++
+ config.h.cmake | 3 +-
+ src/CMakeLists.txt | 18 ++++-
+ src/gsettingsitem.cpp | 91 ++++++++++++++++++++++++
+ src/gsettingsitem.h | 59 +++++++++++++++
+ src/kcm/package/contents/ui/Advanced.qml | 8 +--
+ src/modulemanager.cpp | 79 +++++++++++++-------
+ src/modulemanager.h | 14 ++--
+ 9 files changed, 315 insertions(+), 44 deletions(-)
+ create mode 100644 cmake/FindGIO.cmake
+ create mode 100644 src/gsettingsitem.cpp
+ create mode 100644 src/gsettingsitem.h
+
+diff --git a/CMakeLists.txt b/CMakeLists.txt
+index 9973ef7..d33dc1d 100644
+--- a/CMakeLists.txt
++++ b/CMakeLists.txt
+@@ -20,11 +20,6 @@ include(KDECompilerSettings NO_POLICY_SCOPE)
+ include(ECMOptionalAddSubdirectory)
+
+ include(FindPkgConfig)
+-pkg_check_modules(GCONF gconf-2.0)
+-pkg_check_modules(GOBJECT gobject-2.0)
+-if (GCONF_FOUND AND GOBJECT_FOUND)
+- set(HAVE_GCONF TRUE)
+-endif()
+
+ find_package(Qt5 ${QT_MIN_VERSION} REQUIRED COMPONENTS
+ Core
+@@ -45,6 +40,16 @@ find_package(PulseAudio 5.0.0 REQUIRED)
+ find_package(Canberra REQUIRED)
+ find_package(GLIB2 REQUIRED)
+
++option(USE_GCONF "Use legacy GConf instead of GSettings")
++
++pkg_check_modules(GOBJECT gobject-2.0 REQUIRED)
++if(USE_GCONF)
++ pkg_check_modules(GCONF gconf-2.0 REQUIRED)
++else()
++ find_package(GIO REQUIRED)
++ set(USE_GSETTINGS True)
++endif()
++
+ find_package(CanberraPulse)
+ set_package_properties(CanberraPulse PROPERTIES
+ DESCRIPTION "Pulseaudio backend for libcanberra"
+diff --git a/cmake/FindGIO.cmake b/cmake/FindGIO.cmake
+new file mode 100644
+index 0000000..827c243
+--- /dev/null
++++ b/cmake/FindGIO.cmake
+@@ -0,0 +1,72 @@
++# - Try to find the GIO libraries
++# Once done this will define
++#
++# GIO_FOUND - system has GIO
++# GIO_INCLUDE_DIR - the GIO include directory
++# GIO_LIBRARIES - GIO library
++#
++# Copyright (c) 2010 Dario Freddi <drf@kde.org>
++#
++# Redistribution and use is allowed according to the terms of the BSD license.
++# For details see the accompanying COPYING-CMAKE-SCRIPTS file.
++
++if(GIO_INCLUDE_DIR AND GIO_LIBRARIES)
++ # Already in cache, be silent
++ set(GIO_FIND_QUIETLY TRUE)
++endif(GIO_INCLUDE_DIR AND GIO_LIBRARIES)
++
++if (NOT WIN32)
++ include(UsePkgConfig)
++ pkgconfig(gio-2.0 _LibGIOIncDir _LibGIOLinkDir _LibGIOLinkFlags _LibGIOCflags)
++endif(NOT WIN32)
++
++MESSAGE(STATUS "gio include dir: ${_LibGIOIncDir}")
++
++# first try without default paths to respect PKG_CONFIG_PATH
++
++find_path(GIO_MAIN_INCLUDE_DIR glib.h
++ PATH_SUFFIXES glib-2.0
++ PATHS ${_LibGIOIncDir}
++ NO_DEFAULT_PATH)
++
++find_path(GIO_MAIN_INCLUDE_DIR glib.h
++ PATH_SUFFIXES glib-2.0
++ PATHS ${_LibGIOIncDir} )
++
++MESSAGE(STATUS "found gio main include dir: ${GIO_MAIN_INCLUDE_DIR}")
++
++# search the glibconfig.h include dir under the same root where the library is found
++find_library(GIO_LIBRARIES
++ NAMES gio-2.0
++ PATHS ${_LibGIOLinkDir}
++ NO_DEFAULT_PATH)
++
++find_library(GIO_LIBRARIES
++ NAMES gio-2.0
++ PATHS ${_LibGIOLinkDir})
++
++
++get_filename_component(GIOLibDir "${GIO_LIBRARIES}" PATH)
++
++find_path(GIO_INTERNAL_INCLUDE_DIR glibconfig.h
++ PATH_SUFFIXES glib-2.0/include
++ PATHS ${_LibGIOIncDir} "${GIOLibDir}" ${CMAKE_SYSTEM_LIBRARY_PATH}
++ NO_DEFAULT_PATH)
++
++find_path(GIO_INTERNAL_INCLUDE_DIR glibconfig.h
++ PATH_SUFFIXES glib-2.0/include
++ PATHS ${_LibGIOIncDir} "${GIOLibDir}" ${CMAKE_SYSTEM_LIBRARY_PATH})
++
++set(GIO_INCLUDE_DIR "${GIO_MAIN_INCLUDE_DIR}")
++
++# not sure if this include dir is optional or required
++# for now it is optional
++if(GIO_INTERNAL_INCLUDE_DIR)
++ set(GIO_INCLUDE_DIR ${GIO_INCLUDE_DIR} "${GIO_INTERNAL_INCLUDE_DIR}")
++endif(GIO_INTERNAL_INCLUDE_DIR)
++
++include(FindPackageHandleStandardArgs)
++find_package_handle_standard_args(GIO DEFAULT_MSG GIO_LIBRARIES GIO_MAIN_INCLUDE_DIR)
++
++mark_as_advanced(GIO_INCLUDE_DIR GIO_LIBRARIES)
++
+diff --git a/config.h.cmake b/config.h.cmake
+index 1643e50..7d801c3 100644
+--- a/config.h.cmake
++++ b/config.h.cmake
+@@ -1,3 +1,4 @@
+ /* config.h. Generated by cmake from config.h.cmake */
+
+-#cmakedefine01 HAVE_GCONF
++#cmakedefine01 USE_GSETTINGS
++#cmakedefine01 USE_GCONF
+diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt
+index 8684251..d4a6c4b 100644
+--- a/src/CMakeLists.txt
++++ b/src/CMakeLists.txt
+@@ -37,11 +37,16 @@ set(qml_SRCS
+ set_property(SOURCE qml/dbus/osdService.xml APPEND PROPERTY CLASSNAME OsdServiceInterface)
+ qt5_add_dbus_interface(dbus_SRCS qml/dbus/osdService.xml osdservice)
+
+-if (HAVE_GCONF)
++if (USE_GCONF)
+ include_directories(${GCONF_INCLUDE_DIRS} ${GOBJECT_INCLUDE_DIRS})
+ set(cpp_SRCS ${cpp_SRCS} gconfitem.cpp)
+ endif()
+
++if (USE_GSETTINGS)
++ include_directories(${GIO_INCLUDE_DIRS} ${GOBJECT_INCLUDE_DIRS})
++ set(cpp_SRCS ${cpp_SRCS} gsettingsitem.cpp)
++endif()
++
+ add_library(plasma-volume-declarative SHARED ${dbus_SRCS} ${cpp_SRCS} ${qml_SRCS})
+ target_link_libraries(plasma-volume-declarative
+ Qt5::Core
+@@ -52,12 +57,19 @@ target_link_libraries(plasma-volume-declarative
+ ${PULSEAUDIO_LIBRARY}
+ ${PULSEAUDIO_MAINLOOP_LIBRARY}
+ ${CANBERRA_LIBRARIES}
++ ${GOBJECT_LIBRARIES}
+ )
+
+-if (HAVE_GCONF)
++if (USE_GCONF)
+ target_link_libraries(plasma-volume-declarative
+ ${GCONF_LDFLAGS}
+- ${GOBJECT_LDFLAGS}
++ )
++endif()
++
++if (USE_GSETTINGS)
++ target_link_libraries(plasma-volume-declarative
++ ${GIO_LIBRARIES}
++ GLIB2::GLIB2
+ )
+ endif()
+
+diff --git a/src/gsettingsitem.cpp b/src/gsettingsitem.cpp
+new file mode 100644
+index 0000000..b3a9353
+--- /dev/null
++++ b/src/gsettingsitem.cpp
+@@ -0,0 +1,91 @@
++/*
++ * Copyright (C) 2018 Nicolas Fella <nicolas.fella@gmx.de>
++ *
++ * This library is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public License
++ * version 2.1 as published by the Free Software Foundation.
++ *
++ * This library 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
++ * Lesser General Public License for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with this library; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
++ * 02110-1301 USA
++ *
++ */
++
++#include <QString>
++#include <QVariant>
++
++#include <gio/gio.h>
++
++#include "gsettingsitem.h"
++#include "debug.h"
++
++QVariant GSettingsItem::value(const QString &key) const
++{
++ GVariant *gvalue = g_settings_get_value(m_settings, key.toLatin1().data());
++
++ QVariant toReturn;
++
++ switch (g_variant_classify(gvalue)) {
++ case G_VARIANT_CLASS_BOOLEAN:
++ toReturn = QVariant((bool)g_variant_get_boolean(gvalue));
++ break;
++ case G_VARIANT_CLASS_STRING:
++ toReturn = QVariant(QString::fromUtf8(g_variant_get_string(gvalue, nullptr)));
++ break;
++ default:
++ qCWarning(PLASMAPA()) << "Unhandled variant type in value()";
++ }
++
++ g_variant_unref(gvalue);
++
++ return toReturn;
++}
++
++void GSettingsItem::set(const QString &key, const QVariant &val)
++{
++ // It might be hard to detect the right GVariant type from
++ // complext QVariant types such as string lists or more detailed
++ // types such as integers (GVariant has different sizes),
++ // therefore we get the current value for the key and convert
++ // to QVariant using the GVariant type
++ GVariant *oldValue = g_settings_get_value(m_settings, key.toLatin1().data());
++ GVariant *newValue = nullptr;
++
++ switch (g_variant_type_peek_string(g_variant_get_type(oldValue))[0]) {
++ case G_VARIANT_CLASS_BOOLEAN:
++ newValue = g_variant_new_boolean(val.toBool());
++ break;
++ case G_VARIANT_CLASS_STRING:
++ newValue = g_variant_new_string(val.toString().toUtf8().constData());
++ break;
++ default:
++ qCWarning(PLASMAPA()) << "Unhandled variant type in set()";
++ }
++
++ if (newValue) {
++ g_settings_set_value(m_settings, key.toLatin1().data(), newValue);
++ }
++
++ g_variant_unref(oldValue);
++}
++
++GSettingsItem::GSettingsItem(const QString &key, QObject *parent)
++ : QObject (parent)
++{
++ m_settings = g_settings_new_with_path("org.freedesktop.pulseaudio.module-group", key.toLatin1().data());
++
++ g_signal_connect(m_settings, "changed", G_CALLBACK(GSettingsItem::settingChanged), this);
++}
++
++GSettingsItem::~GSettingsItem()
++{
++ g_settings_sync();
++ if (m_settings)
++ g_object_unref(m_settings);
++}
+diff --git a/src/gsettingsitem.h b/src/gsettingsitem.h
+new file mode 100644
+index 0000000..9afcfc2
+--- /dev/null
++++ b/src/gsettingsitem.h
+@@ -0,0 +1,59 @@
++/*
++ * Copyright (C) 2018 Nicolas Fella <nicolas.fella@gmx.de>
++ *
++ * This library is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public License
++ * version 2.1 as published by the Free Software Foundation.
++ *
++ * This library 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
++ * Lesser General Public License for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with this library; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
++ * 02110-1301 USA
++ *
++ */
++
++#ifndef GSETTINGSITEM_H
++#define GSETTINGSITEM_H
++
++#include <QVariant>
++#include <QStringList>
++#include <QObject>
++
++#include <gio/gio.h>
++
++class GSettingsItem : public QObject
++{
++ Q_OBJECT
++
++ public:
++
++ explicit GSettingsItem(const QString &key, QObject *parent = nullptr);
++ virtual ~GSettingsItem() override;
++
++ QVariant value(const QString &key) const;
++ void set(const QString &key, const QVariant &val);
++
++
++Q_SIGNALS:
++ void subtreeChanged();
++
++private:
++ GSettings *m_settings;
++
++static void settingChanged(GSettings *settings, const gchar *key, gpointer data)
++{
++ Q_UNUSED(settings)
++ Q_UNUSED(key)
++
++ GSettingsItem *self = static_cast<GSettingsItem *>(data);
++ Q_EMIT self->subtreeChanged();
++}
++
++};
++
++#endif // GCONFITEM_H
+diff --git a/src/kcm/package/contents/ui/Advanced.qml b/src/kcm/package/contents/ui/Advanced.qml
+index 536ae3e..48512e7 100644
+--- a/src/kcm/package/contents/ui/Advanced.qml
++++ b/src/kcm/package/contents/ui/Advanced.qml
+@@ -73,7 +73,7 @@ ScrollView {
+ text: i18nd("kcm_pulseaudio", "Add virtual output device for simultaneous output on all local sound cards")
+ checked: moduleManager.combineSinks
+ onCheckedChanged: moduleManager.combineSinks = checked;
+- enabled: moduleManager.loadedModules.indexOf("module-gconf") != -1
++ enabled: moduleManager.configModuleLoaded
+ visible: moduleManager.settingsSupported
+ }
+
+@@ -84,7 +84,7 @@ ScrollView {
+ text: i18nd("kcm_pulseaudio", "Automatically switch all running streams when a new output becomes available")
+ checked: moduleManager.switchOnConnect
+ onCheckedChanged: moduleManager.switchOnConnect = checked;
+- enabled: moduleManager.loadedModules.indexOf("module-gconf") != -1
++ enabled: moduleManager.configModuleLoaded
+ visible: moduleManager.settingsSupported
+ }
+
+@@ -92,8 +92,8 @@ ScrollView {
+ Layout.alignment: Qt.AlignHCenter
+ enabled: false
+ font.italic: true
+- text: i18nd("kcm_pulseaudio", "Requires 'module-gconf' PulseAudio module")
+- visible: moduleManager.settingsSupported && moduleManager.loadedModules.indexOf("module-gconf") == -1
++ text: i18nd("kcm_pulseaudio", "Requires %1 PulseAudio module", moduleManager.configModuleName)
++ visible: moduleManager.settingsSupported && !moduleManager.configModuleLoaded
+ }
+
+ Header {
+diff --git a/src/modulemanager.cpp b/src/modulemanager.cpp
+index 5245ac5..a43182e 100644
+--- a/src/modulemanager.cpp
++++ b/src/modulemanager.cpp
+@@ -23,10 +23,15 @@
+ #include "module.h"
+ #include "../config.h"
+
+-#if HAVE_GCONF
++#if USE_GSETTINGS
++#include "gsettingsitem.h"
++
++#define PA_SETTINGS_PATH_MODULES "/org/freedesktop/pulseaudio/module-groups"
++#endif
++
++#if USE_GCONF
+ #include "gconfitem.h"
+-#define PA_GCONF_ROOT "/system/pulseaudio"
+-#define PA_GCONF_PATH_MODULES PA_GCONF_ROOT"/modules"
++#define PA_SETTINGS_PATH_MODULES "/system/pulseaudio/modules"
+ #endif
+
+ #include <QTimer>
+@@ -34,29 +39,38 @@
+ namespace QPulseAudio
+ {
+
+-#if HAVE_GCONF
+-class GConfModule : public GConfItem
++#if USE_GCONF || USE_GSETTINGS
++
++#if USE_GSETTINGS
++class ConfigModule : public GSettingsItem
++#elif USE_GCONF
++class ConfigModule : public GConfItem
++#endif
+ {
+ public:
+- GConfModule(const QString &configName, const QString &moduleName, QObject *parent);
++ ConfigModule(const QString &configName, const QString &moduleName, QObject *parent);
+ bool isEnabled() const;
+ void setEnabled(bool enabled, const QVariant &args=QVariant());
+ private:
+ QString m_moduleName;
+ };
+
+-GConfModule::GConfModule(const QString &configName, const QString &moduleName, QObject *parent) :
+- GConfItem(QStringLiteral(PA_GCONF_PATH_MODULES"/") + configName, parent),
++ConfigModule::ConfigModule(const QString &configName, const QString &moduleName, QObject *parent) :
++#if USE_GSETTINGS
++ GSettingsItem(QStringLiteral(PA_SETTINGS_PATH_MODULES"/") + configName + QStringLiteral("/"), parent),
++#elif USE_GCONF
++ GConfItem(QStringLiteral(PA_SETTINGS_PATH_MODULES"/") + configName, parent),
++#endif
+ m_moduleName(moduleName)
+ {
+ }
+
+-bool GConfModule::isEnabled() const
++bool ConfigModule::isEnabled() const
+ {
+ return value(QStringLiteral("enabled")).toBool();
+ }
+
+-void GConfModule::setEnabled(bool enabled, const QVariant &args)
++void ConfigModule::setEnabled(bool enabled, const QVariant &args)
+ {
+ set(QStringLiteral("locked"), true);
+
+@@ -69,20 +83,20 @@ void GConfModule::setEnabled(bool enabled, const QVariant &args)
+ }
+ set(QStringLiteral("locked"), false);
+ }
+-#endif
+
++#endif
+
+ ModuleManager::ModuleManager(QObject *parent) :
+ QObject(parent)
+ {
+-#if HAVE_GCONF
+- m_combineSinks = new GConfModule(QStringLiteral("combine"), QStringLiteral("module-combine"), this);
+- m_switchOnConnect = new GConfModule(QStringLiteral("switch-on-connect"), QStringLiteral("module-switch-on-connect"), this);
+- m_deviceManager = new GConfModule(QStringLiteral("device-manager"), QStringLiteral("module-device-manager"), this);
+-
+- connect(m_combineSinks, &GConfItem::subtreeChanged, this, &ModuleManager::combineSinksChanged);
+- connect(m_switchOnConnect, &GConfItem::subtreeChanged, this, &ModuleManager::switchOnConnectChanged);
+- connect(m_deviceManager, &GConfItem::subtreeChanged, this, &ModuleManager::switchOnConnectChanged);
++#if USE_GCONF || USE_GSETTINGS
++ m_combineSinks = new ConfigModule(QStringLiteral("combine"), QStringLiteral("module-combine"), this);
++ m_switchOnConnect = new ConfigModule(QStringLiteral("switch-on-connect"), QStringLiteral("module-switch-on-connect"), this);
++ m_deviceManager = new ConfigModule(QStringLiteral("device-manager"), QStringLiteral("module-device-manager"), this);
++
++ connect(m_combineSinks, &ConfigModule::subtreeChanged, this, &ModuleManager::combineSinksChanged);
++ connect(m_switchOnConnect, &ConfigModule::subtreeChanged, this, &ModuleManager::switchOnConnectChanged);
++ connect(m_deviceManager, &ConfigModule::subtreeChanged, this, &ModuleManager::switchOnConnectChanged);
+ #endif
+
+ QTimer *updateModulesTimer = new QTimer(this);
+@@ -100,7 +114,7 @@ ModuleManager::~ModuleManager()
+
+ bool ModuleManager::settingsSupported() const
+ {
+-#if HAVE_GCONF
++#if USE_GCONF || USE_GSETTINGS
+ return true;
+ #else
+ return false;
+@@ -109,7 +123,7 @@ bool ModuleManager::settingsSupported() const
+
+ bool ModuleManager::combineSinks() const
+ {
+-#if HAVE_GCONF
++#if USE_GCONF || USE_GSETTINGS
+ return m_combineSinks->isEnabled();
+ #else
+ return false;
+@@ -118,21 +132,21 @@ bool ModuleManager::combineSinks() const
+
+ void ModuleManager::setCombineSinks(bool combineSinks)
+ {
+-#if HAVE_GCONF
++#if USE_GCONF || USE_GSETTINGS
+ m_combineSinks->setEnabled(combineSinks);
+ #else
+- Q_UNUSED(combineSinks)
++ Q_UNUSED(combineSinks()
+ #endif
+ }
+
+ bool ModuleManager::switchOnConnect() const
+ {
++#if USE_GCONF || USE_GSETTINGS
+ //switch on connect and device-manager do the same task. Only one should be enabled
+
+ //Note on the first run m_deviceManager will appear to be disabled even though it's actually running
+ //because there is no gconf entry, however m_switchOnConnect will only exist if set by Plasma PA
+ //hence only check this entry
+-#if HAVE_GCONF
+ return m_switchOnConnect->isEnabled() ;
+ #else
+ return false;
+@@ -141,7 +155,7 @@ bool ModuleManager::switchOnConnect() const
+
+ void ModuleManager::setSwitchOnConnect(bool switchOnConnect)
+ {
+-#if HAVE_GCONF
++#if USE_GCONF || USE_GSETTINGS
+ m_deviceManager->setEnabled(!switchOnConnect);
+ m_switchOnConnect->setEnabled(switchOnConnect);
+ #else
+@@ -164,4 +178,19 @@ void ModuleManager::updateLoadedModules()
+ Q_EMIT loadedModulesChanged();
+ }
+
++bool ModuleManager::configModuleLoaded() const
++{
++ return m_loadedModules.contains(configModuleName());
++}
++
++QString ModuleManager::configModuleName() const
++{
++#if USE_GCONF
++ return QStringLiteral("module-gconf");
++#elif USE_GSETTINGS
++ return QStringLiteral("module-gsettings");
++#else
++ return QString();
++#endif
++}
+ }
+diff --git a/src/modulemanager.h b/src/modulemanager.h
+index 17efd6d..291936e 100644
+--- a/src/modulemanager.h
++++ b/src/modulemanager.h
+@@ -29,11 +29,9 @@
+ // Properties need fully qualified classes even with pointers.
+ #include "client.h"
+
+-class GConfItem;
+-
+ namespace QPulseAudio
+ {
+-class GConfModule;
++class ConfigModule;
+
+ class ModuleManager : public QObject
+ {
+@@ -41,6 +39,8 @@ class ModuleManager : public QObject
+ Q_PROPERTY(bool settingsSupported READ settingsSupported CONSTANT)
+ Q_PROPERTY(bool combineSinks READ combineSinks WRITE setCombineSinks NOTIFY combineSinksChanged)
+ Q_PROPERTY(bool switchOnConnect READ switchOnConnect WRITE setSwitchOnConnect NOTIFY switchOnConnectChanged)
++ Q_PROPERTY(bool configModuleLoaded READ configModuleLoaded NOTIFY loadedModulesChanged)
++ Q_PROPERTY(QString configModuleName READ configModuleName CONSTANT)
+ Q_PROPERTY(QStringList loadedModules READ loadedModules NOTIFY loadedModulesChanged)
+ public:
+ explicit ModuleManager(QObject *parent = nullptr);
+@@ -52,6 +52,8 @@ public:
+ bool switchOnConnect() const;
+ void setSwitchOnConnect(bool switchOnConnect);
+ QStringList loadedModules() const;
++ bool configModuleLoaded() const;
++ QString configModuleName() const;
+
+ Q_SIGNALS:
+ void combineSinksChanged();
+@@ -61,9 +63,9 @@ Q_SIGNALS:
+ private:
+ void updateLoadedModules();
+
+- GConfModule *m_combineSinks;
+- GConfModule *m_switchOnConnect;
+- GConfModule *m_deviceManager;
++ ConfigModule *m_combineSinks;
++ ConfigModule *m_switchOnConnect;
++ ConfigModule *m_deviceManager;
+ QStringList m_loadedModules;
+ };
+
+--
+2.21.0
diff --git a/kde-plasma/plasma-pa/plasma-pa-5.15.3.ebuild b/kde-plasma/plasma-pa/plasma-pa-5.15.4-r1.ebuild
index 58e2347df232..3596f6d6bd74 100644
--- a/kde-plasma/plasma-pa/plasma-pa-5.15.3.ebuild
+++ b/kde-plasma/plasma-pa/plasma-pa-5.15.4-r1.ebuild
@@ -3,6 +3,7 @@
EAPI=7
+CMAKE_REMOVE_MODULES_LIST=( FindGLIB2 )
KDE_HANDBOOK="forceoptional"
inherit kde5
@@ -20,6 +21,7 @@ DEPEND="
$(add_qt_dep qtdeclarative)
$(add_qt_dep qtgui)
$(add_qt_dep qtwidgets)
+ dev-libs/glib:2
media-libs/libcanberra
media-sound/pulseaudio
"
@@ -30,4 +32,4 @@ RDEPEND="${DEPEND}
x11-themes/sound-theme-freedesktop
"
-PATCHES=( "${FILESDIR}/${PN}-5.13.3-automagic_gconf.patch" )
+PATCHES=( "${FILESDIR}/${PN}-5.15.4-gsettings.patch" )