Desktop PC development support 21/13021/1
authorTasuku Suzuki <tasuku.suzuki@qt.io>
Wed, 27 Dec 2017 11:32:36 +0000 (20:32 +0900)
committerTasuku Suzuki <tasuku.suzuki@qt.io>
Wed, 27 Dec 2017 11:35:51 +0000 (20:35 +0900)
Add tests if libhomescreen and qlibwindowmanager are available and use
them only when they are available.

Change-Id: I6b219721b279542bf474f3df34bfb3adbc6e9ff0
Signed-off-by: Tasuku Suzuki <tasuku.suzuki@qt.io>
app/app.pri
app/app.pro
app/config.tests/libhomescreen/libhomescreen.pro
app/config.tests/qlibwindowmanager/qlibwindowmanager.cpp [new file with mode: 0644]
app/config.tests/qlibwindowmanager/qlibwindowmanager.pro [new file with mode: 0644]
app/main.cpp

index e535cbc..590c154 100644 (file)
@@ -2,4 +2,19 @@ TEMPLATE = app
 
 load(configure)
 
+qtCompileTest(libhomescreen)
+qtCompileTest(qlibwindowmanager)
+
+config_libhomescreen {
+    CONFIG += link_pkgconfig
+    PKGCONFIG += libhomescreen
+    DEFINES += HAVE_LIBHOMESCREEN
+}
+
+config_qlibwindowmanager {
+    CONFIG += link_pkgconfig
+    PKGCONFIG += qlibwindowmanager
+    DEFINES += HAVE_QLIBWINDOWMANAGER
+}
+
 DESTDIR = $${OUT_PWD}/../package/root/bin
index 6cd3ead..da4e8a4 100644 (file)
@@ -3,9 +3,6 @@ QT = quick qml
 
 SOURCES = main.cpp
 
-CONFIG += link_pkgconfig
-PKGCONFIG += libhomescreen libwindowmanager qlibwindowmanager
-
 RESOURCES += \
     hvac.qrc \
     images/images.qrc
index eb4e8f3..7d43112 100644 (file)
@@ -2,4 +2,4 @@ SOURCES = libhomescreen.cpp
 
 CONFIG -= qt
 CONFIG += link_pkgconfig
-PKGCONFIG += homescreen
+PKGCONFIG += libhomescreen
diff --git a/app/config.tests/qlibwindowmanager/qlibwindowmanager.cpp b/app/config.tests/qlibwindowmanager/qlibwindowmanager.cpp
new file mode 100644 (file)
index 0000000..bb95c93
--- /dev/null
@@ -0,0 +1,8 @@
+#include <qlibwindowmanager.h>
+
+int main(int argc,char **argv)
+{
+    QLibWindowmanager qwm;
+    return 0;
+}
+
diff --git a/app/config.tests/qlibwindowmanager/qlibwindowmanager.pro b/app/config.tests/qlibwindowmanager/qlibwindowmanager.pro
new file mode 100644 (file)
index 0000000..cb51d98
--- /dev/null
@@ -0,0 +1,5 @@
+SOURCES = qlibwindowmanager.cpp
+
+CONFIG += qt
+CONFIG += link_pkgconfig
+PKGCONFIG += qlibwindowmanager
index 574e9a5..b793ef3 100644 (file)
 #include <QtGui/QGuiApplication>
 #include <QtQml/QQmlApplicationEngine>
 #include <QtQml/QQmlContext>
-#include <QQuickWindow>
+#include <QtQuick/QQuickWindow>
+
+#ifdef HAVE_LIBHOMESCREEN
 #include <libhomescreen.hpp>
+#endif
+#ifdef HAVE_QLIBWINDOWMANAGER
 #include <qlibwindowmanager.h>
