Fully port away from KPluginLoader

This commit is contained in:
Alexander Lohnau 2021-10-19 21:39:51 +02:00
parent e431b453b6
commit dffbfcc9f7
No known key found for this signature in database
GPG key ID: 1F58708D54A003E7
13 changed files with 14 additions and 44 deletions

View file

@ -12,7 +12,6 @@
// KDE
#include <KConfig>
#include <KConfigGroup>
#include <KPluginLoader>
// Qt
#include <QtTest>
#include <QStringList>

View file

@ -10,7 +10,6 @@
#include <QTest>
#include <QX11Info>
#include <KPluginLoader>
#include <KPluginMetaData>
#include "main.h"
@ -37,7 +36,7 @@ X11TestApplication::X11TestApplication(int &argc, char **argv)
setX11Connection(QX11Info::connection());
setX11RootWindow(QX11Info::appRootWindow());
// move directory containing executable to front, so that KPluginLoader prefers the plugins in
// move directory containing executable to front, so that KPluginMetaData::findPluginById prefers the plugins in
// the build dir over system installed ones
const auto ownPath = libraryPaths().last();
removeLibraryPath(ownPath);

View file

@ -36,7 +36,6 @@
#include <KGlobalAccel>
#include <KLocalizedString>
#include <KPluginLoader>
#include <KPluginMetaData>
#include <KNotification>
#include <KSelectionOwner>

View file

@ -27,7 +27,6 @@
// Frameworks
#include <KPluginFactory>
#include <KPluginMetaData>
#include <KPluginLoader>
// Qt
#include <QMetaProperty>
@ -143,13 +142,12 @@ void DecorationBridge::initPlugin()
return;
}
qCDebug(KWIN_DECORATIONS) << "Trying to load decoration plugin: " << metaData.fileName();
KPluginLoader loader(metaData.fileName());
KPluginFactory *factory = loader.factory();
if (!factory) {
qCWarning(KWIN_DECORATIONS) << "Error loading plugin:" << loader.errorString();
auto factoryResult = KPluginFactory::loadFactory(metaData);
if (!factoryResult) {
qCWarning(KWIN_DECORATIONS) << "Error loading plugin:" << factoryResult.errorText;
} else {
m_factory = factory;
loadMetaData(loader.metaData().value(QStringLiteral("MetaData")).toObject());
m_factory = factoryResult.plugin;
loadMetaData(metaData.rawData());
}
}

View file

@ -16,7 +16,6 @@
#include "utils.h"
// KDE
#include <KConfigGroup>
#include <KPluginLoader>
#include <KPackage/Package>
#include <KPackage/PackageLoader>
// Qt
@ -381,12 +380,12 @@ EffectPluginFactory *PluginEffectLoader::factory(const KPluginMetaData &info) co
if (!info.isValid()) {
return nullptr;
}
KPluginLoader loader(info.fileName());
QPluginLoader loader(info.fileName());
if (loader.metaData().value("IID").toString() != EffectPluginFactory_iid) {
qCDebug(KWIN_CORE) << info.pluginId() << " has not matching plugin version, expected " << PluginFactory_iid << "got " << loader.metaData().value("IID");
return nullptr;
}
KPluginFactory *factory = loader.factory();
KPluginFactory *factory = qobject_cast<KPluginFactory *>(loader.instance());
if (!factory) {
qCDebug(KWIN_CORE) << "Did not get KPluginFactory for " << info.pluginId();
return nullptr;

View file

@ -18,7 +18,6 @@
#include <KConfigGroup>
#include <KLocalizedString>
#include <KPackage/PackageLoader>
#include <KPluginLoader>
#include <KPluginFactory>
#include <KPluginInfo>
#include <KPluginMetaData>
@ -630,21 +629,13 @@ static KCModule *loadBinaryConfig(const QString &configModule, QObject *parent)
return nullptr;
}
KPluginLoader loader(metaData.fileName());
KPluginFactory *factory = loader.factory();
return factory->create<KCModule>(parent);
return KPluginFactory::instantiatePlugin<KCModule>(metaData, parent).plugin;
}
static KCModule *findScriptedConfig(const QString &pluginId, QObject *parent)
{
KPluginLoader loader(QStringLiteral("kwin/effects/configs/kcm_kwin4_genericscripted"));
KPluginFactory *factory = loader.factory();
if (!factory) {
return nullptr;
}
return factory->create<KCModule>(parent, QVariantList{pluginId});
KPluginMetaData metaData(QStringLiteral("kwin/effects/configs/kcm_kwin4_genericscripted"));
return KPluginFactory::instantiatePlugin<KCModule>(metaData, parent, QVariantList{pluginId}).plugin;
}
void EffectsModel::requestConfigure(const QModelIndex &index, QWindow *transientParent)

