Harmattan Booster for Qt Quick Applications

From Qt Wiki
Jump to navigation Jump to search
IMPORTANT: The content of this page is outdated. Reason: The MeeGo/Harmattan platform is no longer supported.
If you have checked or updated this page and found the content to be suitable, please remove this notice.
This article may require cleanup to meet the Qt Wiki's quality standards. Reason: Auto-imported from ExpressionEngine.
Please improve this article if you can. Remove the {{cleanup}} tag and add this page to Updated pages list after it's clean.

Manually Enabling Harmattan Booster Library

Up until and including Qt Creator 2.3.0, the "Qt Quick Application" wizard doesn't make use of the Harmattan booster library. This has a negative impact on application startup time, and might even lead to problems when submitting the application to the Ovi store.

Qt Creator 2.3.1 (which is now included in the latest updates to the Qt SDK) already enables the booster by default! The instructions below are only for people who have already projects created with 2.3.0 or older, or are not willing to update for whatever reasons.

This page outlines the changes you can do by hand to the source code to enable the booster. However, by making these changes your application will not compile any more for other targets!

Changes to main.cpp

Replace your main.cpp with following code (obviously replacing "YourApp" by the name of your app):

#include <QApplication>
#include <QDeclarativeView>
#include <QDeclarativeEngine>
#include <MDeclarativeCache>

Q_DECL_EXPORT int main(int argc, char *argv[])
{
 QScopedPointer<QApplication> app(MDeclarativeCache::qApplication(argc, argv));
 QScopedPointer<QDeclarativeView> view(MDeclarativeCache::qDeclarativeView());

view->setSource(MDeclarativeCache::applicationDirPath()
 + QLatin1String("/../qml/YourApp/main.qml"));

QObject::connect(view->engine(), SIGNAL (quit()), view.data(), SLOT (close()));

view->showFullScreen();

app->exec();
}

Changes to .pro file

Add

CONFIG += qdeclarative-boostable

to the .pro file, and don't forget to do a full recompile!

Changes to .desktop file

Open YourApp_harmattan.desktop in the project directory, and change

Exec=/usr/bin/single-instance /opt/YourApp/bin/YourApp

to

Exec=/usr/bin/invoker type=d -s /opt/YourApp/bin/YourApp

Do you have questions, or suggestions? Raise them under http://developer.qt.nokia.com/forums/viewthread/9164