+#endif
 
 int main(int argc, char *argv[])
 {
@@ -42,10 +47,12 @@ int main(int argc, char *argv[])
     QStringList positionalArguments = parser.positionalArguments();
 
     QQmlApplicationEngine engine;
+    QQmlContext *context = engine.rootContext();
+    QUrl bindingAddress;
+
     if (positionalArguments.length() == 2) {
         int port = positionalArguments.takeFirst().toInt();
         QString secret = positionalArguments.takeFirst();
-        QUrl bindingAddress;
         bindingAddress.setScheme(QStringLiteral("ws"));
         bindingAddress.setHost(QStringLiteral("localhost"));
         bindingAddress.setPort(port);
@@ -53,49 +60,57 @@ int main(int argc, char *argv[])
         QUrlQuery query;
         query.addQueryItem(QStringLiteral("token"), secret);
         bindingAddress.setQuery(query);
-        QQmlContext *context = engine.rootContext();
-        context->setContextProperty(QStringLiteral("bindingAddress"), bindingAddress);
+    }
+    context->setContextProperty(QStringLiteral("bindingAddress"), bindingAddress);
+#ifdef HAVE_QLIBWINDOWMANAGER
+    QLibWindowmanager* qwm = new QLibWindowmanager();
 
-        std::string token = secret.toStdString();
-        LibHomeScreen* hs = new LibHomeScreen();
-        QLibWindowmanager* qwm = new QLibWindowmanager();
+    // WindowManager
+    if(qwm->init(port,secret) != 0){
+        exit(EXIT_FAILURE);
+    }
+    // Request a surface as described in layers.json windowmanager’s file
+    if (qwm->requestSurface(myname) != 0) {
+        exit(EXIT_FAILURE);
+    }
+    // Create an event callbnewack against an event type. Here a lambda is called when SyncDraw event occurs
+    qwm->set_event_handler(QLibWindowmanager::Event_SyncDraw, [qwm, myname](json_object *object) {
+        fprintf(stderr, "Surface got syncDraw!\n");
+        qwm->endDraw(myname);
+    });
+#endif
 
-        // WindowManager
-        if(qwm->init(port,secret) != 0){
-            exit(EXIT_FAILURE);
-        }
-        // Request a surface as described in layers.json windowmanager’s file
-        if (qwm->requestSurface(myname) != 0) {
-            exit(EXIT_FAILURE);
-        }
-        // Create an event callbnewack against an event type. Here a lambda is called when SyncDraw event occurs
-        qwm->set_event_handler(QLibWindowmanager::Event_SyncDraw, [qwm, myname](json_object *object) {
-            fprintf(stderr, "Surface got syncDraw!\n");
-            qwm->endDraw(myname);
-        });
+#ifdef HAVE_LIBHOMESCREEN
+    LibHomeScreen* hs = new LibHomeScreen();
 
-        // HomeScreen
-        hs->init(port, token.c_str());
-        // Set the event handler for Event_TapShortcut which will activate the surface for windowmanager
-        hs->set_event_handler(LibHomeScreen::Event_TapShortcut, [qwm, myname](json_object *object){
-            json_object *appnameJ = nullptr;
-            if(json_object_object_get_ex(object, "application_name", &appnameJ))
+    // HomeScreen
+    std::string token = secret.toStdString();
+    hs->init(port, token.c_str());
+    // Set the event handler for Event_TapShortcut which will activate the surface for windowmanager
+    hs->set_event_handler(LibHomeScreen::Event_TapShortcut, [qwm, myname](json_object *object){
+        json_object *appnameJ = nullptr;
+        if(json_object_object_get_ex(object, "application_name", &appnameJ))
+        {
+            const char *appname = json_object_get_string(appnameJ);
+            if(myname == appname)
             {
-                const char *appname = json_object_get_string(appnameJ);
-                if(myname == appname)
-                {
-                    qDebug("Surface %s got tapShortcut\n", appname);
-                    qwm->activateSurface(myname);
-                }
+                qDebug("Surface %s got tapShortcut\n", appname);
+                qwm->activateSurface(myname);
             }
-        });
+        }
+    });
+#endif
+
+    engine.load(QUrl(QStringLiteral("qrc:/HVAC.qml")));
+    QObject *root = engine.rootObjects().first();
+    QQuickWindow *window = qobject_cast<QQuickWindow *>(root);
+#ifdef HAVE_QLIBWINDOWMANAGER
+    QObject::connect(window, SIGNAL(frameSwapped()), qwm, SLOT(slotActivateSurface()));
+#else
+    window->resize(1080, 1920 - 218 - 215);
+    window->setVisible(true);
+#endif
 
-        engine.load(QUrl(QStringLiteral("qrc:/HVAC.qml")));
-        QObject *root = engine.rootObjects().first();
-        QQuickWindow *window = qobject_cast<QQuickWindow *>(root);
-        QObject::connect(window, SIGNAL(frameSwapped()), qwm, SLOT(slotActivateSurface()
-        ));
-    }
     return app.exec();
 }