Port packageStructure loading from KPluginTrader

It will be deprecated.
This commit is contained in:
Nicolas Fella 2020-11-21 22:50:18 +01:00
parent 1a1133006b
commit d7f118e589

View File

@ -435,14 +435,29 @@ Package PluginLoader::loadPackage(const QString &packageFormat, const QString &s
structure->d->internalStructure = internalStructure; structure->d->internalStructure = internalStructure;
//fallback to old structures //fallback to old structures
} else { } else {
const QString constraint = QStringLiteral("[X-KDE-PluginInfo-Name] == '%1'").arg(packageFormat);
structure = KPluginTrader::createInstanceFromQuery<Plasma::PackageStructure>(PluginLoaderPrivate::s_packageStructurePluginDir, QStringLiteral("Plasma/PackageStructure"), constraint, nullptr); auto filter = [packageFormat](const KPluginMetaData &md) -> bool
if (structure) { {
structure->d->internalStructure = new PackageStructureWrapper(structure); return md.value(QStringLiteral("X-KDE-PluginInfo-Name")) == packageFormat;
};
const QVector<KPluginMetaData> plugins = KPluginLoader::findPlugins(PluginLoaderPrivate::s_packageStructurePluginDir, filter);
if (!plugins.isEmpty()) {
KPluginLoader loader(plugins.first().fileName());
KPluginFactory* factory = loader.factory();
if (!factory) {
qWarning() << "Error loading plugin:" << loader.errorString();
} else {
structure = factory->create<Plasma::PackageStructure>();
}
if (structure) {
structure->d->internalStructure = new PackageStructureWrapper(structure);
}
} }
} }
if (structure) { if (structure) {
d->structures.insert(hashkey, structure); d->structures.insert(hashkey, structure);
return Package(structure); return Package(structure);