View file

@ -12,7 +12,6 @@
#include <KDecoration2/Decoration>
#include <KCModule>
#include <KPluginLoader>
#include <KPluginFactory>
#include <KPluginMetaData>
@ -111,8 +110,7 @@ void PreviewBridge::createFactory()
const auto offers = KPluginMetaData::findPlugins(s_pluginName);
auto item = std::find_if(offers.constBegin(), offers.constEnd(), [this](const auto &plugin) { return plugin.pluginId() == m_plugin; });
if (item != offers.constEnd()) {
KPluginLoader loader(item->fileName());
m_factory = loader.factory();
m_factory = KPluginFactory::loadFactory(*item).plugin;
}
setValid(!m_factory.isNull());

View file

@ -9,7 +9,6 @@
#include <KDecoration2/DecorationSettings>
#include <KDecoration2/DecorationThemeProvider>
// KDE
#include <KPluginLoader>
#include <KPluginFactory>
#include <KPluginMetaData>
// Qt

View file

@ -16,7 +16,6 @@
#include <kconfig.h>
#include <kaboutdata.h>
#include <KPluginFactory>
#include <KPluginLoader>
#include "mouse.h"
#include "windows.h"

View file

@ -398,15 +398,7 @@ void KWinTabBoxConfig::configureEffectClicked()
return;
}
KCModule *kcm = nullptr;
KPluginLoader loader(plugins.first().fileName());
KPluginFactory *factory = loader.factory();
if (!factory) {
qWarning() << "Error loading plugin:" << loader.errorString();
} else {
kcm = factory->create<KCModule>(configDialog);
}
KCModule *kcm = KPluginFactory::instantiatePlugin<KCModule>(plugins.first(), configDialog).plugin;
if (!kcm) {
delete configDialog;

View file

@ -28,7 +28,6 @@
#include <KCrash>
#include <KDesktopFile>
#include <KLocalizedString>
#include <KPluginLoader>
#include <KPluginMetaData>
#include <KQuickAddons/QtQuickSettings>
#include <KShell>

View file

@ -21,7 +21,6 @@
#include <KConfigGroup>
#include <KCrash>
#include <KLocalizedString>
#include <KPluginLoader>
#include <KPluginMetaData>
#include <KSelectionOwner>
#include <KQuickAddons/QtQuickSettings>

View file

@ -12,7 +12,6 @@
#include <KConfigGroup>
#include <KPluginFactory>
#include <KPluginLoader>
#include <KPluginMetaData>
namespace KWin
@ -144,7 +143,7 @@ bool PluginManager::loadDynamicPlugin(const KPluginMetaData &metadata)
}
const QString pluginId = metadata.pluginId();
KPluginLoader pluginLoader(metadata.fileName());
QPluginLoader pluginLoader(metadata.fileName());
if (pluginLoader.metaData().value("IID").toString() != PluginFactory_iid) {
qCWarning(KWIN_CORE) << pluginId << "has mismatching plugin version";
return false;