scripted popup applets must also have Plasma/Applet in their ServiceTypes; remove code working around buggy plasmoids
svn path=/trunk/KDE/kdelibs/; revision=1101740
This commit is contained in:
parent
c093832d1f
commit
78201bdf2c
23
applet.cpp
23
applet.cpp
@ -850,10 +850,6 @@ QString Applet::category(const QString &appletName)
|
|||||||
const QString constraint = QString("[X-KDE-PluginInfo-Name] == '%1'").arg(appletName);
|
const QString constraint = QString("[X-KDE-PluginInfo-Name] == '%1'").arg(appletName);
|
||||||
KService::List offers = KServiceTypeTrader::self()->query("Plasma/Applet", constraint);
|
KService::List offers = KServiceTypeTrader::self()->query("Plasma/Applet", constraint);
|
||||||
|
|
||||||
if (offers.isEmpty()) {
|
|
||||||
offers = KServiceTypeTrader::self()->query("Plasma/PopupApplet", constraint);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (offers.isEmpty()) {
|
if (offers.isEmpty()) {
|
||||||
return QString();
|
return QString();
|
||||||
}
|
}
|
||||||
@ -2061,8 +2057,7 @@ void AppletPrivate::filterOffers(QList<KService::Ptr> &offers)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
KPluginInfo::List Applet::listAppletInfo(const QString &category,
|
KPluginInfo::List Applet::listAppletInfo(const QString &category, const QString &parentApp)
|
||||||
const QString &parentApp)
|
|
||||||
{
|
{
|
||||||
QString constraint;
|
QString constraint;
|
||||||
|
|
||||||
@ -2089,7 +2084,6 @@ KPluginInfo::List Applet::listAppletInfo(const QString &category,
|
|||||||
}
|
}
|
||||||
|
|
||||||
KService::List offers = KServiceTypeTrader::self()->query("Plasma/Applet", constraint);
|
KService::List offers = KServiceTypeTrader::self()->query("Plasma/Applet", constraint);
|
||||||
offers << KServiceTypeTrader::self()->query("Plasma/PopupApplet", constraint);
|
|
||||||
|
|
||||||
//now we have to do some manual filtering because the constraint can't handle everything
|
//now we have to do some manual filtering because the constraint can't handle everything
|
||||||
AppletPrivate::filterOffers(offers);
|
AppletPrivate::filterOffers(offers);
|
||||||
@ -2104,7 +2098,6 @@ KPluginInfo::List Applet::listAppletInfoForMimetype(const QString &mimetype)
|
|||||||
QString constraint = QString("'%1' in [X-Plasma-DropMimeTypes]").arg(mimetype);
|
QString constraint = QString("'%1' in [X-Plasma-DropMimeTypes]").arg(mimetype);
|
||||||
//kDebug() << "listAppletInfoForMimetype with" << mimetype << constraint;
|
//kDebug() << "listAppletInfoForMimetype with" << mimetype << constraint;
|
||||||
KService::List offers = KServiceTypeTrader::self()->query("Plasma/Applet", constraint);
|
KService::List offers = KServiceTypeTrader::self()->query("Plasma/Applet", constraint);
|
||||||
offers << KServiceTypeTrader::self()->query("Plasma/PopupApplet", constraint);
|
|
||||||
AppletPrivate::filterOffers(offers);
|
AppletPrivate::filterOffers(offers);
|
||||||
return KPluginInfo::fromServices(offers);
|
return KPluginInfo::fromServices(offers);
|
||||||
}
|
}
|
||||||
@ -2113,7 +2106,6 @@ KPluginInfo::List Applet::listAppletInfoForUrl(const QUrl &url)
|
|||||||
{
|
{
|
||||||
QString constraint = "exist [X-Plasma-DropUrlPatterns]";
|
QString constraint = "exist [X-Plasma-DropUrlPatterns]";
|
||||||
KService::List offers = KServiceTypeTrader::self()->query("Plasma/Applet", constraint);
|
KService::List offers = KServiceTypeTrader::self()->query("Plasma/Applet", constraint);
|
||||||
offers << KServiceTypeTrader::self()->query("Plasma/PopupApplet", constraint);
|
|
||||||
AppletPrivate::filterOffers(offers);
|
AppletPrivate::filterOffers(offers);
|
||||||
|
|
||||||
KPluginInfo::List allApplets = KPluginInfo::fromServices(offers);
|
KPluginInfo::List allApplets = KPluginInfo::fromServices(offers);
|
||||||
@ -2150,7 +2142,6 @@ QStringList Applet::listCategories(const QString &parentApp, bool visibleOnly)
|
|||||||
}
|
}
|
||||||
|
|
||||||
KService::List offers = KServiceTypeTrader::self()->query("Plasma/Applet", constraint);
|
KService::List offers = KServiceTypeTrader::self()->query("Plasma/Applet", constraint);
|
||||||
offers << KServiceTypeTrader::self()->query("Plasma/PopupApplet", constraint);
|
|
||||||
AppletPrivate::filterOffers(offers);
|
AppletPrivate::filterOffers(offers);
|
||||||
|
|
||||||
QStringList categories;
|
QStringList categories;
|
||||||
@ -2237,14 +2228,6 @@ Applet *Applet::load(const QString &appletName, uint appletId, const QVariantLis
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool isPopupApplet = false;
|
|
||||||
if (offers.isEmpty()) {
|
|
||||||
offers = KServiceTypeTrader::self()->query("Plasma/PopupApplet", constraint);
|
|
||||||
if (offers.count() > 0) {
|
|
||||||
isPopupApplet = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* if (offers.count() > 1) {
|
/* if (offers.count() > 1) {
|
||||||
kDebug() << "hey! we got more than one! let's blindly take the first one";
|
kDebug() << "hey! we got more than one! let's blindly take the first one";
|
||||||
} */
|
} */
|
||||||
@ -2269,12 +2252,14 @@ Applet *Applet::load(const QString &appletName, uint appletId, const QVariantLis
|
|||||||
<< offer->property("X-Plasma-API").toString() << "API";
|
<< offer->property("X-Plasma-API").toString() << "API";
|
||||||
if (isContainment) {
|
if (isContainment) {
|
||||||
return new Containment(0, allArgs);
|
return new Containment(0, allArgs);
|
||||||
} else if (isPopupApplet) {
|
} else {
|
||||||
|
if (offer->serviceTypes().contains("Plasma/PopupApplet")) {
|
||||||
return new PopupApplet(0, allArgs);
|
return new PopupApplet(0, allArgs);
|
||||||
} else {
|
} else {
|
||||||
return new Applet(0, allArgs);
|
return new Applet(0, allArgs);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
KPluginLoader plugin(*offer);
|
KPluginLoader plugin(*offer);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user