aboutsummaryrefslogtreecommitdiffstats
path: root/launcher/src/main.cpp
diff options
context:
space:
mode:
authorMarius Vlad <marius.vlad@collabora.com>2020-01-22 21:42:06 +0200
committerMarius Vlad <marius.vlad@collabora.com>2020-01-23 16:33:56 +0200
commit50d87b3696390d30f8801bcdff908e33ed7e61aa (patch)
treedda169c89c5d9db8d69535a7a8ed3cb29db79be6 /launcher/src/main.cpp
parent830921faab68c1d4b00b9a93a99a1584c59baf34 (diff)
launcher/: Convert launcher to agl-compositor
- adds pws/ directory just like homescreen to be able to get list of runnables apps and be able to spawn them with the help of libafbwsc - removes libhomescreen libwindowmanger call from main and qmake files Signed-off-by: Marius Vlad <marius.vlad@collabora.com> Change-Id: I2f6aebfe05a23389796e801300cb616000bdef2b
Diffstat (limited to 'launcher/src/main.cpp')
-rw-r--r--launcher/src/main.cpp91
1 files changed, 13 insertions, 78 deletions
diff --git a/launcher/src/main.cpp b/launcher/src/main.cpp
index e550948..6d20ec8 100644
--- a/launcher/src/main.cpp
+++ b/launcher/src/main.cpp
@@ -23,47 +23,23 @@
#include <QtQml/qqml.h>
#include <QQuickWindow>
#include <QThread>
+#include <QUrlQuery>
+
+#include <QDBusMetaType>
+#include <QDBusArgument>
-#include <qlibwindowmanager.h>
#include "applicationlauncher.h"
#include "applicationmodel.h"
+#include "applicationhandler.h"
#include "appinfo.h"
-#include "afm_user_daemon_proxy.h"
-#include "homescreenhandler.h"
-#include "hmi-debug.h"
-
-// XXX: We want this DBus connection to be shared across the different
-// QML objects, is there another way to do this, a nice way, perhaps?
-org::AGL::afm::user *afm_user_daemon_proxy;
-
-namespace {
-struct Cleanup {
- static inline void cleanup(org::AGL::afm::user *p) {
- delete p;
- afm_user_daemon_proxy = Q_NULLPTR;
- }
-};
-
-}
+#define CONNECT_STR "unix:/run/platform/apis/ws/afm-main"
int main(int argc, char *argv[])
{
QString myname = QString("launcher");
QGuiApplication a(argc, argv);
- // use launch process
- QScopedPointer<org::AGL::afm::user, Cleanup> afm_user_daemon_proxy(new org::AGL::afm::user("org.AGL.afm.user",
- "/org/AGL/afm/user",
- QDBusConnection::sessionBus(),
- 0));
- ::afm_user_daemon_proxy = afm_user_daemon_proxy.data();
-
- QCoreApplication::setOrganizationDomain("LinuxFoundation");
- QCoreApplication::setOrganizationName("AutomotiveGradeLinux");
- QCoreApplication::setApplicationName(myname);
- QCoreApplication::setApplicationVersion("0.1.0");
-
QCommandLineParser parser;
parser.addPositionalArgument("port", a.translate("main", "port for binding"));
parser.addPositionalArgument("secret", a.translate("main", "secret for binding"));
@@ -80,44 +56,17 @@ int main(int argc, char *argv[])
token = positionalArguments.takeFirst();
}
- HMI_DEBUG("launcher","port = %d, token = %s", port, token.toStdString().c_str());
-
// import C++ class to QML
qmlRegisterType<ApplicationModel>("AppModel", 1, 0, "ApplicationModel");
// DBus
qDBusRegisterMetaType<AppInfo>();
- qDBusRegisterMetaType<QList<AppInfo> >();
-
- ApplicationLauncher *launcher = new ApplicationLauncher();
- QLibWindowmanager* layoutHandler = new QLibWindowmanager();
- if(layoutHandler->init(port,token) != 0){
- exit(EXIT_FAILURE);
- }
-
- AGLScreenInfo screenInfo(layoutHandler->get_scale_factor());
+ qDBusRegisterMetaType<QList<AppInfo>>();
- if (layoutHandler->requestSurface(myname) != 0) {
- exit(EXIT_FAILURE);
- }
-
- layoutHandler->set_event_handler(QLibWindowmanager::Event_SyncDraw, [layoutHandler, myname](json_object *object) {
- layoutHandler->endDraw(myname);
- });
-
- layoutHandler->set_event_handler(QLibWindowmanager::Event_Visible, [layoutHandler, launcher](json_object *object) {
- QString label = QString(json_object_get_string( json_object_object_get(object, "drawing_name") ));
- qDebug() << label;
- QMetaObject::invokeMethod(launcher, "setCurrent", Qt::QueuedConnection, Q_ARG(QString, label == "HomeScreen" ? "Home" : label));
- });
-
- layoutHandler->set_event_handler(QLibWindowmanager::Event_Invisible, [layoutHandler, launcher](json_object *object) {
- const char* label = json_object_get_string( json_object_object_get(object, "drawing_name") );
- HMI_DEBUG("launch", "surface %s Event_Invisible", label);
- });
-
- HomescreenHandler* homescreenHandler = new HomescreenHandler();
- homescreenHandler->init(port, token.toStdString().c_str(), layoutHandler, myname);
+ ApplicationLauncher *launcher =
+ new ApplicationLauncher(CONNECT_STR, &a);
+ ApplicationHandler *homescreenHandler =
+ new ApplicationHandler(nullptr, launcher->get_launcher());
QUrl bindingAddress;
bindingAddress.setScheme(QStringLiteral("ws"));
@@ -129,28 +78,14 @@ int main(int argc, char *argv[])
query.addQueryItem(QStringLiteral("token"), token);
bindingAddress.setQuery(query);
- const QByteArray hack_delay = qgetenv("HMI_LAUNCHER_STARTUP_DELAY");
- int delay_time = 1;
-
- if (!hack_delay.isEmpty()) {
- delay_time = (QString::fromLocal8Bit(hack_delay)).toInt();
- }
-
- QThread::sleep(delay_time);
- qDebug("Sleep %d sec to resolve race condtion between HomeScreen and Launcher", delay_time);
-
// mail.qml loading
QQmlApplicationEngine engine;
- engine.rootContext()->setContextProperty(QStringLiteral("layoutHandler"), layoutHandler);
+
engine.rootContext()->setContextProperty(QStringLiteral("homescreenHandler"), homescreenHandler);
engine.rootContext()->setContextProperty(QStringLiteral("launcher"), launcher);
- engine.rootContext()->setContextProperty(QStringLiteral("screenInfo"), &screenInfo);
engine.load(QUrl(QStringLiteral("qrc:/Launcher.qml")));
- homescreenHandler->getRunnables();
- QObject *root = engine.rootObjects().first();
- QQuickWindow *window = qobject_cast<QQuickWindow *>(root);
- QObject::connect(window, SIGNAL(frameSwapped()), layoutHandler, SLOT(slotActivateSurface()));
+ homescreenHandler->getRunnables();
return a.exec();
}