diff options
Diffstat (limited to 'kde-plasma/plasma-workspace/files/plasma-workspace-5.8.3-krunner-crash.patch')
-rw-r--r-- | kde-plasma/plasma-workspace/files/plasma-workspace-5.8.3-krunner-crash.patch | 452 |
1 files changed, 17 insertions, 435 deletions
diff --git a/kde-plasma/plasma-workspace/files/plasma-workspace-5.8.3-krunner-crash.patch b/kde-plasma/plasma-workspace/files/plasma-workspace-5.8.3-krunner-crash.patch index 9b238b68b698..2d4f7eca0b32 100644 --- a/kde-plasma/plasma-workspace/files/plasma-workspace-5.8.3-krunner-crash.patch +++ b/kde-plasma/plasma-workspace/files/plasma-workspace-5.8.3-krunner-crash.patch @@ -1,441 +1,23 @@ -From 3f859c3dbdded68cc96d4c695ff27d15c387da09 Mon Sep 17 00:00:00 2001 -From: Aleix Pol <aleixpol@kde.org> -Date: Mon, 10 Oct 2016 16:30:24 +0200 -Subject: [PATCH] Port to new plasma-framework API - -Reduces unnecessary castings. -Ports away the WindowedWidgets runner from KService - -REVIEW: 129101 ---- - applets/systemtray/systemtray.cpp | 30 +++++++------- - .../shellprivate/widgetexplorer/widgetexplorer.cpp | 14 +++---- - plasma-windowed/plasmawindowedcorona.cpp | 2 +- - runners/windowedwidgets/windowedwidgetsrunner.cpp | 46 ++++++++++------------ - runners/windowedwidgets/windowedwidgetsrunner.h | 2 +- - shell/alternativeshelper.cpp | 6 +-- - shell/containmentconfigview.cpp | 2 +- - shell/scripting/containment.cpp | 4 +- - shell/scripting/widget.cpp | 2 +- - shell/shellcorona.cpp | 15 +++---- - 10 files changed, 60 insertions(+), 63 deletions(-) - -diff --git a/applets/systemtray/systemtray.cpp b/applets/systemtray/systemtray.cpp -index e1cd610..ecc23a4 100644 ---- a/applets/systemtray/systemtray.cpp -+++ b/applets/systemtray/systemtray.cpp -@@ -99,19 +99,19 @@ void SystemTray::init() - { - Containment::init(); - -- for (const auto &info: Plasma::PluginLoader::self()->listAppletInfo(QString())) { -- if (!info.isValid() || info.property(QStringLiteral("X-Plasma-NotificationArea")) != "true") { -+ for (const auto &info: Plasma::PluginLoader::self()->listAppletMetaData(QString())) { -+ if (!info.isValid() || info.value(QStringLiteral("X-Plasma-NotificationArea")) != "true") { - continue; - } -- m_systrayApplets[info.pluginName()] = info; -+ m_systrayApplets[info.pluginId()] = KPluginInfo(info); - -- if (info.isPluginEnabledByDefault()) { -- m_defaultPlasmoids += info.pluginName(); -+ if (info.isEnabledByDefault()) { -+ m_defaultPlasmoids += info.pluginId(); - } -- const QString dbusactivation = info.property(QStringLiteral("X-Plasma-DBusActivationService")).toString(); -+ const QString dbusactivation = info.value(QStringLiteral("X-Plasma-DBusActivationService")); - if (!dbusactivation.isEmpty()) { -- qCDebug(SYSTEM_TRAY) << "ST Found DBus-able Applet: " << info.pluginName() << dbusactivation; -- m_dbusActivatableTasks[info.pluginName()] = dbusactivation; -+ qCDebug(SYSTEM_TRAY) << "ST Found DBus-able Applet: " << info.pluginId() << dbusactivation; -+ m_dbusActivatableTasks[info.pluginId()] = dbusactivation; - } - } - } -@@ -119,12 +119,12 @@ void SystemTray::init() - void SystemTray::newTask(const QString &task) - { - foreach (Plasma::Applet *applet, applets()) { -- if (!applet->pluginInfo().isValid()) { -+ if (!applet->pluginMetaData().isValid()) { - continue; - } - - //only allow one instance per applet -- if (task == applet->pluginInfo().pluginName()) { -+ if (task == applet->pluginMetaData().pluginId()) { - //Applet::destroy doesn't delete the applet from Containment::applets in the same event - //potentially a dbus activated service being restarted can be added in this time. - if (!applet->destroyed()) { -@@ -156,7 +156,7 @@ void SystemTray::newTask(const QString &task) - void SystemTray::cleanupTask(const QString &task) - { - foreach (Plasma::Applet *applet, applets()) { -- if (!applet->pluginInfo().isValid() || task == applet->pluginInfo().pluginName()) { -+ if (!applet->pluginMetaData().isValid() || task == applet->pluginMetaData().pluginId()) { - //we are *not* cleaning the config here, because since is one - //of those automatically loaded/unloaded by dbus, we want to recycle - //the config the next time it's loaded, in case the user configured something here -@@ -255,11 +255,11 @@ Q_INVOKABLE QString SystemTray::plasmoidCategory(QQuickItem *appletInterface) co - } - - Plasma::Applet *applet = appletInterface->property("_plasma_applet").value<Plasma::Applet*>(); -- if (!applet || !applet->pluginInfo().isValid()) { -+ if (!applet || !applet->pluginMetaData().isValid()) { - return "UnknownCategory"; - } - -- const QString cat = applet->pluginInfo().property(QStringLiteral("X-Plasma-NotificationAreaCategory")).toString(); -+ const QString cat = applet->pluginMetaData().value(QStringLiteral("X-Plasma-NotificationAreaCategory")); - - if (cat.isEmpty()) { - return "UnknownCategory"; -@@ -385,11 +385,11 @@ void SystemTray::restorePlasmoids() - foreach (Plasma::Applet *applet, applets()) { - //Here it should always be valid. - //for some reason it not always is. -- if (!applet->pluginInfo().isValid()) { -+ if (!applet->pluginMetaData().isValid()) { - applet->config().parent().deleteGroup(); - applet->deleteLater(); - } else { -- const QString task = applet->pluginInfo().pluginName(); -+ const QString task = applet->pluginMetaData().pluginId(); - if (!m_allowedPlasmoids.contains(task)) { - //in those cases we do delete the applet config completely - //as they were explicitly disabled by the user -diff --git a/components/shellprivate/widgetexplorer/widgetexplorer.cpp b/components/shellprivate/widgetexplorer/widgetexplorer.cpp -index c2b38a8..b445897 100644 ---- a/components/shellprivate/widgetexplorer/widgetexplorer.cpp -+++ b/components/shellprivate/widgetexplorer/widgetexplorer.cpp -@@ -249,14 +249,14 @@ void WidgetExplorerPrivate::addContainment(Containment *containment) - QObject::connect(containment, SIGNAL(appletRemoved(Plasma::Applet*)), q, SLOT(appletRemoved(Plasma::Applet*))); - - foreach (Applet *applet, containment->applets()) { -- if (applet->pluginInfo().isValid()) { -+ if (applet->pluginMetaData().isValid()) { - Containment *childContainment = applet->property("containment").value<Containment*>(); - if (childContainment) { - addContainment(childContainment); - } -- runningApplets[applet->pluginInfo().pluginName()]++; -+ runningApplets[applet->pluginMetaData().pluginId()]++; - } else { -- qDebug() << "Invalid plugininfo. :("; -+ qDebug() << "Invalid plugin metadata. :("; - } - } - } -@@ -268,10 +268,10 @@ void WidgetExplorerPrivate::containmentDestroyed() - - void WidgetExplorerPrivate::appletAdded(Plasma::Applet *applet) - { -- if (!applet->pluginInfo().isValid()) { -+ if (!applet->pluginMetaData().isValid()) { - return; - } -- QString name = applet->pluginInfo().pluginName(); -+ QString name = applet->pluginMetaData().pluginId(); - - runningApplets[name]++; - appletNames.insert(applet, name); -@@ -471,9 +471,9 @@ void WidgetExplorer::uninstall(const QString &pluginName) - const auto &applets = c->applets(); - - foreach (Applet *applet, applets) { -- const auto &appletInfo = applet->pluginInfo(); -+ const auto &appletInfo = applet->pluginMetaData(); - -- if (appletInfo.isValid() && appletInfo.pluginName() == pluginName) { -+ if (appletInfo.isValid() && appletInfo.pluginId() == pluginName) { - applet->destroy(); - } - } -diff --git a/plasma-windowed/plasmawindowedcorona.cpp b/plasma-windowed/plasmawindowedcorona.cpp -index fbacbf8..b68d270 100644 ---- a/plasma-windowed/plasmawindowedcorona.cpp -+++ b/plasma-windowed/plasmawindowedcorona.cpp -@@ -51,7 +51,7 @@ void PlasmaWindowedCorona::loadApplet(const QString &applet, const QVariantList - - //forbid more instances per applet (todo: activate the correpsponding already loaded applet) - for (Plasma::Applet *a : cont->applets()) { -- if (a->pluginInfo().pluginName() == applet) { -+ if (a->pluginMetaData().pluginId() == applet) { - return; - } - } +commit 238ec3ee671bcf6716348122bebefb20c25d1101 +Author: David Edmundson <kde@davidedmundson.co.uk> +Date: Thu, 17 Nov 2016 10:53:48 +0000 + + [Windowed Widgets Runner] Don't access invalid KPluginInfo + + BUG: 372017 + FIXED-IN: 5.8.4 + diff --git a/runners/windowedwidgets/windowedwidgetsrunner.cpp b/runners/windowedwidgets/windowedwidgetsrunner.cpp -index 5ccbd27..7f093a7 100644 +index 5ccbd27..f86159a 100644 --- a/runners/windowedwidgets/windowedwidgetsrunner.cpp +++ b/runners/windowedwidgets/windowedwidgetsrunner.cpp -@@ -60,24 +60,22 @@ void WindowedWidgetsRunner::match(Plasma::RunnerContext &context) - - QList<Plasma::QueryMatch> matches; - -- foreach (const KPluginInfo &info, Plasma::PluginLoader::self()->listAppletInfo(QString())) { -- KService::Ptr service = info.service(); -- -- if (((service->name().contains(term, Qt::CaseInsensitive) || -- service->genericName().contains(term, Qt::CaseInsensitive) || -- service->comment().contains(term, Qt::CaseInsensitive)) || -- service->categories().contains(term, Qt::CaseInsensitive) || -+ foreach (const KPluginMetaData &md, Plasma::PluginLoader::self()->listAppletMetaData(QString())) { -+ if (((md.name().contains(term, Qt::CaseInsensitive) || -+ md.value(QLatin1String("GenericName")).contains(term, Qt::CaseInsensitive) || -+ md.description().contains(term, Qt::CaseInsensitive)) || -+ md.category().contains(term, Qt::CaseInsensitive) || - term.startsWith(i18nc("Note this is a KRunner keyword", "mobile applications"))) && -- !info.property(QStringLiteral("NoDisplay")).toBool()) { -+ !md.rawData().value(QStringLiteral("NoDisplay")).toBool()) { - -- QVariant val = info.property(QStringLiteral("X-Plasma-StandAloneApp")); -+ QVariant val = md.value(QStringLiteral("X-Plasma-StandAloneApp")); - if (!val.isValid() || !val.toBool()) { - continue; - } - - Plasma::QueryMatch match(this); -- setupMatch(service, match); -- if (service->name().compare(term, Qt::CaseInsensitive) == 0) { -+ setupMatch(md, match); -+ if (md.name().compare(term, Qt::CaseInsensitive) == 0) { - match.setType(Plasma::QueryMatch::ExactMatch); - match.setRelevance(1); - } else { -@@ -85,8 +83,6 @@ void WindowedWidgetsRunner::match(Plasma::RunnerContext &context) - match.setRelevance(0.7); - } - matches << match; -- -- qDebug() << service; - } - } - -@@ -100,27 +96,27 @@ void WindowedWidgetsRunner::match(Plasma::RunnerContext &context) - void WindowedWidgetsRunner::run(const Plasma::RunnerContext &context, const Plasma::QueryMatch &match) - { - Q_UNUSED(context); -- KService::Ptr service = KService::serviceByStorageId(match.data().toString()); -- if (service) { -- QProcess::startDetached(QStringLiteral("plasmawindowed"), QStringList() << service->property(QStringLiteral("X-KDE-PluginInfo-Name"), QVariant::String).toString()); -+ KPluginMetaData md(match.data().toString()); -+ if (md.isValid()) { -+ QProcess::startDetached(QStringLiteral("plasmawindowed"), QStringList() << md.pluginId()); - } - } - --void WindowedWidgetsRunner::setupMatch(const KService::Ptr &service, Plasma::QueryMatch &match) -+void WindowedWidgetsRunner::setupMatch(const KPluginMetaData &md, Plasma::QueryMatch &match) - { -- const QString name = service->name(); -+ const QString name = md.pluginId(); - - match.setText(name); -- match.setData(service->storageId()); -+ match.setData(md.metaDataFileName()); - -- if (!service->genericName().isEmpty() && service->genericName() != name) { -- match.setSubtext(service->genericName()); -- } else if (!service->comment().isEmpty()) { -- match.setSubtext(service->comment()); -+ if (!md.name().isEmpty() && md.name() != name) { -+ match.setSubtext(md.name()); -+ } else if (!md.description().isEmpty()) { -+ match.setSubtext(md.description()); - } - -- if (!service->icon().isEmpty()) { -- match.setIconName(service->icon()); -+ if (!md.iconName().isEmpty()) { -+ match.setIconName(md.iconName()); - } - } - -diff --git a/runners/windowedwidgets/windowedwidgetsrunner.h b/runners/windowedwidgets/windowedwidgetsrunner.h -index 2294965..fbc8006 100644 ---- a/runners/windowedwidgets/windowedwidgetsrunner.h -+++ b/runners/windowedwidgets/windowedwidgetsrunner.h -@@ -48,7 +48,7 @@ protected Q_SLOTS: - - - protected: -- void setupMatch(const KService::Ptr &service, Plasma::QueryMatch &action); -+ void setupMatch(const KPluginMetaData &md, Plasma::QueryMatch &action); - }; - - #endif -diff --git a/shell/alternativeshelper.cpp b/shell/alternativeshelper.cpp -index d0f5dfd..6d76307 100644 ---- a/shell/alternativeshelper.cpp -+++ b/shell/alternativeshelper.cpp -@@ -38,12 +38,12 @@ AlternativesHelper::~AlternativesHelper() - - QStringList AlternativesHelper::appletProvides() const - { -- return m_applet->pluginInfo().property(QStringLiteral("X-Plasma-Provides")).toStringList(); -+ return KPluginMetaData::readStringList(m_applet->pluginMetaData().rawData(), QStringLiteral("X-Plasma-Provides")); - } +@@ -60,6 +60,9 @@ void WindowedWidgetsRunner::match(Plasma::RunnerContext &context) - QString AlternativesHelper::currentPlugin() const - { -- return m_applet->pluginInfo().pluginName(); -+ return m_applet->pluginMetaData().pluginId(); - } - - QQuickItem *AlternativesHelper::applet() const -@@ -53,7 +53,7 @@ QQuickItem *AlternativesHelper::applet() const - - void AlternativesHelper::loadAlternative(const QString &plugin) - { -- if (plugin == m_applet->pluginInfo().pluginName() || m_applet->isContainment()) { -+ if (plugin == m_applet->pluginMetaData().pluginId() || m_applet->isContainment()) { - return; - } - -diff --git a/shell/containmentconfigview.cpp b/shell/containmentconfigview.cpp -index cec067e..4c9d146 100644 ---- a/shell/containmentconfigview.cpp -+++ b/shell/containmentconfigview.cpp -@@ -104,7 +104,7 @@ QAbstractItemModel *ContainmentConfigView::currentContainmentActionsModel() - - QString ContainmentConfigView::containmentPlugin() const - { -- return m_containment->pluginInfo().pluginName(); -+ return m_containment->pluginMetaData().pluginId(); - } - - void ContainmentConfigView::setContainmentPlugin(const QString &plugin) -diff --git a/shell/scripting/containment.cpp b/shell/scripting/containment.cpp -index 6040e62..96e2009 100644 ---- a/shell/scripting/containment.cpp -+++ b/shell/scripting/containment.cpp -@@ -248,7 +248,7 @@ QScriptValue Containment::widgets(QScriptContext *context, QScriptEngine *engine - int count = 0; - - foreach (Plasma::Applet *widget, c->d->containment.data()->applets()) { -- if (widgetType.isEmpty() || widget->pluginInfo().pluginName() == widgetType) { -+ if (widgetType.isEmpty() || widget->pluginMetaData().pluginId() == widgetType) { - widgets.setProperty(count, env->wrap(widget)); - ++count; - } -@@ -273,7 +273,7 @@ QString Containment::type() const - return QString(); - } - -- return d->containment.data()->pluginInfo().pluginName(); -+ return d->containment.data()->pluginMetaData().pluginId(); - } - - void Containment::remove() -diff --git a/shell/scripting/widget.cpp b/shell/scripting/widget.cpp -index a651c2a..b58822b 100644 ---- a/shell/scripting/widget.cpp -+++ b/shell/scripting/widget.cpp -@@ -65,7 +65,7 @@ uint Widget::id() const - QString Widget::type() const - { - if (d->applet) { -- return d->applet.data()->pluginInfo().pluginName(); -+ return d->applet.data()->pluginMetaData().pluginId(); - } - - return QString(); -diff --git a/shell/shellcorona.cpp b/shell/shellcorona.cpp -index 33259da..598fdb0 100644 ---- a/shell/shellcorona.cpp -+++ b/shell/shellcorona.cpp -@@ -406,7 +406,7 @@ QByteArray ShellCorona::dumpCurrentLayoutJS() const - || cont->location() == Plasma::Types::BottomEdge - || cont->location() == Plasma::Types::LeftEdge - || cont->location() == Plasma::Types::RightEdge) && -- cont->pluginInfo().pluginName() != QStringLiteral("org.kde.plasma.private.systemtray"); -+ cont->pluginMetaData().pluginId() != QStringLiteral("org.kde.plasma.private.systemtray"); - }; - - auto isDesktop = [] (Plasma::Containment *cont) { -@@ -493,7 +493,7 @@ QByteArray ShellCorona::dumpCurrentLayoutJS() const - - KConfigGroup appletConfig = applet->config(); - -- appletJson.insert("plugin", applet->pluginInfo().pluginName()); -+ appletJson.insert("plugin", applet->pluginMetaData().pluginId()); - appletJson.insert("config", dumpconfigGroupJS(appletConfig)); - - appletsJsonArray << appletJson; -@@ -560,7 +560,7 @@ QByteArray ShellCorona::dumpCurrentLayoutJS() const - QJsonObject appletJson; - - appletJson.insert("title", applet->title()); -- appletJson.insert("plugin", applet->pluginInfo().pluginName()); -+ appletJson.insert("plugin", applet->pluginMetaData().pluginId()); - - appletJson.insert("geometry.x", geometry.x() / gridUnit); - appletJson.insert("geometry.y", geometry.y() / gridUnit); -@@ -1238,11 +1238,11 @@ void ShellCorona::handleContainmentAdded(Plasma::Containment *c) - - void ShellCorona::executeSetupPlasmoidScript(Plasma::Containment *containment, Plasma::Applet *applet) - { -- if (!applet->pluginInfo().isValid() || !containment->pluginInfo().isValid()) { -+ if (!applet->pluginMetaData().isValid() || !containment->pluginMetaData().isValid()) { - return; - } - -- const QString scriptFile = m_lookAndFeelPackage.filePath("plasmoidsetupscripts", applet->pluginInfo().pluginName() + ".js"); -+ const QString scriptFile = m_lookAndFeelPackage.filePath("plasmoidsetupscripts", applet->pluginMetaData().pluginId() + ".js"); - - if (scriptFile.isEmpty()) { - return; -@@ -1541,7 +1541,7 @@ Plasma::Containment *ShellCorona::setContainmentTypeForScreen(int screen, const - //if creation failed or invalid plugin, give up - if (!newContainment) { - return oldContainment; -- } else if (!newContainment->pluginInfo().isValid()) { -+ } else if (!newContainment->pluginMetaData().isValid()) { - newContainment->deleteLater(); - return oldContainment; - } -@@ -1975,7 +1975,8 @@ void ShellCorona::activateLauncherMenu() - for (auto it = m_panelViews.constBegin(), end = m_panelViews.constEnd(); it != end; ++it) { - const auto applets = it.key()->applets(); - for (auto applet : applets) { -- if (applet->pluginInfo().property("X-Plasma-Provides").toStringList().contains(QStringLiteral("org.kde.plasma.launchermenu"))) { -+ const auto provides = KPluginMetaData::readStringList(applet->pluginMetaData().rawData(), QStringLiteral("X-Plasma-Provides")); -+ if (provides.contains(QLatin1String("org.kde.plasma.launchermenu"))) { - if (!applet->globalShortcut().isEmpty()) { - emit applet->activated(); - return; --- -2.7.3 - -From 59b2d1effcee8d449cbbcd237ba8cebaeb4dd949 Mon Sep 17 00:00:00 2001 -From: Kai Uwe Broulik <kde@privat.broulik.de> -Date: Mon, 14 Nov 2016 15:23:00 +0100 -Subject: [PATCH] [Windowed Widgets Runner] Don't access invalid - KPluginMetaData - -BUG: 372017 -FIXED-IN: 5.8.4 - -Differential Revision: https://phabricator.kde.org/D3356 ---- - runners/windowedwidgets/windowedwidgetsrunner.cpp | 4 ++++ - 1 file changed, 4 insertions(+) - -diff --git a/runners/windowedwidgets/windowedwidgetsrunner.cpp b/runners/windowedwidgets/windowedwidgetsrunner.cpp -index 7f093a7..706b1bb 100644 ---- a/runners/windowedwidgets/windowedwidgetsrunner.cpp -+++ b/runners/windowedwidgets/windowedwidgetsrunner.cpp -@@ -61,6 +61,10 @@ void WindowedWidgetsRunner::match(Plasma::RunnerContext &context) - QList<Plasma::QueryMatch> matches; - - foreach (const KPluginMetaData &md, Plasma::PluginLoader::self()->listAppletMetaData(QString())) { -+ if (!md.isValid()) { + foreach (const KPluginInfo &info, Plasma::PluginLoader::self()->listAppletInfo(QString())) { + KService::Ptr service = info.service(); ++ if (!service || !service->isValid()) { + continue; + } -+ - if (((md.name().contains(term, Qt::CaseInsensitive) || - md.value(QLatin1String("GenericName")).contains(term, Qt::CaseInsensitive) || - md.description().contains(term, Qt::CaseInsensitive)) || --- -2.7.3 - + + if (((service->name().contains(term, Qt::CaseInsensitive) || + service->genericName().contains(term, Qt::CaseInsensitive) || |