use QmlObjectSharedEngine in applets

Change-Id: Ie3f8c90b7fd601fdb2da23bd69e4b4b338cb190b
This commit is contained in:
Marco Martin 2015-05-11 20:44:57 +02:00
parent cb6b03e907
commit a595bf9f61
2 changed files with 11 additions and 17 deletions

View File

@ -33,7 +33,7 @@
#include <Plasma/Applet> #include <Plasma/Applet>
#include <Plasma/Containment> #include <Plasma/Containment>
#include <Plasma/Corona> #include <Plasma/Corona>
#include <kdeclarative/qmlobject.h> #include <kdeclarative/qmlobjectsharedengine.h>
#include <packageurlinterceptor.h> #include <packageurlinterceptor.h>
@ -42,8 +42,6 @@ namespace PlasmaQuick
QHash<QObject *, AppletQuickItem *> AppletQuickItemPrivate::s_rootObjects = QHash<QObject *, AppletQuickItem *>(); QHash<QObject *, AppletQuickItem *> AppletQuickItemPrivate::s_rootObjects = QHash<QObject *, AppletQuickItem *>();
QQmlEngine *AppletQuickItemPrivate::s_engine = 0;
AppletQuickItemPrivate::AppletQuickItemPrivate(Plasma::Applet *a, AppletQuickItem *item) AppletQuickItemPrivate::AppletQuickItemPrivate(Plasma::Applet *a, AppletQuickItem *item)
: q(item), : q(item),
switchWidth(-1), switchWidth(-1),
@ -51,10 +49,14 @@ AppletQuickItemPrivate::AppletQuickItemPrivate(Plasma::Applet *a, AppletQuickIte
applet(a), applet(a),
expanded(false) expanded(false)
{ {
if (!s_engine) { if (a->pluginInfo().property("X-Plasma-RequiredExtensions").toStringList().contains("SharedEngine")) {
s_engine = new QQmlEngine; qmlObject = new KDeclarative::QmlObjectSharedEngine(q);
PackageUrlInterceptor *interceptor = new PackageUrlInterceptor(s_engine, Plasma::Package()); if (!qmlObject->engine()->urlInterceptor()) {
s_engine->setUrlInterceptor(interceptor); PackageUrlInterceptor *interceptor = new PackageUrlInterceptor(qmlObject->engine(), Plasma::Package());
qmlObject->engine()->setUrlInterceptor(interceptor);
}
} else {
qmlObject = new KDeclarative::QmlObject(q);
} }
} }
@ -385,13 +387,6 @@ AppletQuickItem::AppletQuickItem(Plasma::Applet *applet, QQuickItem *parent)
connect(&d->compactRepresentationCheckTimer, SIGNAL(timeout()), connect(&d->compactRepresentationCheckTimer, SIGNAL(timeout()),
this, SLOT(compactRepresentationCheck())); this, SLOT(compactRepresentationCheck()));
if (applet->pluginInfo().property("X-Plasma-RequiredExtensions").toStringList().contains("SharedEngine")) {
QQmlContext *context = new QQmlContext(AppletQuickItemPrivate::s_engine->rootContext());
d->qmlObject = new KDeclarative::QmlObject(AppletQuickItemPrivate::s_engine, context, this);
} else {
d->qmlObject = new KDeclarative::QmlObject(this);
}
if (applet->pluginInfo().isValid()) { if (applet->pluginInfo().isValid()) {
const QString rootPath = applet->pluginInfo().property("X-Plasma-RootPath").toString(); const QString rootPath = applet->pluginInfo().property("X-Plasma-RootPath").toString();
if (!rootPath.isEmpty()) { if (!rootPath.isEmpty()) {
@ -421,7 +416,7 @@ AppletQuickItem *AppletQuickItem::qmlAttachedProperties(QObject *object)
{ {
QQmlContext *context; QQmlContext *context;
//is it using shared engine mode? //is it using shared engine mode?
if (QtQml::qmlEngine(object) == AppletQuickItemPrivate::s_engine) { if (!QtQml::qmlEngine(object)->parent()) {
context = QtQml::qmlContext(object); context = QtQml::qmlContext(object);
//search the root context of the applet in which the object is in //search the root context of the applet in which the object is in
while (context) { while (context) {
@ -467,7 +462,7 @@ void AppletQuickItem::init()
//if the engine of the qmlObject is different from the static one, then we //if the engine of the qmlObject is different from the static one, then we
//are using an old version of the api in which every applet had one engine //are using an old version of the api in which every applet had one engine
//so initialize a private url interceptor //so initialize a private url interceptor
if (d->applet->package().isValid() && engine != AppletQuickItemPrivate::s_engine) { if (d->applet->package().isValid() && qobject_cast<KDeclarative::QmlObjectSharedEngine *>(d->qmlObject)) {
PackageUrlInterceptor *interceptor = new PackageUrlInterceptor(engine, d->applet->package()); PackageUrlInterceptor *interceptor = new PackageUrlInterceptor(engine, d->applet->package());
interceptor->addAllowedPath(d->coronaPackage.path()); interceptor->addAllowedPath(d->coronaPackage.path());
engine->setUrlInterceptor(interceptor); engine->setUrlInterceptor(interceptor);

View File

@ -104,7 +104,6 @@ public:
bool expanded : 1; bool expanded : 1;
static QHash<QObject *, AppletQuickItem *> s_rootObjects; static QHash<QObject *, AppletQuickItem *> s_rootObjects;
static QQmlEngine *s_engine;
}; };
} }